日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

linux的根文件系统中的proc文件夹详解

發布時間:2023/11/27 生活经验 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 linux的根文件系统中的proc文件夹详解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

什么是proc文件系統??? |linux /proc目錄介紹|proc中文手冊

proc文件系統是一個偽文件系統,它只存在內存當中,而不占用外存空間。它以文件系統的方式為訪問系統內核數據的操作提供接口。用戶和應用程序可以通過proc得到系統的信息,并可以改變內核的某些參數。由于系統的信息,如進程,是動態改變的,所以用戶或應用程序讀取proc文件時,proc文件系統是動態從系統內核讀出所需信息并提交的。它的目錄結構如下:??

目錄名稱 目錄內容???
apm 高級電源管理信息???
cmdline 內核命令行???
Cpuinfo 關于Cpu信息???
Devices 可以用到的設備(塊設備/字符設備)???
Dma 使用的DMA通道??
Filesystems 支持的文件系統???
Interrupts 中斷的使用???
Ioports I/O端口的使用???
Kcore 內核核心印象???
Kmsg 內核消息???
Ksyms 內核符號表???
Loadavg 負載均衡???
Locks 內核鎖???
Meminfo 內存信息???
Misc 雜項??
Modules 加載模塊列表???
Mounts 加載的文件系統???
Partitions 系統識別的分區表???
Rtc 實時時鐘??
Slabinfo Slab池信息??
Stat 全面統計狀態表??
Swaps 對換空間的利用情況???
Version 內核版本???
Uptime 系統正常運行時間???

并不是所有這些目錄在你的系統中都有,這取決于你的內核配置和裝載的模塊。另外,在/proc下還有三個很重要的目錄:net,scsi和 sys。Sys目錄是可寫的,可以通過它來訪問或修改內核的參數(見下一部分),而net和scsi則依賴于內核配置。例如,如果系統不支持scsi,則 scsi目錄不存在。???

除了以上介紹的這些,還有的是一些以數字命名的目錄,它們是進程目錄。系統中當前運行的每一個進程都有對應的一個目錄在/proc下,以進程的 PID號為目錄名,它們是讀取進程信息的接口。而self目錄則是讀取進程本身的信息接口,是一個link。Proc文件系統的名字就是由之而起。進程目錄的結構如下:???

目錄名稱 目錄內容???
Cmdline 命令行參數???
Environ 環境變量值???
Fd 一個包含所有文件描述符的目錄???
Mem 進程的內存被利用情況???
Stat 進程狀態???
Status 進程當前狀態,以可讀的方式顯示出來???
Cwd 當前工作目錄的鏈接???
Exe 指向該進程的執行命令文件??
Maps 內存映象??
Statm 進程內存狀態信息???
Root 鏈接此進程的root目錄??

用戶如果要查看系統信息,可以用cat命令。例如:??

# cat /proc/interrupts???
CPU0???
0: 8728810 XT-PIC timer???
1: 895 XT-PIC keyboard???
2: 0 XT-PIC cascade???
3: 531695 XT-PIC aha152x???
4: 2014133 XT-PIC serial???
5: 44401 XT-PIC pcnet_cs???
8: 2 XT-PIC rtc???
11: 8 XT-PIC i82365???
12: 182918 XT-PIC Mouse???
13: 1 XT-PIC fpu PS/2???
14: 1232265 XT-PIC ide0???
15: 7 XT-PIC ide1???
NMI: 0???

用戶還可以實現修改內核參數。在/proc文件系統中有一個有趣的目錄:/proc/sys。它不僅提供了內核信息,而且可以通過它修改內核參數,來優化你的系統。但是你必須很小心,因為可能會造成系統崩潰。最好是先找一臺無關緊要的機子,調試成功后再應用到你的系統上。??

要改變內核的參數,只要用vi編輯或echo參數重定向到文件中即可。下面有一個例子:???

# cat /proc/sys/fs/file-max???
4096???
# echo 8192 >; /proc/sys/fs/file-max???
# cat /proc/sys/fs/file-max???
8192???

