博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
产看Linux运行时间
阅读量:5886 次
发布时间:2019-06-19

本文共 3555 字,大约阅读时间需要 11 分钟。

1.uptime命令

输出:16:11:40 up 59 days, 4:21, 2 users, load average: 0.00, 0.01, 0.00
2.查看/proc/uptime文件计算系统启动时间
cat /proc/uptime
输出: 5113396.94 575949.85
第一数字即是系统已运行的时间5113396.94 秒,运用系统工具date即可算出系统启动时间

代码: 
date -d "$(awk -F. '{print $1}' /proc/uptime) second ago" +"%Y-%m-%d %H:%M:%S"

输出: 2008-11-09 11:50:31
3.查看/proc/uptime文件计算系统运行时间

代码: 
cat /proc/uptime| awk -F. '{run_days=$1 / 86400;run_hour=($1 % 86400)/3600;run_minute=($1 % 3600)/60;run_second=$1 % 60;printf("系统已运行:%d天%d时%d分%d秒",run_days,run_hour,run_minute,run_second)}'

输出:系统已运行:59天4时13分9秒

 

 

下面的摘自  

1: who 命令查看

      who -b 查看最后一次系统启动的时间。

      who -r 查看当前系统运行时间

[root@DB-Server ~]# who -b

         system boot May 11 09:27

 

2: last  reboot

如下所示last reboot可以看到Linux系统历史启动的时间。 重启一下操作系统后,然后

[root@DB-Server ~]# last reboot

reboot

 system boot 2.6.9-42.ELsmp Thu May 29 15:25 (00:07)

 

reboot system boot 2.6.9-42.ELsmp Sun May 11 09:27 (18+05:55)

 

wtmp begins Mon May 5 16:18:57 2014

 

 

如果只需要查看最后一次Linux系统启动的时间

 

[root@DB-Server ~]# last reboot | head -1

 

reboot

 system boot 2.6.9-42.ELsmp Thu May 29 15:25 (00:08) 

 

 

 

3:TOP命令查看

 

    如下截图所示,up后表示系统到目前运行了多久时间。反过来推算系统重启时间

 

4:w  命令查看

 

 

 

4: w命令查看

 

如下截图所示,up后表示系统到目前运行了多久时间。反过来推算系统重启时间

 

 

 

5:uptime 命令查看

 

 

 

 

6: 查看/proc/uptime

 

[root@DB-Server ~]# cat /proc/uptime

 

1415.59 1401.42

 

[root@DB-Server ~]# date -d "`cut -f1 -d. /proc/uptime` seconds ago"

 

Thu May 29 15:24:57 CST 2014

 

[root@DB-Server ~]# date -d "$(awk -F. '{print $1}' /proc/uptime) second ago" +"%Y-%m-%d %H:%M:%S" 

 

2014-05-29 15:24:57

 

 

 

 

 下面的是程序的方式 ,在程序开发的时候会比较有用。摘自

 

1、前言

  时间对操作系统来说非常重要,从内核级到应用层,时间的表达方式及精度各部相同。linux内核里面用一个名为jiffes的常量来计算时间戳。应用层有time、getdaytime等函数。今天需要在应用程序获取系统的启动时间,百度了一下,通过sysinfo中的uptime可以计算出系统的启动时间。

2、sysinfo结构

  sysinfo结构保持了系统启动后的信息,主要包括启动到现在的时间,可用内存空间、共享内存空间、进程的数目等。man sysinfo得到结果如下所示:

1 struct sysinfo { 2                long uptime;             /* Seconds since boot */ 3                unsigned long loads[3];  /* 1, 5, and 15 minute load averages */ 4                unsigned long totalram;  /* Total usable main memory size */ 5                unsigned long freeram;   /* Available memory size */ 6                unsigned long sharedram; /* Amount of shared memory */ 7                unsigned long bufferram; /* Memory used by buffers */ 8                unsigned long totalswap; /* Total swap space size */ 9                unsigned long freeswap;  /* swap space still available */10                unsigned short procs;    /* Number of current processes */11                char _f[22];             /* Pads structure to 64 bytes */12            };

3、获取系统启动时间

  通过sysinfo获取系统启动到现在的秒数,用当前时间减去这个秒数即系统的启动时间。程序如下所示:

1 #include 
2 #include
3 #include
4 #include
5 6 static int print_system_boot_time() 7 { 8 struct sysinfo info; 9 time_t cur_time = 0;10 time_t boot_time = 0;11 struct tm *ptm = NULL;12 if (sysinfo(&info)) {13 fprintf(stderr, "Failed to get sysinfo, errno:%u, reason:%s\n",14 errno, strerror(errno));15 return -1;16 }17 time(&cur_time);18 if (cur_time > info.uptime) {19 boot_time = cur_time - info.uptime;20 }21 else {22 boot_time = info.uptime - cur_time;23 }24 ptm = gmtime(&boot_time);25 printf("System boot time: %d-%-d-%d %d:%d:%d\n", ptm->tm_year + 1900,26 ptm->tm_mon + 1, ptm->tm_mday, ptm->tm_hour, ptm->tm_min, ptm->tm_sec);27 return 0; 28 }29 30 int main()31 {32 if (print_system_boot_time() != 0) {33 return -1;34 }35 return 0;36 }

测试结果如下所:

 
 
标签: 

转载于:https://www.cnblogs.com/zhouhbing/p/4989611.html

你可能感兴趣的文章
winform 窗体实现增删改查(CRUD)窗体基类模式
查看>>
MySQL · 特性分析 · 数据一样checksum不一样
查看>>
CIO的责任不仅仅是信息管理
查看>>
vs2015 Xamarin.Android安装
查看>>
SpringMVC空字符串转为null
查看>>
我需要完全理解这部分代码才能确保它能够正常工作,如果由我来修复代码中的问题,我是不会这么写的,因此希望你也不要这么来写(转)...
查看>>
Spark_SQl
查看>>
查看光纤卡的WWN号
查看>>
【百度地图API】如何在地图上添加标注?——另有:坐标拾取工具+打车费用接口介绍...
查看>>
机器学习之梯度下降法
查看>>
笔记本外接2-3个屏幕
查看>>
SDL2.0教程翻译·目录
查看>>
嵌入式 Linux进程含义知多少
查看>>
类加载器的双亲委派及打破双亲委派
查看>>
Docker入门教程(二)命令
查看>>
python中多线程与非线程的执行性能对比
查看>>
R3 Corda 1.0即将问世,创想本地硬件和云端存储混合的未来
查看>>
安全市场风云变幻 Sophos发力移动和云
查看>>
Android应用UI设计流程
查看>>
如何在 Swift 3 中用 SpriteKit 框架编写游戏 (Part 2)
查看>>