리눅스를 사용시.. 특히 find 옵션을 줄때
atime
mtime
ctime
등 의 옵션을 주는경우가 있다.
혹시 이 내용의 구분이 어렵다면 다음과 같이 생각해 보자.
1. 파일정보
명령어 : stat
stat 명령을 이용해서 파일을 보자.
결과가 대략 이렇게 나오는데
File: `hw.txt'
Size: 22975 Blocks: 48 IO Block: 4096 일반 파일
Device: 802h/2050d Inode: 786492 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2014-10-20 10:55:08.477882048 +0900
Modify: 2014-10-01 13:19:06.799179062 +0900
Change: 2014-10-01 13:19:06.799179062 +0900
Birth: -
위 정보중
Access 에 기록된 시간이 바로 atime
Modify 에 기록된 시간이 바로 mtime
Change 에 기록된 시간이 바로 ctime
이 되겠다...
위 파일을 가지고 예를들어 설명해 보도록 하겠다.
2. atime
말그대로 파일에 접근한 시간을 의미한다.
편집기로 열거나, 아니면 파일의 내용을 확인하는 형태의 다른 명령어(grep 등.. )가 실행될 경우 변경된다.
# stat hw.txt
File: `hw.txt'
Size: 22975 Blocks: 48 IO Block: 4096 일반 파일
Device: 802h/2050d Inode: 786492 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2014-11-26 17:43:18.723701989 +0900
Modify: 2014-10-01 13:19:06.799179062 +0900
Change: 2014-10-01 13:19:06.799179062 +0900
Birth: -
예제처럼 grep 을 이용해서 hw.txt 파일에 접근후 stat 으로 상태 확인을 해보면
Access 항목 즉, atime 이 변경되었음을 알 수 있다.
3. ctime
파일이 수정된 시간인데... 그중에서도 파일의 속성이 수정된 시간을 의미한다.
- 퍼미션
- 소유권
등의 정보 수정이 이루어질때 변경된다.
# stat hw.txt
File: `hw.txt'
Size: 22978 Blocks: 48 IO Block: 4096 일반 파일
Device: 802h/2050d Inode: 786492 Links: 1
Access: (0600/-rw-------) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2014-11-26 17:43:18.723701989 +0900
Modify: 2014-10-01 13:19:06.799179062 +0900
Change: 2014-11-26 17:49:54.541238037 +0900
Birth: -
4. mtime
파일이 수정된 시간인데... 그중에서도 파일의 내용이 수정된 시간을 의미한다.
파일내용이 수정/추가/삭제 등의 작업이 이루어질때 변경된다.
# stat hw.txt
File: `hw.txt'
Size: 22994 Blocks: 48 IO Block: 4096 일반 파일
Device: 802h/2050d Inode: 786247 Links: 1
Access: (0600/-rw-------) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2014-11-26 17:53:48.765890656 +0900
Modify: 2014-11-26 17:55:33.267827347 +0900
Change: 2014-11-26 17:55:33.267827347 +0900
Birth: -
설명에는 파일내용이 수정될때 mtime이 변경된다고 했는데..
파일을 수정후에 stat을 통한 결과를 보자 ctime 이 같은 시간으로 변경된것을 알 수 있다.
이것은 파일 내용이 수정될때.. 내용뿐만 아니라 파일 사이즈가 같이 수정되었기 때문이고
파일 사이즈는 파일의 속성이기 때문에 같이 변경된다고 이해하면 되겠다...
이상~
댓글 0
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
154 | /etc/fstab 설정하기 [1] | 위대한유저 | 2009.01.29 | 234326 |
153 | /proc/meminfo 의 고찰! | 위대한유저 | 2009.09.16 | 190490 |
152 | telnet 커맨드를 이용한 메일발송 테스트 | 위대한유저 | 2009.11.29 | 121156 |
151 | 데비안(debian)계열에서 apt-get 사용하다 GPG 에러 발생시 | 위대한유저 | 2009.11.10 | 111780 |
150 | 구버전 MySQL(to 4.0) 에서 바이너리 로그 정리하기 | 위대한유저 | 2011.07.02 | 104454 |
149 | XE 업데이트(및 기타상황)에서 로그인이 되지 않을때 | 위대한유저 | 2011.10.06 | 82694 |
148 | XE 스팸성 엮인글 관리 | 위대한유저 | 2013.06.17 | 80592 |
147 | 제로보드4 에서 한글파일 다운로드가 되지 않을때 | 위대한유저 | 2010.01.24 | 79185 |
146 | FTP 상태코드 | 위대한유저 | 2009.08.28 | 78604 |
145 | piwik analytics 사용시 이메일보고서의 그래프 내용중 한글이 깨지는문제 | 위대한유저 | 2013.05.23 | 67653 |
144 | HTTP 응답코드 | 위대한유저 | 2009.04.02 | 64545 |
143 | debian repository (old version) | 위대한유저 | 2013.04.11 | 57167 |
142 | linux 에서 cisco console 연결하기 | 위대한유저 | 2013.03.28 | 46285 |
141 | Control-D 화면에 대한 고찰 | 위대한유저 | 2009.03.13 | 43698 |
140 | 리눅스에서 arp cache 삭제/초기화 하는 방법 | 위대한유저 | 2015.05.29 | 34005 |