시스템 부팅 시각및 시간 알아보기
페이지 정보
작성자 MintState 댓글 0건 조회 18,747회 작성일 08-11-20 12:43본문
시스템 부팅 시각및 시간 알아보기
- 작성자 : 김칠봉 <san2(at)linuxchannel.net>
- 작성일 : 2002.11.09
- 분 류 : 시스템관리(SE)
- 수 준 : 초보
- 내 용 : 시스템 부팅 시각(시점)과 시간을 알아보는 방법
- 키워드 : uptime, last, /proc/uptime, /proc/stat, perl, PHP
*주)
이 문서에 대한 최신 내용은 아래 URL에서 확인할 수 있습니다.
http://www.linuxchannel.net/docs/sys-uptime.txt
[방법1] uptime 명령어
가장 간단한 방법입니다.
현재 제 시스템은 부팅후 2시간 12분 지났군요.. 위의 오후 9시 01분부터 역으로 거슬러
올라가면 부팅 시각을 알 수 있겠죠.... (계산하지 마세요. T.T)
[방법2] last 명령어
제일 마지막의 (02:12) 값이 시스템 uptime 입니다. 즉 2시간 12분 지났다는 의미입니다. 그리고 'Sat Nov 9 18:50'은 시스템 boot time 입니다.
첫번째 값은 시스템이 부팅후 현재 시각까지의 부팅 시간을 초단위로 표시한 sytem uptime 값입니다. 두번째 값은 'idle uptime' 입니다. (reference : /usr/src/linux/fs/proc/proc_misc.c)
위의 7979 초를 계산하니 시스템이 부팅된지 약 2시간 13분이되었군요. (uptime 명령어로 확인하면 거의 같은 값임)
그럼 좀더 정확하게 부팅 시각을 계산해 봅시다. 부팅후 구동 시간이 7979초이므로 현재 UNIX timestamp 값에서 7979초를 빼면 부팅시점의 Unix timestamp 값이 계산되죠.. 이 값을 perl의 gmdate()이나 PHP의 data() 함수를 이용하면 쉽게 부팅시점의 시각을 알 수 있습니다(C는 생략).
-- uptime.pl -------------------------------------------------------
(실행 결과)
-- uptime.php ------------------------------------------------------
<팁> 실시간(1초간격)으로 uptime 보기
# watch -n 1 cat /proc/uptime
종료는 'Ctrl + C'
</팁>
<참고> PHP sysinfo(http://ftp.linuxchannel.net/devel/sysinfo.tar)
최근 버전에는 boot time을 추가되었습니다.
</참고>
[방법4] /proc/stat 이용
8번째 항목의 btime 값(1036835394)이 바로 부팅시의 UNIX timestamp 값입니다. 이 값은 [방법3]에서 계산한 $btime 값과 같습니다(오차1초). 바꾸어 말하면 현재 UNIX timestamp 값에서 이 btime 값을 빼면 시스템 uptime 값이 나옵니다. 이 uptime 값은 [방법3]에서 얻은 $uptime[0] 값과 같습니다.
이번에는 이 btime 값을 얻어서 boot time을 출력하고 uptime 값을 계산하여 읽기 편하게 출력해 봅시다.
-- uptime2.pl -------------------------------------------------------
(헙... perl은 역시 어렵군요... T.T)
(실행 결과)
-- uptime2.php ------------------------------------------------------
[방법5] 그 외에 부팅시 생성/갱신되는 로그 파일의 확인
EOF
- 작성자 : 김칠봉 <san2(at)linuxchannel.net>
- 작성일 : 2002.11.09
- 분 류 : 시스템관리(SE)
- 수 준 : 초보
- 내 용 : 시스템 부팅 시각(시점)과 시간을 알아보는 방법
- 키워드 : uptime, last, /proc/uptime, /proc/stat, perl, PHP
*주)
이 문서에 대한 최신 내용은 아래 URL에서 확인할 수 있습니다.
http://www.linuxchannel.net/docs/sys-uptime.txt
[방법1] uptime 명령어
가장 간단한 방법입니다.
현재 제 시스템은 부팅후 2시간 12분 지났군요.. 위의 오후 9시 01분부터 역으로 거슬러
올라가면 부팅 시각을 알 수 있겠죠.... (계산하지 마세요. T.T)
[방법2] last 명령어
제일 마지막의 (02:12) 값이 시스템 uptime 입니다. 즉 2시간 12분 지났다는 의미입니다. 그리고 'Sat Nov 9 18:50'은 시스템 boot time 입니다.
첫번째 값은 시스템이 부팅후 현재 시각까지의 부팅 시간을 초단위로 표시한 sytem uptime 값입니다. 두번째 값은 'idle uptime' 입니다. (reference : /usr/src/linux/fs/proc/proc_misc.c)
위의 7979 초를 계산하니 시스템이 부팅된지 약 2시간 13분이되었군요. (uptime 명령어로 확인하면 거의 같은 값임)
그럼 좀더 정확하게 부팅 시각을 계산해 봅시다. 부팅후 구동 시간이 7979초이므로 현재 UNIX timestamp 값에서 7979초를 빼면 부팅시점의 Unix timestamp 값이 계산되죠.. 이 값을 perl의 gmdate()이나 PHP의 data() 함수를 이용하면 쉽게 부팅시점의 시각을 알 수 있습니다(C는 생략).
-- uptime.pl -------------------------------------------------------
(실행 결과)
-- uptime.php ------------------------------------------------------
<?php $uptime = file('/proc/uptime'); $btime = time() - (int)$uptime[0]; echo 'boot time: ' . date('Y.m.d H:i:s',$btime); ?>
<팁> 실시간(1초간격)으로 uptime 보기
# watch -n 1 cat /proc/uptime
종료는 'Ctrl + C'
</팁>
<참고> PHP sysinfo(http://ftp.linuxchannel.net/devel/sysinfo.tar)
최근 버전에는 boot time을 추가되었습니다.
</참고>
[방법4] /proc/stat 이용
8번째 항목의 btime 값(1036835394)이 바로 부팅시의 UNIX timestamp 값입니다. 이 값은 [방법3]에서 계산한 $btime 값과 같습니다(오차1초). 바꾸어 말하면 현재 UNIX timestamp 값에서 이 btime 값을 빼면 시스템 uptime 값이 나옵니다. 이 uptime 값은 [방법3]에서 얻은 $uptime[0] 값과 같습니다.
이번에는 이 btime 값을 얻어서 boot time을 출력하고 uptime 값을 계산하여 읽기 편하게 출력해 봅시다.
-- uptime2.pl -------------------------------------------------------
(헙... perl은 역시 어렵군요... T.T)
(실행 결과)
-- uptime2.php ------------------------------------------------------
<?php $stat = file('/proc/stat'); $stat[7] = preg_replace('/[^\d]+/','',$stat[7]); $btime = date('Y.m.d H:i:s',$stat[7]); $uptime = runtime(time()-$stat[7]); echo <<<_EOF_ boot time\t: $btime<BR> system uptime\t: $uptime<BR> _EOF_; function runtime($term, $lang='kr') { $l[kr] = $l[ko] = array('초','분','시간','일','달'); $l[en] = array('seconds','minutes','hours','days','mon'); $days = (int)($term / 86400); $secs = (int)($term % 86400); $hours = (int)($secs / 3600); $secs = (int)($secs % 3600); $mins = (int)($secs / 60); $secs = (int)($secs % 60); $days = $days ? $days.$l[$lang][3] : ''; $hours = $hours ? " $hours".$l[$lang][2] : ''; $mins = $mins ? " $mins".$l[$lang][1].' ' : ''; $secs .= $l[$lang][0]; return "$days$hours$mins$secs"; } ?>
[방법5] 그 외에 부팅시 생성/갱신되는 로그 파일의 확인
EOF
|
댓글목록
등록된 댓글이 없습니다.