如果你優化了參數,則可以把它們寫成添加到文件rc.local中,使它在系統啟動時自動完成修改。??

/proc文件系統中網絡參數??

在/proc/sys/net/ipv4/目錄下,包含的是和tcp/ip協議相關的各種參數,下面我們就對這些網絡參數加以詳細的說明。??

ip_forward 參數類型:BOOLEAN??
0 - 關閉(默認值)??
not 0 - 打開ip轉發??

在網絡本地接口之間轉發數據報。該參數非常特殊,對該參數的修改將導致其它所有相關配置參數恢復其默認值(對于主機參閱RFC1122,對于路由器參見RFC1812)??

ip_default_ttl 參數類型:INTEGER??
默認值為 64 。表示IP數據報的Time To Live值。??

ip_no_pmtu_disc 參數類型:BOOLEAN??
關閉路徑MTU探測,默認值為FALSE??

ipfrag_high_thresh 參數類型:整型??
用來組裝分段的IP包的最大內存量。當ipfrag_high_thresh數量的內存被分配來用來組裝IP包,則IP分片處理器將丟棄數據報直到ipfrag_low_thresh數量的內存被用來組裝IP包。??

ipfrag_low_thresh 參數類型:整型??
參見ipfrag_high_thresh。??

ipfrag_time 參數類型:整型??
保存一個IP分片在內存中的時間。??

inet_peer_threshold 參數類型:整型??
INET對端存儲器某個合適值,當超過該閥值條目將被丟棄。該閥值同樣決定生存時間以及廢物收集通過的時間間隔。條目越多﹐存活期越低﹐GC 間隔越短??

inet_peer_minttl 參數類型:整型??
條目的最低存活期。在重組端必須要有足夠的碎片(fragment)存活期。這個最低存活期必須保證緩沖池容積是否少于 inet_peer_threshold。該值以 jiffies為單位測量。??

inet_peer_maxttl 參數類型:整型??
條目的最大存活期。在此期限到達之后﹐如果緩沖池沒有耗盡壓力的話(例如﹐緩沖池中的條目數目非常少)﹐不使用的條目將會超時。該值以 jiffies為單位測量。??

inet_peer_gc_mintime 參數類型:整型??
廢物收集(GC)通過的最短間隔。這個間隔會影響到緩沖池中內存的高壓力。 該值以 jiffies為單位測量。??

inet_peer_gc_maxtime 參數類型:整型??
廢物收集(GC)通過的最大間隔,這個間隔會影響到緩沖池中內存的低壓力。 該值以 jiffies為單位測量。??

tcp_syn_retries 參數類型:整型??
對于一個新建連接,內核要發送多少個 SYN 連接請求才決定放棄。不應該大于255,默認值是5,對應于180秒左右。??

tcp_synack_retries 參數類型:整型??
對于遠端的連接請求SYN,內核會發送SYN + ACK數據報,以確認收到上一個 SYN連接請求包。這是所謂的三次握手( threeway handshake)機制的第二個步驟。這里決定內核在放棄連接之前所送出的 SYN+ ACK 數目。???

tcp_keepalive_time 參數類型:整型??
當keepalive打開的情況下,TCP發送keepalive消息的頻率,默認值是2個小時。??

tcp_keepalive_probes 參數類型:整型??
TCP發送keepalive探測以確定該連接已經斷開的次數,默認值是9。??

tcp_keepalive_interval 參數類型:整型??
探測消息發送的頻率,乘以tcp_keepalive_probes就得到對于從開始探測以來沒有響應的連接殺除的時間。默認值為75秒,也就是沒有活動的連接將在大約11分鐘以后將被丟棄。??

tcp_retries1 參數類型:整型??
當出現可疑情況而必須向網絡層報告這個可疑狀況之前﹐需要進行多少次重試。最低的 RFC 數值是 3 ﹐這也是默認值﹐根據RTO的值大約在3秒 - 8分鐘之間。??

