This is a text-only version of the following page on https://raymii.org: --- Title : Exploring /proc/ - tips and tricks for the procfs Author : Remy van Elst Date : 28-01-2013 URL : https://raymii.org/s/snippets/Procfs_tips_and_tricks.html Format : Markdown/HTML --- > procfs (or the proc filesystem) is a special filesystem in UNIX-like operating systems that presents information about processes and other system information in a hierarchical file-like structure, providing a more convenient and standardized method for dynamically accessing process data held in the kernel than traditional tracing methods or direct access to kernel memory. Typically, it is mapped to a mount point named /proc at boot time. Note that most /proc/ entries are separated by null characters, and there may be a null character at the end. Where applicable the `tr` command is used to replace these. <p class="ad"> <b>Recently I removed all Google Ads from this site due to their invasive tracking, as well as Google Analytics. Please, if you found this content useful, consider a small donation using any of the options below:</b><br><br> <a href="https://leafnode.nl">I'm developing an open source monitoring app called Leaf Node Monitoring, for windows, linux & android. Go check it out!</a><br><br> <a href="https://github.com/sponsors/RaymiiOrg/">Consider sponsoring me on Github. It means the world to me if you show your appreciation and you'll help pay the server costs.</a><br><br> <a href="https://www.digitalocean.com/?refcode=7435ae6b8212">You can also sponsor me by getting a Digital Ocean VPS. With this referral link you'll get $100 credit for 60 days. </a><br><br> </p> ### Processes Inside the `/proc` directory every process has a folder, named after its process ID. For example, my `nagios3` program has the following process ID: ps aux | grep [n]agios3 | awk '{ print $2 }' 3363 So it has its own special folder: `/proc/3363`. Every process has a folder like `/proc/$PID` where $PID is its process ID. I'll cover a few specific files of a process folder below. #### exe This is a symlink to the process binary: sudo ls -l /proc/3363/exe lrwxrwxrwx 1 root root 0 2013-01-26 15:18 /proc/3363/exe -> /usr/sbin/nagios3 #### cmdline This shows the command which started the process: (sudo cat /proc/3363/cmdline; echo) | tr "\000" " " /usr/sbin/nagios3 -d /etc/nagios3/nagios.cfg #### cwd This is a symlink to the process current working directory: sudo ls -la /proc/3363/cwd lrwxrwxrwx 1 root root 0 2013-01-26 15:18 /proc/3363/cwd -> / #### environ This gives us the environment of the command (your `env`) which also shows us all the user variables and such: (sudo cat /proc/3363/environ; echo) | tr "\000" "\n" [output truncated] #### status This gives us a `ps` like information overview for the process: cat /proc/3363/status Name: nagios3 State: S (sleeping) Tgid: 3363 Pid: 3363 PPid: 1 TracerPid: 0 [output truncated] #### limits This gives the limits the process has, which can be set and tweaked using `ulimit`: sudo cat /proc/3363/limits Limit Soft Limit Hard Limit Units Max cpu time unlimited unlimited seconds Max file size unlimited unlimited bytes Max data size unlimited unlimited bytes Max stack size 8388608 unlimited bytes Max core file size 0 unlimited bytes Max resident set unlimited unlimited bytes Max processes unlimited unlimited processes [output truncated] ### Non Processes There are also a lot of "general" files which give you system information. #### /proc/filesystems This gives a list of all the filesystems supported by the current kernel: cat /proc/filesystems nodev sysfs nodev rootfs nodev bdev nodev proc nodev cgroup When it has `nodev` before it, it means it is a non-physical filesystems such as network filesystems and proc. #### /proc/cpuinfo This return a lot of info about the processor(s). cat /proc/cpuinfo processor : 0 vendor_id : GenuineIntel cpu family : 15 model : 3 model name : Intel(R) Xeon(TM) CPU 2.60GHz stepping : 9 #### /proc/uptime This returns the uptime as two decimal values in seconds, separated by a space, the amount of time since the kernel was started and the amount of time that the kernel has been idle. cat /proc/uptime 3121129.58 4100521.65 #### /proc/cmdline This gives the current command line passed to the running kernel (by GRUB/lilo): cat /proc/cmdline BOOT_IMAGE=/boot/vmlinuz-2.6.18-21-generic-pae root=UUID=[...] ro quiet #### /proc/version This gives very detailed kernel version information. More than with `uname -a`, see the comparison: cat /proc/version Linux version 2.6.18-21-custom-pae-bfs (remy@solaris3) (gcc version 4.4.3 (Ubuntu 4.2-ubuntu5.1) ) #101-Ubuntu SMP Mon Dec 3 15:56:38 UTC 2012 uname -a Linux solaris3 2.6.18-21-custom-pae-bfs #101-Ubuntu SMP Mon Dec 3 15:56:38 UTC 2012 i686 GNU/Linux (Note that this is a custom kernel, hence the `remy@solaris3`). #### /proc/modules This returns a list of currently loaded kernel modules: cat /proc/modules btrfs 462393 0 - Live 0xf908d000 zlib_deflate 19568 1 btrfs, Live 0xf87e9000 crc32c 2519 1 - Live 0xf8410000 #### /proc/scsi/scsi This gives information on the attached SCSI devices (handy on servers, also does SAS): cat /proc/scsi/scsi Attached devices: Host: scsi1 Channel: 00 Id: 00 Lun: 00 Vendor: TEAC Model: CD-224E Rev: K.9A Type: CD-ROM ANSI SCSI revision: 05 #### /proc/uptime This gives the same result as the `uptime` command, with two extra's. The fourth field consists of two numbers separated by a slash, the first one represents the number of currently executing processes/threads. This number will not exceed the number of processors cores the system has.The second number (the one after the slash) represents the number of processes/threads currently existing on the system. The fifth field has the most reced PID created (probably of the `cat` command you just did.) cat /proc/loadavg 1.02 1.43 1.40 1/132 16254 ### The /proc/net folder This folder has information about the network stack. #### /proc/net/route This is the systems routing table, in HEX format: cat /proc/net/route Iface Destination Gateway Flags RefCnt Use Metric Mask MTU Window IRTT eth0 0EF1D9C2 00000000 0001 0 0 0 00FFFFFF 0 0 0 eth0 00000000 0EF1D9C2 0003 0 0 100 00000000 0 0 0 #### /proc/net/arp This has the system ARP table, also in HEX format. Using the `arp -a` command gives more readable output. cat /proc/net/arp IP address HW type Flags HW address Mask Device 10.0.20.3 0x1 0x2 00:11:22:33:44:55 * eth0 10.0.20.4 0x1 0x2 00:11:11:11:44:55 * eth0 #### /proc/net/dev This has information about sent and received packages for all interfaces. `ifconfig` gives a more readable output. cat /proc/net/dev Inter-| Receive |Transmit face |bytes packets errs drop fifo frame compressed multicast|bytes packets errs drop fifo colls carrier compressed lo:775661077 998843 0 0 0 0 0 0 775661077 998843 0 0 0 0 0 0 eth0:2914473149 1605253769 1 0 0 1 0 0 3861718441 884372746 0 0 0 0 0 0 ### /proc/sys #### /proc/sys/vm/swappiness This value controls how willing the kernel will be to swap memory. If you raise this number, the kernel will want to swap more often, while lowering it will decrease his tendency to swap. cat /proc/sys/vm/swappiness 60 #### /proc/sys/kernel/threads-max This value is the maximum number of processes/threads that can exist at any given time on the system. cat /proc/sys/kernel/threads-max 32068 #### /proc/sys/net/ipv4/conf/default/forwarding This file controls if the kernel forwards packets. If your system is not acting as a router or firewall this should be off (0). You can change it by `echo 1 > /proc/sys/net/ipv4/conf/default/forwarding` or by setting it in `/etc/sysctl.conf`. cat /proc/sys/net/ipv4/conf/default/forwarding 0 #### /proc/sys/vm/drop_caches Writing to this file causes the kernel to drop clean caches, dentries and inodes from memory, causing that memory to become free. To free pagecache, dentries and inodes, use `echo 3 > /proc/sys/vm/drop_caches`. Because this is a nondestructive operation and dirty objects are not freeable, you should run `sync` first! #### /proc/sysrq-trigger Writing a character to this file triggers the SysRq function sent by the key. This file is only writable by root. If you don't know what sysreq is, [read the wikipedia page to find out more.][2] #### /proc/sys/net/ipv4/ip _local_ port_range This controls the ports locally available for opening. If you use for example an apache or nginx proxy, that service will have to open two connections for each request (one to the client, one to the backend). Setting this value higher will in heavy load environments give a performance boost. cat /proc/sys/net/ipv4/ip_local_port_range 32768 61000 [1]: https://www.digitalocean.com/?refcode=7435ae6b8212 [2]: https://en.wikipedia.org/wiki/Magic_SysRq_key --- License: All the text on this website is free as in freedom unless stated otherwise. This means you can use it in any way you want, you can copy it, change it the way you like and republish it, as long as you release the (modified) content under the same license to give others the same freedoms you've got and place my name and a link to this site with the article as source. This site uses Google Analytics for statistics and Google Adwords for advertisements. You are tracked and Google knows everything about you. Use an adblocker like ublock-origin if you don't want it. All the code on this website is licensed under the GNU GPL v3 license unless already licensed under a license which does not allows this form of licensing or if another license is stated on that page / in that software: This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. Just to be clear, the information on this website is for meant for educational purposes and you use it at your own risk. I do not take responsibility if you screw something up. Use common sense, do not 'rm -rf /' as root for example. If you have any questions then do not hesitate to contact me. See https://raymii.org/s/static/About.html for details.