mount
매뉴얼 페이지 에 따르면 ,
이전 액세스 시간이 현재 수정 또는 변경 시간보다 이전인 경우에만 액세스 시간이 업데이트됩니다.
그러나 이렇게 하면( relatime
옵션(*)이 있는 ext4):
> date +%T.%N ; dd if=/dev/random of=random.dat bs=1 count=4096 ; date +%T.%N ; stat random.dat
18:52:00.616084761
4096+0 records in
4096+0 records out
4096 bytes (4.1 kB, 4.0 KiB) copied, 0.0319383 s, 128 kB/s
18:52:00.651183318
File: random.dat
Size: 4096 Blocks: 8 IO Block: 4096 regular file
Device: fd01h/64769d Inode: 28313073 Links: 1
Access: (0664/-rw-rw-r--) Uid: ( 1000/ me) Gid: ( 1000/ me)
Access: 2022-09-26 18:52:00.616297607 +0200
Modify: 2022-09-26 18:52:00.648297639 +0200
Change: 2022-09-26 18:52:00.648297639 +0200
Birth: -
액세스 시간은 생성 시간과 일치하는 것으로 보이며 다시 실행하면(즉, random.dat
현재 존재하며 더 새로운 inode와 동일함) 다음과 같은 결과를 얻습니다.
> date +%T.%N ; dd if=/dev/random of=random.dat bs=1 count=4096 ; date +%T.%N ; stat random.dat
18:52:43.014712313
4096+0 records in
4096+0 records out
4096 bytes (4.1 kB, 4.0 KiB) copied, 0.0633748 s, 64.6 kB/s
18:52:43.081174320
File: random.dat
Size: 4096 Blocks: 8 IO Block: 4096 regular file
Device: fd01h/64769d Inode: 28313073 Links: 1
Access: (0664/-rw-rw-r--) Uid: ( 1000/ me) Gid: ( 1000/ me)
Access: 2022-09-26 18:52:00.616297607 +0200
Modify: 2022-09-26 18:52:43.076338407 +0200
Change: 2022-09-26 18:52:43.076338407 +0200
Birth: -
...파일 내용을 완전히 다시 작성했음에도 불구하고 액세스 시간은 전혀 변하지 않았습니다.
내가 무엇을 놓쳤거나 잘못 이해했나요? 수정 및 변경으로 접속 시간을 업데이트하면 안되는 걸까요?
(*)/dev/mapper/vgkubuntu-root on / type ext4 (rw,relatime,errors=remount-ro)
(**) dd if=/dev/random
데모용(느린 출력)
답변1
데이터 블록에 액세스하지 않고(쓰기만 함) atime이 업데이트되지 않습니다. Random.dat를 읽으면 atime이 업데이트됩니다(관련 시간 기준이 충족되는 한).
file_accessed()
커널에서 호출을 찾을 때 다음을 볼 수 있습니다.
https://github.com/torvalds/linux/blob/master/fs/ext4/file.c
file_accessed는 inode의 atime을 업데이트하는 루틴을 호출하며 읽기 함수(및 mmap) 내에서만 호출됩니다.