tcp_retries2 參數類型:整型??
在丟棄激活的TCP連接之前﹐需要進行多少次重試。RFC1122規定,該值必須大于100秒。默認值為15,根據RTO的值來決定,相當于13-30分鐘,??

tcp_orphan_retries 參數類型:整型??
在近端丟棄TCP連接之前﹐要進行多少次重試。默認值是 7 個﹐相當于 50秒 - 16分鐘﹐視 RTO 而定。如果您的系統是負載很大的 web服務器﹐那么也許需要降低該值﹐這類 sockets 可能會耗費大量的資源。另外參的考 tcp_max_orphans 。??

tcp_fin_timeout 參數類型:整型??
對于本端斷開的socket連接,TCP保持在FIN-WAIT-2狀態的時間。對方可能會斷開連接或一直不結束連接或不可預料的進程死亡。默認值為 60 秒。過去在2.2版本的內核中是 180 秒。您可以設置該值﹐但需要注意﹐如果您的機器為負載很重的web服務器﹐您可能要冒內存被大量無效數據報填滿的風險﹐FIN-WAIT-2 sockets 的危險性低于 FIN-WAIT-1 ﹐因為它們最多只吃 1.5K 的內存﹐但是它們存在時間更長。另外參考 tcp_max_orphans。???

tcp_max_tw_buckets 參數類型:整型??
系統在同時所處理的最大timewait sockets 數目。如果超過此數的話﹐time-wait socket 會被立即砍除并且顯示警告信息。之所以要設定這個限制﹐純粹為了抵御那些簡單的 DoS 攻擊﹐千萬不要人為的降低這個限制﹐不過﹐如果網絡條件需要比默認值更多﹐則可以提高它 (或許還要增加內存)。???

tcp_tw_recycle 參數類型:布爾??
打開快速 TIME-WAIT sockets 回收。默認值是1。除非得到技術專家的建議或要求﹐請不要隨意修改這個值。???

tcp_max_orphans 參數類型:整型??
系統所能處理不屬于任何進程的TCP sockets最大數量。假如超過這個數量﹐那么不屬于任何進程的連接會被立即reset,并同時顯示警告信息。之所以要設定這個限制﹐純粹為了抵御那些簡單的 DoS 攻擊﹐千萬不要依賴這個或是人為的降低這個限制???

tcp_abort_on_overflow 參數類型:布爾??
當守護進程太忙而不能接受新的連接,就象對方發送reset消息,默認值是false。這意味著當溢出的原因是因為一個偶然的猝發,那么連接將恢復狀態。只有在你確信守護進程真的不能完成連接請求時才打開該選項,該選項會影響客戶的使用。??

tcp_syncookies 參數類型:整型??
只有在內核編譯時選擇了CONFIG_SYNCOOKIES時才會發生作用。當出現syn等候隊列出現溢出時象對方發送syncookies。目的是為了防止syn flood攻擊。默認值是false。??

注意:該選項千萬不能用于那些沒有收到攻擊的高負載服務器,如果在日志中出現synflood消息,但是調查發現沒有收到synflood攻擊,而是合法用戶的連接負載過高的原因,你應該調整其它參數來提高服務器性能。參考: tcp_max_syn_backlog,???? tcp_synack_retries, tcp_abort_on_overflow.??

syncookie嚴重的違背TCP協議,不允許使用TCP擴展,可能對某些服務導致嚴重的性能影響(如SMTP轉發)。??

tcp_stdurg 參數類型:整型??
使用 TCP urg pointer 字段中的主機請求解釋功能。大部份的主機都使用老舊的???? BSD解釋,因此如果您在 Linux 打開它﹐或會導致不能和它們正確溝通。默認值為為﹕FALSE????

tcp_max_syn_backlog 參數類型:整型??
對于那些依然還未獲得客戶端確認的連接請求﹐需要保存在隊列中最大數目。對于超過 128Mb 內存的系統﹐默認值是 1024 ﹐低于???? 128Mb 的則為 128。如果服務器經常出現過載﹐可以嘗試增加這個數字。警告﹗假如您將此值設為大于 1024﹐最好修改???? include/net/tcp.h 里面的 TCP_SYNQ_HSIZE ﹐以保持 TCP_SYNQ_HSIZE*16<= tcp_max_syn_backlog ﹐并且編進核心之內。???

