Bu soruyu 2013 yılında sorduğundan bu yana ad alanları ile çalışmak için yardımcı programlar geliştirildi.
lsns
dan util-linux paketinin çeşitli yararlı biçimlerde, ad farklı türleri listeleyebilirsiniz.
# lsns --help
Usage:
lsns [options] [<namespace>]
List system namespaces.
Options:
-J, --json use JSON output format
-l, --list use list format output
-n, --noheadings don't print headings
-o, --output <list> define which output columns to use
-p, --task <pid> print process namespaces
-r, --raw use the raw output format
-u, --notruncate don't truncate text in columns
-t, --type <name> namespace type (mnt, net, ipc, user, pid, uts, cgroup)
-h, --help display this help and exit
-V, --version output version information and exit
Available columns (for --output):
NS namespace identifier (inode number)
TYPE kind of namespace
PATH path to the namespace
NPROCS number of processes in the namespace
PID lowest PID in the namespace
PPID PPID of the PID
COMMAND command line of the PID
UID UID of the PID
USER username of the PID
For more details see lsns(8).
lsns
yalnızca her işlem için en düşük PID'yi listeler - ancak pgrep
bir ad alanına ait tüm işlemleri listelemek istiyorsanız bu PID'yi kullanabilirsiniz .
Örneğin, docker'da gitlab kullanıyorum ve bu ad alanında çalışan tüm işlemleri bulmak istiyorsanız, şunları yapabilirim:
# lsns -t pid -o ns,pid,command | grep gitlab
4026532661 459 /opt/gitlab/embedded/bin/redis-server 127.0.0.1:0
ve daha sonra şu pid'i (459) pgrep
:
# pgrep --ns 459 -a
459 /opt/gitlab/embedded/bin/redis-server 127.0.0.1:0
623 postgres: gitlab gitlabhq_production [local] idle
[...around 50 lines deleted...]
30172 nginx: worker process
Ayrıca ps
, örneğin ad alan kimliğini (4026532661) kullanabilirim :
ps -o pidns,pid,cmd | awk '$1==4026532661'
[...output deleted...]