1.uptime命令
輸出:16:11:40 up 59 days, 4:21, 2 users, load average: 0.00, 0.01, 0.00php
2.查看/proc/uptime文件計算系統啓動時間
cat /proc/uptime
輸出: 5113396.94 575949.85
第一數字便是系統已運行的時間5113396.94 秒,運用系統工具date便可算出系統啓動時間linux
[root@localhost ~]# date -d "$(awk -F. '{print $1}' /proc/uptime) second ago" +"%Y-%m-%d %H:%M:%S" 2017-10-27 14:32:35
3.查看/proc/uptime文件計算系統運行時間bash
[root@localhost ~]# 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)}' 系統已運行:0天0時24分34秒
1: who 命令查看函數
who -b 查看最後一次系統啓動的時間。工具
[root@localhost ~]# who -b system boot 2017-10-27 14:32
who -r 查看當前系統運行時間測試
[root@localhost ~]# who -r run-level 3 2017-10-27 14:33
2: last rebootspa
以下所示last reboot能夠看到Linux系統歷史啓動的時間。 重啓一下操做系統後,而後操作系統
[root@DB-Server ~]# last rebootcode
[root@localhost ~]# last reboot reboot system boot 3.10.0-327.el7.x Fri Oct 27 14:32 - 14:59 (00:26) wtmp begins Fri Oct 27 14:32:39 2017
#若是隻須要查看最後一次Linux系統啓動的時間server
[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後表示系統到目前運行了多久時間。反過來推算系統重啓時間
[root@localhost ~]# who -b system boot 2017-10-27 14:32 top - 15:00:29 up 27 min, 2 users, load average: 0.00, 0.01, 0.05 Tasks: 99 total, 1 running, 98 sleeping, 0 stopped, 0 zombie %Cpu(s): 0.0 us, 0.2 sy, 0.0 ni, 99.8 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st KiB Mem : 8176008 total, 7892856 free, 131764 used, 151388 buff/cache KiB Swap: 8257532 total, 8257532 free, 0 used. 7868548 avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1855 root 20 0 0 0 0 S 0.3 0.0 0:00.33 kworker/0:2 1 root 20 0 44496 7168 2612 S 0.0 0.1 0:02.32 systemd 2 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kthreadd 3 root 20 0 0 0 0 S 0.0 0.0 0:00.05 ksoftirqd/0 5 root 0 -20 0 0 0 S 0.0 0.0 0:00.00 kworker/0:0H 6 root 20 0 0 0 0 S 0.0 0.0 0:00.03 kworker/u4:0 7 root rt 0 0 0 0 S 0.0 0.0 0:00.06 migration/0 8 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcu_bh 9 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcuob/0 10 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcuob/1 11 root 20 0 0 0 0 S 0.0 0.0 0:00.33 rcu_sched 12 root 20 0 0 0 0 S 0.0 0.0 0:00.12 rcuos/0 13 root 20 0 0 0 0 S 0.0 0.0 0:00.37 rcuos/1 14 root rt 0 0 0 0 S 0.0 0.0 0:00.01 watchdog/0 15 root rt 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/1 16 root rt 0 0 0 0 S 0.0 0.0 0:00.08 migration/1 17 root 20 0 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/1 19 root 0 -20 0 0 0 S 0.0 0.0 0:00.00 kworker/1:0H
4: w命令查看
以下截圖所示,up後表示系統到目前運行了多久時間。反過來推算系統重啓時間
[root@localhost ~]# w 15:00:56 up 28 min, 2 users, load average: 0.00, 0.01, 0.05 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT root tty1 14:33 25:52 0.07s 0.07s -bash root pts/0 10.0.100.55 14:37 0.00s 0.10s 0.00s w
5:uptime 命令查看
[root@localhost ~]# uptime 15:01:40 up 29 min, 2 users, load average: 0.00, 0.01, 0.05
6: 查看/proc/uptime
方法一:
[root@localhost ~]# cat /proc/uptime 1778.05 3520.28
方法二:
[root@localhost ~]# date -d "`cut -f1 -d. /proc/uptime` seconds ago" Fri Oct 27 14:32:35 CST 2017
方法三:
[root@localhost ~]# date -d "$(awk -F. '{print $1}' /proc/uptime) second ago" +"%Y-%m-%d %H:%M:%S" 2017-10-27 14:32:35
一、前言
時間對操做系統來講很是重要,從內核級到應用層,時間的表達方式及精度各部相同。linux內核裏面用一個名爲jiffes的常量來計算時間戳。應用層有time、getdaytime等函數。
在應用程序獲取系統的啓動時間,經過sysinfo中的uptime能夠計算出系統的啓動時間。
二、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 };
三、獲取系統啓動時間
經過sysinfo獲取系統啓動到如今的秒數,用當前時間減去這個秒數即系統的啓動時間。程序以下所示:
1 #include <stdio.h> 2 #include <sys/sysinfo.h> 3 #include <time.h> 4 #include <errno.h> 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 }
測試結果以下所:
#查看系統安裝時間
[root@control1 ~]# tune2fs -l /dev/sda1 | grep create
Filesystem created: Tue Aug 15 16:52:06 2017
#經過查看系統建立帳號時間來判斷系統安裝日期
[root@zabbix-server ~]# passwd -S zabbix zabbix LK 2017-06-28 -1 -1 -1 -1 (密碼已被鎖定。)