tcp_window_scaling 參數類型:布爾??
正常來說,TCP/IP 可以接受最大到65535字節的 windows。對于寬帶網絡,該值可能是不夠的,通過調整該參數有助于提高寬帶服務器性能。??

tcp_timestamps 參數類型:布爾??
Timestamps 用在其它一些東西中﹐可以防范那些偽造的 sequence 號碼。一條1G的寬帶線路或許會重遇到帶 out-of-line數值的舊sequence 號碼(假如它是由于上次產生的)。Timestamp???? 會讓它知道這是個 '舊封包'。???

tcp_sack 參數類型:布爾??
使用 Selective ACK﹐它可以用來查找特定的遺失的數據報--- 因此有助于快速恢復狀態。??

tcp_fack 參數類型:布爾??
打開FACK擁塞避免和快速重傳功能。??

tcp_dsack 參數類型:布爾??
允許TCP發送"兩個完全相同"的SACK。??

tcp_ecn 參數類型:布爾??
打開TCP的直接擁塞通告功能。??

tcp_reordering 參數類型:整型??
TCP流中重排序的數據報最大數量默認值是 3 。??

tcp_retrans_collapse 參數類型:布爾??
對于某些有bug的打印機提供針對其bug的兼容性。??

tcp_wmem - 三個整數的向量: min, default, max??
min:為TCP socket預留用于發送緩沖的內存最小值。每個tcp socket都可以在建議以后都可以使用它。默認值為4K。??

default:為TCP socket預留用于發送緩沖的內存數量,默認情況下該值會影響其它協議使用的net.core.wmem_default 值,一般要低于net.core.wmem_default的值。默認值為16K。??

max: 用于TCP socket發送緩沖的內存最大值。該值不會影響net.core.wmem_max,今天選擇參數SO_SNDBUF則不受該值影響。默認值為128K。??

tcp_rmem - 三個整數的向量: min, default, max??
min:為TCP socket預留用于接收緩沖的內存數量,即使在內存出現緊張情況下tcp socket都至少會有這么多數量的內存用于接收緩沖,默認值為8K。??

default:為TCP socket預留用于接收緩沖的內存數量,默認情況下該值影響其它協議使用的???? net.core.wmem_default 值。該值決定了在tcp_adv_win_scale、tcp_app_win和 tcp_app_win:0是默認值情況下,tcp 窗口大小為65535。??

max:用于TCP socket接收緩沖的內存最大值。該值不會影響 net.core.wmem_max,今天選擇參數???? SO_SNDBUF則不受該值影響。默認值為 128K。默認值為87380*2 bytes。??

tcp_mem - 三個整數的向量: low, pressure, high??
low:當TCP使用了低于該值的內存頁面數時,TCP不會考慮釋放內存。??

pressure:當TCP使用了超過該值的內存頁面數量時,TCP試圖穩定其內存使用,進入pressure模式,當內存消耗低于low值時則退出pressure狀態。??

high:允許所有tcp sockets用于排隊緩沖數據報的頁面量。??

一般情況下這些值是在系統啟動時根據系統內存數量計算得到的。??

tcp_app_win - 整數??

保留max(window/2^tcp_app_win, mss)數量的窗口由于應用緩沖。當為0時表示不需要緩沖。默認值是31。??

tcp_adv_win_scale - 整數??
計算緩沖開銷bytes/2^tcp_adv_win_scale(如果tcp_adv_win_scale >; 0)或者bytes- bytes/2^(-tcp_adv_win_scale)(如果tcp_adv_win_scale <= 0),默認值為2。??

