1. Linux /proc ディレクトリの概要
Linux カーネルは、/proc ファイル システムを通じてカーネルの内部データ構造にアクセスし、実行時にカーネル設定を変更するメカニズムを提供します。 proc ファイル システムは、メモリ内にのみ存在し、外部メモリ領域を占有しない疑似ファイル システムです。ファイル システムの形式でシステム カーネル データにアクセスするためのインターフェイスを提供します。
ユーザーとアプリケーションは、proc を通じてシステム情報を取得し、カーネルの特定のパラメーターを変更できます。プロセスなどのシステム情報は動的に変化するため、ユーザーまたはアプリケーションが proc ファイルを読み取ると、proc ファイル システムはシステム カーネルから必要な情報を動的に読み取り、送信します。カーネル構成およびロードされたモジュールによっては、以下にリストされているすべてのファイルまたはサブフォルダーがシステム上に存在するわけではありません。さらに、/proc には、net、scsi、sys という 3 つの非常に重要なディレクトリがあります。 sys ディレクトリは書き込み可能で、カーネル パラメータへのアクセスや変更に使用できますが、net と scsi はカーネル設定に依存します。たとえば、システムが scsi をサポートしていない場合、scsi ディレクトリは存在しません。
上で紹介したもの以外にも、プロセスディレクトリと呼ばれる数字の付いたディレクトリがいくつかあります。現在システム内で動作している各プロセスは、/proc 配下にプロセスの pid 番号をディレクトリ名として対応するディレクトリを持ち、プロセス情報を読み取るためのインターフェースとなります。自己ディレクトリは、プロセス自体を読み取るための情報インターフェースであり、リンクです。
2. /proc ディレクトリ内のサブファイルまたはサブフォルダーの役割
/proc/buddyinfo 各メモリ領域で各オーダーに使用できるブロックの数はメモリに関係します断片化の問題
/proc/cmdline 起動時にカーネルに渡されるパラメータ情報
/proc/cpuinfo CPU 情報
/proc/crypto カーネルで使用されるすべてのインストールされた暗号化パスワードと詳細
/proc/devicesすでにロードされているデバイスとカテゴリ
/proc/dma 使用するために登録されている isa dma チャネルのリスト
/proc/execdomains Linux カーネルで現在サポートされている実行ドメイン
/proc/fb 番号を含むフレーム バッファ デバイスのリストおよびそのドライバーを制御します
/proc/filesystems カーネルによって現在サポートされているファイル システム タイプ
/proc/interrupts x86 アーキテクチャにおける irq ごとの割り込み数
/proc/iomem 各物理デバイスの数現在システム メモリ内にあります マッピング
/proc/ioports デバイスの入出力に使用される登録されたポート範囲
/proc/kcore はシステムの物理メモリを表し、コア ファイル形式で保存されます。表示されるバイト数は、RAM サイズに最大 4kb
/proc/kmsg を加えたものと等しくなります。 カーネルによって生成された情報が記録されます。この情報は、/sbin/klogd または /bin/dmesg
/proc/loadavg を通じて処理できます。 負荷ステータス過去の期間の CPU と IO のステータスに基づく、uptime コマンドに関連する
/proc/locks カーネル ロック ファイル リスト
/proc/mdstat 複数のハード ドライブ、RAID 構成情報 (md=複数のディスク) )
/proc/meminfo Ram 使用関連情報
/proc/misc 他の主要なデバイス (デバイス番号 10) に登録されているドライバー
/proc/modules カーネルにロードされているすべてのモジュールのリスト
/proc /mounts システムで使用されるすべてのマウント
/proc/mtrr システムで使用されるメモリ タイプ範囲レジスタ (mtrrs)
/proc/partitions パーティション内のブロック割り当て情報
/proc/pci PCI デバイス リストシステム
/proc/slabinfo システム すべてのアクティブなスラブ キャッシュ情報
/proc/stat すべての CPU アクティビティ情報
/proc/sysrq-trigger echo コマンドを使用してこのファイルを書き込む場合、リモート root ユーザーは次のことを行うことができます。ほとんどのシステム リクエスト キー コマンドをローカル ターミナルで実行するのと同じように実行します。このファイルに書き込むには、/proc/sys/kernel/sysrq を 0 に設定しないでください。このファイルは root でも読み取ることができません
/proc/uptime システムの実行時間
/proc/swaps スワップ領域の使用状況
/proc/version Linux カーネルのバージョンと gcc のバージョン
/proc /バス システム バス (バス) 情報 (pci/usb など)
/proc/driver ドライバー情報
/proc/fs ファイル システム情報
/proc/ide ide デバイス情報
/proc /irq 割り込み要求デバイス情報
/proc/net ネットワーク カード デバイス情報
/proc/scsi scsi デバイス情報
/proc/tty tty デバイス情報
/proc/net/dev ネットワーク アダプタと表示統計情報
/proc/vmstat 仮想メモリ統計情報
/proc/vmcore カーネルパニック時のメモリイメージ
/proc/diskstats ディスク情報取得
/proc/schedstat カーネルスケジューラ統計情報
/proc/ zoneinfo は、メモリ空間の統計情報を表示します。これは、仮想メモリの動作を分析するのに役立ちます。
以下は、/proc ディレクトリ内のプロセス n の情報です。
/proc/n pid n のプロセス情報
/ proc/n /cmdline プロセス起動コマンド
/proc/n/cwd プロセスの現在の作業ディレクトリへのリンク
/proc/n/environ プロセス環境変数リスト
/proc/n/exe へのリンクプロセス
/proc/n/fdの実行コマンドファイルには、プロセスに関連するすべてのファイル記述子が含まれます
/proc/n/maps プロセスに関連するメモリマッピング情報
/proc/n/memは参照しますプロセスが保持するメモリへの読み取り不可
/proc/n/root プロセスのルート ディレクトリへのリンク
/proc/n/stat プロセスのステータス
/proc/n/statmプロセスによって使用されるメモリのステータス
/proc/ n/status プロセスのステータス情報。stat/statm
/proc/self よりも読みやすい 現在実行中のプロセス
3 にリンクします。 example
1. 列 /proc/
yafang@qa:~$ ls /proc/ 1 16819 21242 2180 2494 8768 interrupts partitions 116 16820 21244 2181 2524 885 iomem sched_debug 11740 17901 21245 21810 2525 acpi ioports scsi 11742 17903 21247 21812 3 asound irq self 11743 17904 2131 21813 39 buddyinfo kallsyms slabinfo 13452 18362 21319 21923 4 bus kcore stat 13454 18364 2132 2193 41 cgroups key-users swaps 13455 18365 2139 21933 42 cmdline kmsg sys 149 19451 2142 2209 5 cpuinfo kpagecount sysrq-trigger 150 19453 21572 2212 5330 crypto kpageflags sysvipc 151 19454 21574 2219 596 devices loadavg timer_list 152 2 21575 2243 597 diskstats locks timer_stats 15771 2083 2158 2260 6 dma meminfo tty 15773 2092 21625 2261 617 driver misc uptime 15774 2101 21627 2262 619 execdomains modules version 16232 21112 21628 2263 7 fb mounts vmallocinfo 16234 21115 2165 2264 804 filesystems mtrr vmstat 16235 21116 2167 2265 8765 fs net zoneinfo 16811 2112 2177 2338 8767 ide pagetypeinfo
にあるすべてのファイルをエクスポートします2. システム情報とカーネル パラメーターを表示します
yafang@qa:~$ ls /proc/sys debug dev fs kernel net vm[code]
3. 查看网卡设备信息
[code]yafang@qa:~$ ls /proc/net anycast6 ip6_flowlabel netfilter raw6 sockstat6 udplite arp ip6_mr_cache netlink route softnet_stat udplite6 dev ip6_mr_vif netstat rt6_stats stat unix dev_mcast ip_mr_cache packet rt_acct tcp vlan dev_snmp6 ip_mr_vif protocols rt_cache tcp6 wireless if_inet6 ipv6_route psched snmp tr_rif igmp mcfilter ptype snmp6 udp igmp6 mcfilter6 raw sockstat udp6
4. 查看scsi设备信息
yafang@qa:~$ ls /proc/scsi device_info scsi
5. 查看所有加载到内核的模块列表
root@bdsp-a-2-1-2:~# cat /proc/modules bdspboard 8486 2 dspcontrol, live 0xe134c000 dspcontrol 9575 1 clkmon, live 0xe135b000 clkmon 6765 1 - live 0xe136c000 diagint 6635 1 - live 0xe1379000 bdsprio 10775 2 srioif,tsi577, live 0xe9389000 tsi577 17998 1 srioif, live 0xe939e000 srioif 7329 0 - live 0xe93b2000 linux_kernel_bde 54666 1 linux_user_bde, live 0xf1417000 (p) linux_user_bde 17849 0 - live 0xf1427000 (p) root@bdsp-a-2-1-2:~#
6. 查看已经加载的设备并分类
root@bcnmb-a:~# cat /proc/devicescharacter devices: 1 mem 2 pty 3 ttyp 4 /dev/vc/0 4 tty 4 ttys 5 /dev/tty 5 /dev/console 5 /dev/ptmx 7 vcs 10 misc 13 input 89 i2c 90 mtd116 linux-user-bde2117 linux-kernel-bde2126 linux-user-bde127 linux-kernel-bde128 ptm136 pts180 usb189 usb_device245 ext_alarm251 ipmidev252 usb_endpoint253 usbmon254 rtcblock devices: 1 ramdisk 8 sd 31 mtdblock 65 sd 66 sd 67 sd 68 sd 69 sd 70 sd 71 sd128 sd129 sd130 sd131 sd132 sd133 sd134 sd135 sd root@bcnmb-a:~#
7. 查看分区中的块分配信息
root@bdsp-a-2-1-2:~# cat /proc/partitions major minor #blocks name 31 0 512 mtdblock0 31 1 512 mtdblock1 31 2 123904 mtdblock2 31 3 4096 mtdblock3 31 4 1024 mtdblock4 31 5 1024 mtdblock5 31 6 512 mtdblock6 31 7 512 mtdblock7 31 8 123904 mtdblock8 31 9 4096 mtdblock9 31 10 1024 mtdblock10 31 11 1024 mtdblock11 31 12 1048576 mtdblock12 root@bdsp-a-2-1-2:~#
8. 查看linux内核版本和gcc版本
root@bdsp-a-2-1-2:~# cat /proc/version linux version 2.6.34.6-wr4.0.0.0_standard (satomi@charliebrown) (gcc version 4.4.1 (wind river linux sourcery g++ 4.4-291) ) #1 smp preempt fri nov 26 16:07:47 cst 2010 root@bdsp-a-2-1-2:~#
9. /proc/sys/fs/file-max
该文件指定了可以分配的文件句柄的最大数目。如果用户得到的错误消息声明由于打开文件数已经达到了最大值,从而他们不能打开更多文件,则可能需要增加该值。可将这个值设置成有任意多个文件,并且能通过将一个新数字值写入该文件来更改该值。默认设置时4096。
改变内核的参数,用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中,使它在系统启动时自动完成修改。
其它例子:
1:[root@gechong proc]# more /proc/cmdline
显示了内核启动的命令行
2:[root@gechong proc]# cat /proc/cpuinfo
显示了cpu信息
3:[root@gechong proc]# cat /proc/devices
显示了字符和块设备的主设备号以及分配到这些设备号的设备名称
4:[root@gechong proc]# cat /proc/dma
显示了驱动程序保留的dma通道和保留它们的驱动程序名称
5:[root@gechong proc]# more /proc/filesystems
显示了可供使用的文件系统类型,一种类型一行
6:[root@gechong proc]# more /proc/interrupts
每一行都有一个保留的中断,内容是:中断号 中断次数 登记中断的驱动程序名称
7:[root@gechong proc]# more /proc/ioports
显示了i/o相关的设备驱动器例如磁盘驱动器、以太网卡、声卡设备等
以上がLinux proc ディレクトリ内のサブファイルまたはサブフォルダーの機能は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。