10.statm文件
描述進程的內存狀態。
niutao@niutao-desktop:/proc/6950$ cat statm 12992 4432 3213 144 0 1028 0 niutao@niutao-desktop:/proc/6950$
|
下面我們來詳細解釋該文件中內容的含義。首先我們可以在內核中搜索到該文件的內容是由函數proc_pid_statm()函數寫入的:(/fs/proc/array.c)
int proc_pid_statm(struct task_struct *task, char *buffer) { int size = 0, resident = 0, shared = 0, text = 0, lib = 0, data = 0; struct mm_struct *mm = get_task_mm(task); if (mm) { size = task_statm(mm, &shared, &text, &data, &resident); mmput(mm); } return sprintf(buffer, "%d %d %d %d %d %d %d\n", size, resident, shared, text, lib, data, 0); } /*fs/proc/task_mmu.c*/ int task_statm(struct mm_struct *mm, int *shared, int *text, int *data, int *resident) { *shared = get_mm_counter(mm, file_rss); *text = (PAGE_ALIGN(mm->end_code) - (mm->start_code & PAGE_MASK)) >> PAGE_SHIFT; *data = mm->total_vm - mm->shared_vm; *resident = *shared + get_mm_counter(mm, anon_rss); return mm->total_vm; }
|
size表示進程虛擬地址空間的大小(單位爲
頁),resident表示文件映射內存大小和分配給匿名內存映射的大小(單位爲頁),shared表示共享文件內存映射大小(單位爲頁),text表示
可執行代碼區域的內存空間的大小(單位爲頁),所以該進程的內存信息可描述爲其虛擬地址空間的大小爲12992頁(將近60MB),文
件映射內存大小和分配給匿名內存映射的大小爲4432頁(將近18MB).
11.status文件:
用可讀的方式描述進程的狀態
niutao@niutao-desktop:/proc/9744$ cat status Name: gedit /*進程的程序名*/ State: S (sleeping) /*進程的狀態信息,具體參見http://blog.chinaunix.net/u2/73528/showart_1106510.html*/ Tgid: 9744 /*線程組號*/ Pid: 9744 /*進程pid*/ PPid: 7672 /*父進程的pid*/ TracerPid: 0 /*跟蹤進程的pid*/ Uid: 1000 1000 1000 1000 /*uid euid suid fsuid*/ Gid: 1000 1000 1000 1000 /*gid egid sgid fsgid*/ FDSize: 256 /*文件描述符的最大個數,file->fds*/ Groups: 0 4 20 24 25 29 30 44 46 107 109 115 124 1000 /*啓動該進程的用戶所屬的組的id*/ VmPeak: 60184 kB /*進程地址空間的大小*/ VmSize: 60180 kB /*進程虛擬地址空間的大小reserved_vm:進程在預留或特殊的內存間的物理頁*/ VmLck: 0 kB /*進程已經鎖住的物理內存的大小.鎖住的物理內存不能交換到硬盤*/ VmHWM: 18020 kB /*文件內存映射和匿名內存映射的大小*/ VmRSS: 18020 kB /*應用程序正在使用的物理內存的大小,就是用ps命令的參數rss的值 (rss)*/ VmData: 12240 kB /*程序數據段的大小(所佔虛擬內存的大小),存放初始化了的數據*/ VmStk: 84 kB /*進程在用戶態的棧的大小*/ VmExe: 576 kB /*程序所擁有的可執行虛擬內存的大小,代碼段,不包括任務使用的庫 */ VmLib: 21072 kB /*被映像到任務的虛擬內存空間的庫的大小*/ VmPTE: 56 kB /*該進程的所有頁表的大小*/ Threads: 1 /*共享使用該信號描述符的任務的個數*/ SigQ: 0/8183 /*待處理信號的個數/目前最大可以處理的信號的個數*/ SigPnd: 0000000000000000 /*屏蔽位,存儲了該線程的待處理信號*/ ShdPnd: 0000000000000000 /*屏蔽位,存儲了該線程組的待處理信號*/ SigBlk: 0000000000000000 /*存放被阻塞的信號*/ SigIgn: 0000000000001000 /*存放被忽略的信號*/ SigCgt: 0000000180000000 /*存放被俘獲到的信號*/ CapInh: 0000000000000000 /*能被當前進程執行的程序的繼承的能力*/ CapPrm: 0000000000000000 /*進程能夠使用的能力,可以包含CapEff中沒有的能力,這些能力是被進程自己臨時放棄的*/ CapEff: 0000000000000000 /*是CapPrm的一個子集,進程放棄沒有必要的能力有利於提高安全性*/ Cpus_allowed: 01 /*可以執行該進程的CPU掩碼集*/ Mems_allowed: 1 /**/ voluntary_ctxt_switches: 1241 /*進程主動切換的次數*/ nonvoluntary_ctxt_switches: 717 /*進程被動切換的次數*/
|
該文件的內容在內核中由proc_pid_status函數寫入:
int proc_pid_status(struct task_struct *task, char *buffer) { char *orig = buffer; struct mm_struct *mm = get_task_mm(task); buffer = task_name(task, buffer); buffer = task_state(task, buffer); if (mm) { buffer = task_mem(mm, buffer); mmput(mm); } buffer = task_sig(task, buffer); buffer = task_cap(task, buffer); buffer = cpuset_task_status_allowed(task, buffer); #if defined(CONFIG_S390) buffer = task_show_regs(task, buffer); #endif buffer = task_context_switch_counts(task, buffer); return buffer - orig; }
|
經過以上分析,我們知道該進程的程序名爲gedit,目前處
於睡眠狀態,該進程的線程組號爲9744,進程的pid爲9744,父進程的pid爲7672,沒有跟蹤進程。該進程所屬用戶的id爲1000,用戶組
id爲1000,限制該進程最大可以同時打開256個文件。進程的地址空間的大小是60184 kB,進程的虛擬地址空間大小是60180
kB,常駐物理內存的大小爲0KB,文件內存映射和匿名內存映射的大小爲18020 kB,程序正在使用的物理內存的大小18020
kB,程序數據段的大小12240
kB,進程在用戶態的棧的大小84KB,程序所擁有的可執行虛擬內存的大小576KB,被映像到進程的虛擬內存空間的庫的大小21072KB,該進程的
所有頁表的大小56KB,只有一個進程共享使用該進程的信號描述符,沒有帶處理的信號,進程主動切換了1241次,被動切換了717次。
12.mounts文件
該文件包含該系統掛在的文件系統的信息。該文件在/proc下和每個進程文件夾下都有,並且內容一樣。
niutao@niutao-desktop:/proc/1$ cat mounts rootfs / rootfs rw 0 0 none /sys sysfs rw,nosuid,nodev,noexec 0 0 none /proc proc rw,nosuid,nodev,noexec 0 0 udev /dev tmpfs rw,relatime 0 0 fusectl /sys/fs/fuse/connections fusectl rw,relatime 0 0 /dev/disk/by-uuid/f9f21592-a8a3-4e61-ac3d-0c7b7aa2cd42 / ext3 rw,relatime,errors=remount-ro,data=ordered 0 0 /dev/disk/by-uuid/f9f21592-a8a3-4e61-ac3d-0c7b7aa2cd42 /dev/.static/dev ext3 rw,relatime,errors=remount-ro,data=ordered 0 0 ....
|
該
文件的輸出結果和/etc/mtab文件的內容類似,但比/etc/mtab文件多一些內容。第一列指出被掛載的設備,第二列表示掛載點,第三列指出該文
件系統的類型。第四列對該掛載的文件系統的讀寫權限,一般有ro(read-only
)和rw(read-write)。第五列和第六列是虛擬數據,用在/etc/mtab中。
13.io文件
niutao@niutao-desktop:/proc/1$ cat io
rchar: 14699 /*task_struct->rchar*/
wchar: 20553017 /*task_struct->wchar*/
syscr: 350 /*task_struct->syscr*/
syscw: 1128 /*task_struct->syscw,*/
read_bytes: 1605632 /*task_struct->ioac.read_bytes*/
write_bytes: 0 /*task_struct->ioac.write_bytes*/
cancelled_write_bytes: 0 /*task_struct->ioac.cancelled_write_bytes*/