ip_local_port_range - 兩個整數??
定于TCP和UDP使用的本地端口范圍,第一個數是開始,第二個數是最后端口號,默認值依賴于系統中可用的內存數:??
>; 128Mb 32768-61000??
< 128Mb 1024-4999 or even less.??
該值決定了活動連接的數量,也就是系統可以并發的連接數??

icmp_echo_ignore_all - 布爾類型??
icmp_echo_ignore_broadcasts - 布爾類型??
如果任何一個設置為true(>;0)則系統將忽略所有發送給自己的ICMP ECHO請求或那些廣播地址的請求。??

icmp_destunreach_rate - 整數??
icmp_paramprob_rate - 整數??
icmp_timeexceed_rate - 整數??
icmp_echoreply_rate - 整數(not enabled per default)??
限制發向特定目標的ICMP數據報的最大速率。0表示沒有任何限制,否則表示jiffies數據單位中允許發送的個數。??

icmp_ignore_bogus_error_responses - 布爾類型??
某些路由器違背RFC1122標準,其對廣播幀發送偽造的響應來應答。這種違背行為通常會被以告警的方式記錄在系統日志中。如果該選項設置為True,內核不會記錄這種警告信息。默認值為False。??

(1) Jiffie: 內核使用的內部時間單位,在i386系統上大小為1/100s,在Alpha中為1/1024S。在/usr/include/asm/param.h中的HZ定義有特定系統的值。??

