From e830fa716bedecbff8c3a572d1d20061342ec4c7 Mon Sep 17 00:00:00 2001 From: Johannes Stoelp Date: Tue, 27 Aug 2024 23:05:39 +0200 Subject: mv monitor -> process --- src/monitor/README.md | 8 ------ src/monitor/lsof.md | 74 -------------------------------------------------- src/monitor/pgrep.md | 16 ----------- src/monitor/pidstat.md | 31 --------------------- src/monitor/pmap.md | 10 ------- src/monitor/ps.md | 61 ----------------------------------------- src/monitor/pstack.md | 6 ---- 7 files changed, 206 deletions(-) delete mode 100644 src/monitor/README.md delete mode 100644 src/monitor/lsof.md delete mode 100644 src/monitor/pgrep.md delete mode 100644 src/monitor/pidstat.md delete mode 100644 src/monitor/pmap.md delete mode 100644 src/monitor/ps.md delete mode 100644 src/monitor/pstack.md (limited to 'src/monitor') diff --git a/src/monitor/README.md b/src/monitor/README.md deleted file mode 100644 index dee94aa..0000000 --- a/src/monitor/README.md +++ /dev/null @@ -1,8 +0,0 @@ -# Resource analysis & monitor - -- [lsof](./lsof.md) -- [pidstat](./pidstat.md) -- [pgrep](./pgrep.md) -- [ps](./ps.md) -- [pmap](./pmap.md) -- [pstack](./pstack.md) diff --git a/src/monitor/lsof.md b/src/monitor/lsof.md deleted file mode 100644 index 562c8fc..0000000 --- a/src/monitor/lsof.md +++ /dev/null @@ -1,74 +0,0 @@ -# lsof(8) - -```markdown -lsof - -r ..... repeatedly execute command ervery seconds - -a ......... AND slection filters instead ORing (OR: default) - -p ... filter by - +fg ........ show file flags for file descripros - -n ......... don't convert network addr to hostnames - -P ......... don't convert network port to service names - -i <@h[:p]>. show connections to h (hostname|ip addr) with optional port p - -s ... in conjunction with '-i' filter for protocol

