Verilen bir PID hakkında ayrıntılı bilgileri nasıl görebilirim?


23

Başlık temelde her şeyi söylüyor. Sadece PID'nin verildiği bir program var, daha fazla bir şey yok ve verilen işlem hakkında nasıl daha fazla bilgi edindiğimi bilmek istiyorum.


Python ile çalışıyorsanız, muhtemelen psutilkütüphaneyi kullanmak istersiniz . Yapın: psutil.Process(pid)işlem nesnesini elde etmek ve daha sonra bellek / işlemci vb. Bilgileri almak için arabirimini kullanmak.
Bakuriu

Yanıtlar:



12

Tam ihtiyacın nedir bilmiyorum. ama bu size yardımcı olabilir.

Her işlem için ayrı ayrı bir dizin var /proc.

ps -ef | grep docker 
root      1700     1  0 Sep20 ?        00:03:04 /usr/bin/docker daemon --raw-logs

Yukarıdaki çıkışta PID 1700.

git /proc/1700

cd /proc/1700

ve lsorada yap

ls
attr       clear_refs       cpuset   fd       limits     mem         net        oom_score      projid_map  sessionid  stat     task
autogroup  cmdline          cwd      fdinfo   loginuid   mountinfo   ns         oom_score_adj  root        setgroups  statm    timers
auxv       comm             environ  gid_map  map_files  mounts      numa_maps  pagemap        sched       smaps      status   uid_map
cgroup     coredump_filter  exe      io       maps       mountstats  oom_adj    personality    schedstat   stack      syscall  wchan

süreçle ilgili tüm bilgileri içeren birçok dosya var.

Sevmek:

cat /proc/1700/status

Name:   docker
State:  S (sleeping)
Tgid:   1700
Ngid:   0
Pid:    1700
PPid:   1
TracerPid:  0
Uid:    0   0   0   0
Gid:    0   0   0   0
FDSize: 64
Groups: 0 999 
VmPeak:   527576 kB
VmSize:   527512 kB
VmLck:         0 kB
VmPin:         0 kB
VmHWM:     46032 kB
VmRSS:     34180 kB
VmData:   449308 kB
VmStk:       136 kB
VmExe:     28324 kB
VmLib:      4236 kB
VmPTE:       296 kB
VmSwap:     5324 kB
Threads:    12
SigQ:   0/63662
SigPnd: 0000000000000000
ShdPnd: 0000000000000000
SigBlk: 0000000000000000
SigIgn: 0000000000000000
SigCgt: ffffffffffc1feff
CapInh: 0000000000000000
CapPrm: 0000003fffffffff
CapEff: 0000003fffffffff
CapBnd: 0000003fffffffff
Seccomp:    0
Cpus_allowed:   f
Cpus_allowed_list:  0-3
Mems_allowed:   00000000,00000001
Mems_allowed_list:  0
voluntary_ctxt_switches:    437726
nonvoluntary_ctxt_switches: 27579

İşlem bilgisini almak için temel komuta ihtiyacınız varsa, komutu kullanarak kolayca alabilirsiniz:

man ps

3

psCevabı eklemek için, pidstatkullanıcı modunda harcanan zaman veya CPU'nun işgali gibi ek istatistikleri de gösteren bir komut var. İle kullanabilirsiniz:

# pidstat -p 51648

-dG / Ç hakkında ayrıntılı bilgi eklemek için bayrağı da ekleyebilirsiniz :

# pidstat -p 51648 -d

Ayrıca, komutu her X saniyede bir yenilemeyi sağlamak için ikinci bir parametre olarak bir tam sayı da yapabilirsiniz:

# pidstat -p 51648 3
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.