conf/interface/*:???
conf/all/*是特定的,用來修改所有接口的設置,is special and changes the settings for all interfaces.??
Change special settings per interface.??

log_martians - 布爾類型??
記錄帶有不允許的地址的數據報到內核日志中。??

accept_redirects - 布爾類型??
收發接收ICMP重定向消息。對于主機來說默認為True,對于用作路由器時默認值為False。??

forwarding - 布爾類型??
在該接口打開轉發功能??

mc_forwarding - 布爾類型??
是否進行多播路由。只有內核編譯有CONFIG_MROUTE并且有路由服務程序在運行該參數才有效。??

proxy_arp - 布爾類型??
打開proxy arp功能。??

shared_media - 布爾類型??
發送(路由器)或接收(主機) RFC1620 共享媒體重定向。覆蓋ip_secure_redirects的值。默認為True。??

secure_redirects - 布爾類型??
僅僅接收發給默認網關列表中網關的ICMP重定向消息,默認值是TRUE。??

send_redirects - 布爾類型??
如果是router,發送重定向消息,默認值是TRUE??

bootp_relay - 布爾類型??
接收源地址為0.b.c.d,目的地址不是本機的數據報。用來支持BOOTP轉發服務進程,該進程將捕獲并轉發該包。默認為False,目前還沒有實現。??

accept_source_route - 布爾類型??
接收帶有SRR選項的數據報。對于主機來說默認為False,對于用作路由器時默認值為True。??

rp_filter 參數類型??
1 - 通過反向路徑回溯進行源地址驗證(在RFC1812中定義)。對于單穴主機和stub網絡路由器推薦使用該選項。??
0 - 不通過反向路徑回溯進行源地址驗證。??
默認值為0。某些發布在啟動時自動將其打開

================================================================

proc 在Linux中是一個比較奇妙的目錄,保存了當前系統所有的詳細信息,包括進程、文件系統、硬件…… 而且還可以通過/proc來即時修改系統中的某些參數。

你可能會認為,“文件”指的就是硬盤上保存的數據,要么是文本,要么就是二進制文件。而在 Linux 的世界中,所有的東西都可以通過文件來表示和管理,哪怕是硬件設備,也可以通過 /dev 下的設備文件來操作硬件設備。

/proc 就是這樣一種文件,它并不存在于硬盤上,每當系統啟動的時候,操作系統自動創建 /proc 下的內容,你可以查看這些文件的列表,但是你會發現大部分文件的大小都是 0 ,這并不奇怪,因為這些文件屬于“virtual files“,也就是說,當你讀取這些文件的時候,系統內核為你即時生成文件中的內容。

/proc 下的信息包括了有關硬件、進程、系統的詳細信息,先看看 /proc 下大致都有啥吧:

/proc 下的信息包括了有關硬件、進程、系統的詳細信息,先看看 /proc 下大致都有啥吧:

localhost ~#ls/proc
1 143 19218 28326 28357 28406 5630 5784 5807 79 924 diskstats interrupts locks pagetypeinfo timer_list
1013 144 19223 28327 28377 28407 5713 5785 5808 814 asound dma iomem meminfo partitions tty
11079 18990 2 28329 28382 28796 5714 5786 5809 816 buddyinfo driver ioports misc self uptime
11086 19060 25659 28332 28385 3 5718 5787 5861 85 bus execdomains irq modules slabinfo version
11108 19068 28300 28334 28397 3454 5750 5798 71 88 cmdline fb kallsyms mounts stat vmstat
139 19070 28316 28338 28400 4 5781 5800 737 882 config.gz filesystems kcore mtd swaps zoneinfo
141 19174 28317 28342 28403 5 5782 5805 74 883 cpuinfo fs kmsg mtrr sys
142 19178 28322 28347 28404 5059 5783 5806 78 893 devices ide loadavg net sysvipc

可以看到,除了一些文件之外,更多的是一堆以數字為名稱的目錄,每個目錄代表了系統中的一個進程,目錄下是有關這個進程的詳細信息,這個等下我們再說。 /proc 下還有一個 self 文件,實際上是一個連接,指向了當前運行中的進程目錄。

首先我們看看 /proc 目錄下一些非常有用的文件,查看這些文件的內容很簡單,用 cat 命令就可以了~

/proc/cpuinfo

localhost ~#cat /proc/cpuinfo
processor :0
vendor_id : GenuineIntel
cpu family :15
model :2
model name : Intel(R)Pentium(R)4CPU2.40GHz
stepping :7
cpu MHz :2394.017
cache size :512KB
fdiv_bug : no
hlt_bug : no
f00f_bug : no
coma_bug : no
fpu : yes
fpu_exception : yes
cpuid level :2
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe pebs bts sync_rdtsc cid xtpr
bogomips :4792.93
clflush size :64

/proc/cpuinfo 即是當前系統 cpu 的詳細信息,從型號到支持的特性,如果你是多核 cpu 的話,會看到多個這樣的輸出。檢測 cpu 的程序,也是通過 /proc/cpuinfo 來得到當前 cpu 的詳細信息的。

/proc/meminfo

localhost ~#cat /proc/meminfo
MemTotal: 514624kB
MemFree: 10144kB
Buffers: 20248kB
Cached: 156248kB
SwapCached: 60kB
Active: 387864kB
Inactive: 79612kB
SwapTotal: 1052216kB
SwapFree: 1051740kB
Dirty: 8kB
Writeback: 0kB
AnonPages: 290940kB
Mapped: 66216kB
Slab: 25404kB
SReclaimable: 16872kB
SUnreclaim: 8532kB
PageTables: 2152kB
NFS_Unstable: 0kB
Bounce: 0kB
CommitLimit: 1309528kB
Committed_AS: 801488kB
VmallocTotal: 515808kB
VmallocUsed: 48176kB
VmallocChunk: 463580kB

/proc/meminfo 是當前系統內存的詳細信息,當然,隨著系統的運行,這些信息也會隨時變化。像 top、free 這些可以查看當前系統內存信息的程序,就是通過讀取 /proc/meminfo 來實現的。

/proc/version

localhost ~#cat /proc/version
Linux version2.6.24-gentoo-r2(root@localhost)(gcc version4.2.2(Gentoo4.2.2p1.0))#1Wed Feb1322:18:22UTC2008

/proc/version 是當前系統的版本信息,uname 這個命令,就是通過它來得到內核版本和系統版本的。

/proc/filesystems

localhost ~#cat /proc/filesystems
nodev sysfs
nodev rootfs
nodev bdev
nodev proc
nodev sockfs
nodev usbfs
nodev pipefs
nodev anon_inodefs
nodev futexfs
nodev tmpfs
nodev inotifyfs
nodev devpts
reiserfs
ext3
ext2
nodev ramfs
msdos
vfat
iso9660
nodev cifs
ntfs
udf

/proc/filesystems 為當前系統支持的文件系統列表,你可以在程序中讀取這個文件,以獲得當前系統對文件系統的支持信息。

上面這幾個只是比較常用的,實際上 /proc 下的信息相當豐富,很多文件都可以 cat 一下看看,比如:

* /proc/apm: APM 高級電源管理信息。
* /proc/acpi: 目錄下為 ACPI 的詳細信息。 比方說, 你想知道你的筆記本電腦是否連接了電源, 你可以 cat /proc/acpi/ac_adapter/AC/state 看看結果是 "on line" 還是 "off line" 。
* /proc/cmdline: 顯示內核的啟動參數,一般就是你 grub 中傳入內核的那些參數,比如我的就是: root=/dev/sda9 video=uvesafb:1680x1050-32,mtrr:3,ywrap
* /proc/loadav: 顯示系統的負載,w、top 這類程序也是從此得到系統負載信息。
* /proc/uptime: 系統自啟動來所經歷的秒數,uptime 程序就是從此計算出系統啟動后經歷的時間的。
* /proc/devices: 系統中所有可用的字符和塊設備。
* /proc/ioports: IO 端口信息。
* /proc/dma: 當前可用的 DMA 通道。
* /proc/mounts: 系統當前的掛載信息。

除此之外,還有一些文件和硬件相關,比如 /proc/interrupts 為終端信息,/proc/irq 為 IRQ 信息,還有 /proc/pci、/proc/bus 等等。

現在我們來看看開始提到的那些數字目錄,也就是和進程相關的目錄。

如前面所說,每個數字目錄都代表了一個正在運行的進程,目錄的數字名就是進程的 ID,每當一個新進程啟動,一個新的目錄就會被創建,同理進程結束的時候,相應的目錄也會消失。

讓我們看看進程目錄下面都有啥:

localhost /#ls /proc/11108
auxv cmdline cwd exe fdinfo maps mounts oom_adj root stat status wchan
clear_refs coredump_filter environ fd limits mem mountstats oom_score smaps statm task

隨便挑選了一個名稱為 11108 的目錄,在我的機子上對應的進程是 firefox-bin,讓我們看看目錄下這些文件都是啥:

* cmdline: 啟動進程的命令和參數。
* cwd: 指向進程當前目錄的一個連接。
* environ: 進程所有的環境變量。
* fd: 進程所有打開的文件描述符,目錄下是一個個以數字為名稱的連接,指向了進程當前正在使用的文件。
* maps, statm, mem: 進程的內存信息。
* stat, status: 進程的狀態信息,比如查看 /proc/status 中是否含有 “Zombie”字樣,來查看僵尸進程。

/proc/sys

/proc/sys 目錄下不僅提供了系統某些設置信息,你還可以修改這些文件來在運行中改變系統的參數,比如,你想讓別人 ping 不到你,只要:

#echo1 > /proc/sys/net/ipv4/icmp_echo_ignore_all

這樣就可以讓系統忽略所有的 ICMP 回應,別人就 ping 不到你了。

/proc/sys 下的可配置的選項很多,主要有 6 類: debug、dev、fs、kernel、net、vm,只要文件屬性是可讀寫的,一般都對應了系統某個可以修改的參數。

不過系統重啟之后參數就恢復默認值了,其實有專門的工具來修改這些參數,那就是sysctl和 /etc/sysctl.conf 這個配置文件,不過這不是本文的內容,感興趣的就去搜一下吧~

如上所述,/proc 是一個強大的特殊目錄,其中的文件提供了非常詳細的系統信息,很多常用的程序就是從此得到系統各個方面的信息的,在你寫的程序和腳本中,也可以通過 /proc 方便的獲得一些系統參數,甚至修改系統的某些參數.

from:LinuxGem


總結

以上是生活随笔為你收集整理的linux的根文件系统中的proc文件夹详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。