in state - -U ......... show unix domain sockets ('@' indicates abstract sock name, see unix(7)) -``` - -```markdown -file flags: - R/W/RW ..... read/write/read-write - CR ......... create - AP ......... append - TR ......... truncate -``` - -```markdown --s protocols - TCP, UDP - --s states (TCP) - CLOSED, IDLE, BOUND, LISTEN, ESTABLISHED, SYN_SENT, SYN_RCDV, ESTABLISHED, - CLOSE_WAIT, FIN_WAIT1, CLOSING, LAST_ACK, FIN_WAIT_2, TIME_WAIT - --s states (UDP) - Unbound, Idle -``` - -# Examples - -## File flags -Show open files with file flags for process: -```markdown -lsof +fg -p -``` - -## Open TCP connections -Show open tcp connections for `$USER`: -```markdown -lsof -a -u $USER -i TCP -``` -**Note**: `-a` _ands_ the results. If `-a` is not given all open files matching -`$USER` and all tcp connections are listed (_ored_). - -## Open connection to specific host -Show open connections to `localhost` for `$USER`: -```markdown -lsof -a -u $USER -i @localhost -``` - -## Open connection to specific port -Show open connections to port `:1234` for `$USER`: -```markdown -lsof -a -u $USER -i :1234 -``` - -## IPv4 TCP connections in `ESTABLISHED` state -```markdown -lsof -i 4TCP -s TCP:ESTABLISHED -``` -## List open files in a mounted directory. -This may help to find which processes keep devices busy when trying to unmount -and the device is currently busy. -```markdown -# Assuming /proc is a mount point. -lsof /proc -``` diff --git a/src/monitor/pgrep.md b/src/monitor/pgrep.md deleted file mode 100644 index b2cf466..0000000 --- a/src/monitor/pgrep.md +++ /dev/null @@ -1,16 +0,0 @@ -# pgrep(1) - -```markdown -pgrep [opts] - -n only list newest matching process - -u only show matching for user - -l additionally list command - -a additionally list command + arguments - -x match exactly -``` - -## Debug newest process -For example attach gdb to newest zsh process from `$USER`. -```markdown -gdb -p $(pgrep -n -u $USER zsh) -``` diff --git a/src/monitor/pidstat.md b/src/monitor/pidstat.md deleted file mode 100644 index b57f231..0000000 --- a/src/monitor/pidstat.md +++ /dev/null @@ -1,31 +0,0 @@ -# pidstat(1) - -```markdown -pidstat [opt] [interval] [cont] - -U [user] show username instead UID, optionally only show for user - -r memory statistics - -d I/O statistics - -h single line per process and no lines with average -``` - -# Page fault and memory utilization -```markdown -pidstat -r -p [interval] [count] -``` - -```markdown -minor_pagefault: Happens when the page needed is already in memory but not - allocated to the faulting process, in that case the kernel - only has to create a new page-table entry pointing to the - shared physical page (not required to load a memory page from - disk). - -major_pagefault: Happens when the page needed is NOT in memory, the kernel - has to create a new page-table entry and populate the - physical page (required to load a memory page from disk). -``` - -# I/O statistics -```markdown -pidstat -d -p [interval] [count] -``` diff --git a/src/monitor/pmap.md b/src/monitor/pmap.md deleted file mode 100644 index 531ae99..0000000 --- a/src/monitor/pmap.md +++ /dev/null @@ -1,10 +0,0 @@ -# pmap(1) - -```markdown -pmap [opts] - Dump virtual memory map of process. - Compared to /proc//maps it shows the size of the mappings. -opts: - -p show full path in the mapping - -x show details (eg RSS usage of each segment) -``` diff --git a/src/monitor/ps.md b/src/monitor/ps.md deleted file mode 100644 index d7ddf95..0000000 --- a/src/monitor/ps.md +++ /dev/null @@ -1,61 +0,0 @@ -# ps(1) - -``` -ps [opt] - opt: - --no-header .... do not print column header - -o ....... comma separated list of output columns - -p ....... only show pid - -C ...... only show processes matching name - -T ............. list threads - --signames ..... use short signames instead bitmasks -``` -> Set `PS_FORMAT` env variable to setup default output columns. - -Frequently used output columns -``` -pid process id -ppid parent process id -pgid process group id -tid thread id - -comm name of process -cmd name of process + args (full) - -etime elapsed time (since process started) -user user owning process -thcount thread count of process -nice nice value (-20 highest priority to 19 lowest) - -pcpu cpu utilization (percent) -pmem physical resident set (rss) (percent) -rss physical memory (in kb) -vsz virtual memory (in kb) - -sig mask of pending signals -sigcatch mask of caught signals -sigignore mask of ignored signals -sigmask mask of blocked signals -``` - -## Example: Use output for scripting -```sh -# Print the cpu affinity for each thread of process 31084. -for tid in $(ps -o tid --no-header -T -p 31084); do - taskset -c -p $tid; -done -``` - -## Example: Watch processes by name -```sh -watch -n1 ps -o pid,pcpu,pmem,rss,vsz,state,user,comm -C fish -``` - -## Example: Show signal information -```sh -# With signal masks. -ps -o pid,user,sig,sigcatch,sigignore,sigmask,comm -p 66570 - -# With signal names. -ps --signames -o pid,user,sig,sigcatch,sigignore,sigmask,comm -p 66570 -``` diff --git a/src/monitor/pstack.md b/src/monitor/pstack.md deleted file mode 100644 index c135844..0000000 --- a/src/monitor/pstack.md +++ /dev/null @@ -1,6 +0,0 @@ -# pstack(1) - -```markdown -pstack - Dump stack for all threads of process. -``` -- cgit v1.2.3