लिनक्स व्यवस्थापक - प्रक्रिया प्रबंधन

प्रक्रिया प्रबंधन- bg, fg, nohup, ps, pstree, टॉप, किल, किलॉल, फ्री, अपटाइम, नाइस के साथ उपयोग किए जाने वाले सामान्य कमांड निम्नलिखित हैं।

प्रक्रियाओं के साथ काम करें

Quick Note: Process PID in Linux

लिनक्स में हर रनिंग प्रोसेस को PID या प्रोसेस आईडी नंबर दिया जाता है। यह पीआईडी है कि कैसे CentOS एक विशेष प्रक्रिया की पहचान करता है। जैसा कि हम चर्चा कर चुके हैं, systemd पहली प्रक्रिया है और CentOS में 1 की PID दी गई है।

Pgrep किसी दिए गए प्रक्रिया के नाम के लिए Linux PID प्राप्त करने के लिए उपयोग किया जाता है।

[root@CentOS]# pgrep systemd 
1 
[root@CentOS]#

जैसा कि देखा गया है, pgrep कमांड सिस्टम की वर्तमान पीआईडी ​​लौटाता है।

बुनियादी CentOS प्रक्रिया और CentOS में नौकरी प्रबंधन

लिनक्स में प्रक्रियाओं के साथ काम करते समय यह जानना महत्वपूर्ण है कि कमांड लाइन पर बुनियादी अग्रभूमि और पृष्ठभूमि प्रक्रियाएं कैसे की जाती हैं।

  • fg - अग्रभूमि में लाना प्रक्रिया

  • bg - पृष्ठभूमि के लिए Movesthe प्रक्रिया

  • jobs - शेल से जुड़ी वर्तमान प्रक्रियाओं की सूची

  • ctrl+z - वर्तमान प्रक्रिया को सोने के लिए नियंत्रण + z कुंजी संयोजन

  • & - पृष्ठभूमि में Startsthe प्रक्रिया

चलो शेल कमांड नींद का उपयोग करना शुरू करते हैंsleepजैसा कि नाम दिया गया है, बस समय की एक निर्धारित अवधि के लिए सोएँ : नींद

[root@CentOS ~]$ jobs

[root@CentOS ~]$ sleep 10 & 
[1] 12454 

[root@CentOS ~]$ sleep 20 & 
[2] 12479

[root@CentOS ~]$ jobs 
[1]-  Running                 sleep 10 & 
[2]+  Running                 sleep 20 &

[cnetos@CentOS ~]$

अब, पहली नौकरी को अग्रभूमि में लाएँ -

[root@CentOS ~]$ fg 1 
sleep 10

यदि आप साथ चल रहे हैं, तो आप देखेंगे कि अग्रभूमि नौकरी आपके शेल में अटक गई है। अब, प्रक्रिया को सोने के लिए रखें, फिर इसे पृष्ठभूमि में पुन: सक्षम करें।

  • मारो नियंत्रण + z
  • टाइप करें: bg 1, बैकग्राउंड में पहला काम भेजना और उसे शुरू करना।
[root@CentOS ~]$ fg 1 
sleep 20 
^Z 
[1]+  Stopped                 sleep 20

[root@CentOS ~]$ bg 1 
[1]+ sleep 20 &

[root@CentOS ~]$

nohup

शेल या टर्मिनल से काम करते समय, यह ध्यान देने योग्य है कि डिफ़ॉल्ट रूप से शेल से जुड़ी सभी प्रक्रियाएं और कार्य समाप्त हो जाएंगे जब शेल बंद हो जाएगा या उपयोगकर्ता लॉग आउट करेगा। जब nohup का उपयोग किया जाता है तो प्रक्रिया चलती रहेगी यदि उपयोगकर्ता लॉग आउट करता है या उस शेल को बंद करता है जिससे प्रक्रिया जुड़ी हुई है।

[root@CentOS]# nohup ping www.google.com & 
[1] 27299 
nohup: ignoring input and appending output to ‘nohup.out’

[root@CentOS]# pgrep ping 
27299

[root@CentOS]# kill -KILL `pgrep ping` 
[1]+  Killed                  nohup ping www.google.com

[root@CentOS rdc]# cat nohup.out  
PING www.google.com (216.58.193.68) 56(84) bytes of data. 
64 bytes from sea15s07-in-f4.1e100.net (216.58.193.68): icmp_seq = 1 ttl = 128
time = 51.6 ms 
64 bytes from sea15s07-in-f4.1e100.net (216.58.193.68): icmp_seq = 2 ttl = 128
time = 54.2 ms 
64 bytes from sea15s07-in-f4.1e100.net (216.58.193.68): icmp_seq = 3 ttl = 128
time = 52.7 ms

ps कमांड

psकिसी विशिष्ट प्रक्रिया के स्नैपशॉट की जांच के लिए प्रशासकों द्वारा आमतौर पर कमांड का उपयोग किया जाता है। पीएस आमतौर पर विश्लेषण के लिए एक विशिष्ट प्रक्रिया को फ़िल्टर करने के लिए grep के साथ प्रयोग किया जाता है ।

[root@CentOS ~]$ ps axw | grep python 
762   ?        Ssl    0:01 /usr/bin/python -Es /usr/sbin/firewalld --nofork -nopid 
1296  ?        Ssl    0:00 /usr/bin/python -Es /usr/sbin/tuned -l -P 
15550 pts/0    S+     0:00 grep --color=auto python

उपरोक्त कमांड में, हम अजगर इंटरप्रेटर का उपयोग करते हुए सभी प्रक्रियाओं को देखते हैं । परिणाम के साथ शामिल थे हमारे grep कमांड, स्ट्रिंग अजगर की तलाश में

पीएस के साथ उपयोग किए जाने वाले सबसे सामान्य कमांड लाइन स्विच निम्नलिखित हैं ।

स्विच कार्य
वर्तमान उपयोगकर्ता के लिए केवल रिपोर्टिंग प्रक्रियाओं की बाधाओं को छोड़ देता है
एक्स एक ट्टी या शेल से जुड़ी प्रक्रियाएं नहीं दिखाता है
w आउटपुट का व्यापक प्रदर्शन प्रदर्शित करता है
कमांड के बाद पर्यावरण दिखाता है
-इ सभी प्रक्रियाओं का चयन करता है
-ओ उपयोगकर्ता-परिभाषित स्वरूपित आउटपुट
यू एक विशिष्ट उपयोगकर्ता द्वारा सभी प्रक्रियाओं को दिखाता है
-सी नाम या प्रक्रिया आईडी द्वारा सभी प्रक्रियाओं को दिखाता है
--sort परिभाषा के अनुसार प्रक्रियाओं का निर्माण करता है

द्वारा उपयोग में सभी प्रक्रियाओं को देखने के लिए कोई भी उपयोगकर्ता -

[root@CentOS ~]$ ps -u nobody 
PID TTY          TIME CMD 
1853 ?        00:00:00 dnsmasq 

[root@CentOS ~]$

फ़ायरवॉल प्रक्रिया के बारे में सभी जानकारी देखने के लिए -

[root@CentOS ~]$ ps -wl -C firewalld 
F   S   UID   PID   PPID   C   PRI   NI   ADDR   SZ   WCHAN   TTY   TIME      CMD
0   S     0   762      1   0    80   0     -   81786  poll_s   ?   00:00:01 firewalld 

[root@CentOS ~]$

आइए देखें कि कौन सी प्रक्रियाएं सबसे अधिक मेमोरी का उपभोग कर रही हैं -

[root@CentOS ~]$ ps aux  --sort=-pmem | head -10 
USER       PID   %CPU   %MEM   VSZ     RSS   TTY   STAT   START   TIME   COMMAND 
cnetos     6130   0.7   5.7   1344512 108364  ?      Sl   02:16   0:29  /usr/bin/gnome-shell 
cnetos     6449   0.0   3.4   1375872 64440   ?      Sl   02:16   0:00  /usr/libexec/evolution-calendar-factory 
root       5404   0.6   2.1   190256  39920 tty1     Ssl+ 02:15   0:27  /usr/bin/Xorg :0 -background none -noreset -audit 4 -verbose -auth /run/gdm/auth-for-gdm-iDefCt/database -seat seat0 -nolisten tcp vt1 
cnetos     6296   0.0   1.7   1081944 32136   ?      Sl   02:16   0:00  /usr/libexec/evolution/3.12/evolution-alarm-notify 
cnetos     6350   0.0   1.5   560728  29844   ?      Sl   02:16   0:01  /usr/bin/prlsga 
cnetos     6158   0.0   1.4   1026956 28004   ?      Sl   02:16   0:00  /usr/libexec/gnome-shell-calendar-server 
cnetos     6169   0.0   1.4   1120028 27576   ?      Sl   02:16   0:00  /usr/libexec/evolution-source-registry 
root       762    0.0   1.4   327144  26724   ?      Ssl  02:09   0:01  /usr/bin/python -Es /usr/sbin/firewalld --nofork --nopid 
cnetos     6026   0.0  1.4 1090832 26376      ?      Sl   02:16   0:00  /usr/libexec/gnome-settings-daemon

[root@CentOS ~]$

कस्टम आउटपुट प्रदर्शित करते हुए, उपयोगकर्ता सेंटोस और प्रारूप द्वारा सभी प्रक्रियाएं देखें -

[cnetos@CentOS ~]$ ps -u cnetos -o pid,uname,comm 
   PID    USER     COMMAND 
   5802  centos   gnome-keyring-d 
   5812  cnetos   gnome-session 
   5819  cnetos   dbus-launch 
   5820  cnetos   dbus-daemon 
   5888  cnetos   gvfsd 
   5893  cnetos   gvfsd-fuse 
   5980  cnetos   ssh-agent   
   5996  cnetos   at-spi-bus-laun

pstree कमांड

pstreeपीएस के समान है, लेकिन अक्सर उपयोग नहीं किया जाता है। यह एक नटखट पेड़ के फैशन में प्रक्रियाओं को प्रदर्शित करता है।

[centos@CentOS ~]$ pstree 
  systemd─┬─ModemManager───2*[{ModemManager}] 
          ├─NetworkManager─┬─dhclient 
          │                └─2*[{NetworkManager}] 
          ├─2*[abrt-watch-log] 
          ├─abrtd 
          ├─accounts-daemon───2*[{accounts-daemon}] 
          ├─alsactl 
          ├─at-spi-bus-laun─┬─dbus-daemon───{dbus-daemon} 
          │                 └─3*[{at-spi-bus-laun}] 
          ├─at-spi2-registr───2*[{at-spi2-registr}] 
          ├─atd 
          ├─auditd─┬─audispd─┬─sedispatch 
          │        │         └─{audispd} 
          │        └─{auditd} 
          ├─avahi-daemon───avahi-daemon 
          ├─caribou───2*[{caribou}] 
          ├─cgrulesengd 
          ├─chronyd 
          ├─colord───2*[{colord}] 
          ├─crond 
          ├─cupsd

Pstree से कुल उत्पादन 100 लाइनों से अधिक हो सकता है। आमतौर पर, पीएस अधिक उपयोगी जानकारी देगा।

शीर्ष कमान

topलिनक्स में प्रदर्शन समस्याओं का निवारण करते समय सबसे अधिक उपयोग की जाने वाली कमांड में से एक है। यह वास्तविक समय के आँकड़े और लिनक्स में प्रक्रिया की निगरानी के लिए उपयोगी है। कमांड लाइन से ऊपर लाए जाने पर टॉप का डिफ़ॉल्ट आउटपुट होता है ।

Tasks: 170 total,   1 running, 169 sleeping,   0 stopped,   0 zombie 
%Cpu(s):  2.3 us,  2.0 sy,  0.0 ni, 95.7 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st 
KiB Mem :  1879668 total,   177020 free,   607544 used,  1095104 buff/cache 
KiB Swap:  3145724 total,  3145428 free,      296 used.  1034648 avail Mem 
 
PID    USER     PR   NI    VIRT     RES   SHR    S  %CPU  %MEM   TIME+   COMMAND
5404   root     20   0    197832   48024  6744   S   1.3   2.6  1:13.22   Xorg
8013   centos   20   0    555316   23104  13140  S   1.0   1.2  0:14.89   gnome-terminal-
6339   centos   20   0    332336   6016   3248   S   0.3   0.3  0:23.71   prlcc
6351   centos   20   0    21044    1532   1292   S   0.3   0.1  0:02.66   prlshprof

शीर्ष चलाते समय उपयोग की जाने वाली सामान्य गर्म कुंजियाँ ( गर्म कुंजी कुंजी को दबाकर एक्सेस की जाती हैं क्योंकि शीर्ष आपके शेल में चल रहा है)।

आदेश कार्य
शीर्ष मेनू पर बोल्ड हाइलाइटिंग को सक्षम / अक्षम करता है
जेड रंग योजना चक्र
एल चक्र औसत लोड बढ़ रहा है
मेमोरी औसत हेडिंग को साइकिल करता है
टी कार्य जानकारी शीर्षक
एच मदद मेनू
Shift + F छँटाई और प्रदर्शन क्षेत्रों को अनुकूलित करता है

शीर्ष के लिए सामान्य कमांड लाइन स्विच निम्नलिखित हैं ।

आदेश कार्य
-ओ कॉलम द्वारा सॉर्ट (आरोही या अवरोही क्रमबद्ध करने के लिए - या + के साथ आगे बढ़ सकता है)
यू एक निर्दिष्ट उपयोगकर्ता से केवल प्रक्रियाओं को दिखाता है
डी शीर्ष के विलंब समय को अद्यतन करता है
-O स्तंभों की सूची लौटाता है जो शीर्ष क्रमबद्धता को लागू कर सकते हैं

शीर्ष में छँटाई विकल्प स्क्रीन, Shift + F का उपयोग करके प्रस्तुत किया गया । यह स्क्रीन शीर्ष प्रदर्शन और सॉर्ट विकल्पों के अनुकूलन की अनुमति देता है ।

Fields Management for window 1:Def, whose current sort field is %MEM 
Navigate with Up/Dn, Right selects for move then <Enter> or Left commits, 
 'd' or <Space> toggles display, 's' sets sort.  Use 'q' or <Esc> to end!
 
* PID     = Process Id             TGID    = Thread Group Id      
* USER    = Effective User Name    ENVIRON = Environment vars     
* PR      = Priority               vMj     = Major Faults delta   
* NI      = Nice Value             vMn     = Minor Faults delta   
* VIRT    = Virtual Image (KiB)    USED    = Res+Swap Size (KiB)  
* RES     = Resident Size (KiB)    nsIPC   = IPC namespace Inode  
* SHR     = Shared Memory (KiB)    nsMNT   = MNT namespace Inode
* S       = Process Status         nsNET   = NET namespace Inode  
* %CPU    = CPU Usage              nsPID   = PID namespace Inode  
* %MEM    = Memory Usage (RES)     nsUSER  = USER namespace Inode 
* TIME+   = CPU Time, hundredths   nsUTS   = UTS namespace Inode  
* COMMAND = Command Name/Line 
PPID    = Parent Process pid
UID     = Effective User Id

शीर्ष , उपयोगकर्ता rdc के लिए प्रक्रियाओं को दिखा रहा है और मेमोरी उपयोग द्वारा क्रमबद्ध है -

PID   USER  %MEM  PR  NI    VIRT    RES    SHR    S %CPU     TIME+    COMMAND
 6130  rdc    6.2  20   0  1349592  117160  33232  S  0.0   1:09.34    gnome-shell
 6449  rdc    3.4  20   0  1375872   64428  21400  S  0.0   0:00.43    evolution-calen
 6296  rdc    1.7  20   0  1081944   32140  22596  S  0.0   0:00.40    evolution-alarm
 6350  rdc    1.6  20   0   560728   29844   4256  S  0.0   0:10.16    prlsga
 6281  rdc    1.5  20   0  1027176   28808  17680  S  0.0   0:00.78    nautilus
 6158  rdc    1.5  20   0  1026956   28004  19072  S  0.0   0:00.20    gnome-shell-cal

मान्य शीर्ष फ़ील्ड्स (संघनित) दिखाना -

[centos@CentOS ~]$ top -O 
PID 
PPID 
UID 
USER 
RUID 
RUSER 
SUID 
SUSER 
GID 
GROUP 
PGRP 
TTY 
TPGID

कमान को मार डालो

killकमांड का उपयोग कमांड शेल से उसके पीआईडी ​​के माध्यम से एक प्रक्रिया को मारने के लिए किया जाता है। जब मारे गए एक प्रक्रिया है, हम भेजने के लिए एक संकेत निर्दिष्ट करने के लिए की जरूरत है। संकेत कर्नेल को बताता है कि हम प्रक्रिया को कैसे समाप्त करना चाहते हैं। सबसे अधिक इस्तेमाल होने वाले सिग्नल हैं -

  • SIGTERMकर्नेल के रूप में निहित है एक प्रक्रिया यह बताती है कि इसे जल्द से जल्द बंद कर देना चाहिए क्योंकि ऐसा करना सुरक्षित है। SIGTERM प्रक्रिया को इनायत से बाहर निकलने और सुरक्षित निकास संचालन करने का अवसर देता है।

  • SIGHUPSITEUP भेजे जाने पर अधिकांश डेमॉन पुनः आरंभ हो जाएंगे । यह अक्सर उन प्रक्रियाओं पर उपयोग किया जाता है जब कॉन्फ़िगरेशन फ़ाइल में परिवर्तन किए गए हैं।

  • SIGKILLचूंकि SIGTERM एक प्रक्रिया को बंद करने के लिए कहने के बराबर है। कर्नेल को एक प्रक्रिया को समाप्त करने के लिए एक विकल्प की आवश्यकता होती है जो अनुरोधों का अनुपालन नहीं करेगी। जब कोई प्रक्रिया लटका दी जाती है, तो प्रक्रिया को स्पष्ट रूप से बंद करने के लिए SIGKILL विकल्प का उपयोग किया जाता है।

सभी संकेतों से एक सूची है कि के साथ भेजा जा सकता है के लिए मार -l विकल्प का इस्तेमाल किया जा सकता है -

[root@CentOS]# kill -l 
1) SIGHUP           2) SIGINT         3) SIGQUIT        4) SIGILL         5) SIGTRAP
6) SIGABRT          7) SIGBUS         8) SIGFPE         9) SIGKILL       10) SIGUSR1
11) SIGSEGV        12) SIGUSR2       13) SIGPIPE       14) SIGALRM       15) SIGTERM
16) SIGSTKFLT      17) SIGCHLD       18) SIGCONT       19) SIGSTOP       20) SIGTSTP
21) SIGTTIN        22) SIGTTOU       23) SIGURG        24) SIGXCPU       25) SIGXFSZ
26) SIGVTALRM      27) SIGPROF       28) SIGWINCH      29) SIGIO         30) SIGPWR
31) SIGSYS         34) SIGRTMIN      35) SIGRTMIN+1    36) SIGRTMIN+2    37) SIGRTMIN+3
38) SIGRTMIN+4     39) SIGRTMIN+5    40) SIGRTMIN+6    41) SIGRTMIN+7    42) SIGRTMIN+8
43) SIGRTMIN+9     44) SIGRTMIN+10   45) SIGRTMIN+11   46) SIGRTMIN+12   47) SIGRTMIN+13 
48) SIGRTMIN+14    49) SIGRTMIN+15   50) SIGRTMAX-14   51) SIGRTMAX-13   52) SIGRTMAX-12 
53) SIGRTMAX-11    54) SIGRTMAX-10   55) SIGRTMAX-9    56) SIGRTMAX-8    57) SIGRTMAX-7
58) SIGRTMAX-6     59) SIGRTMAX-5    60) SIGRTMAX-4    61) SIGRTMAX-3    62) SIGRTMAX-2
63) SIGRTMAX-1     64) SIGRTMAX

[root@CentOS rdc]#

सिस्टम को पुनरारंभ करने के लिए SIGHUP का उपयोग करना ।

[root@CentOS]# pgrep systemd 
1 
464 
500 
643 
15071

[root@CentOS]# kill -HUP 1

[root@CentOS]# pgrep systemd
1 
464 
500 
643 
15196 
15197 
15198

[root@CentOS]#

pkillव्यवस्थापक को प्रक्रिया नाम से किल संकेत भेजने की अनुमति देगा ।

[root@CentOS]# pgrep ping 
19450 
[root@CentOS]# pkill -9 ping 
[root@CentOS]# pgrep ping 
[root@CentOS]#

killallसभी प्रक्रियाओं को मार देगा। किलॉल को रूट के रूप में उपयोग करने से सावधान रहें , क्योंकि यह सभी उपयोगकर्ताओं के लिए सभी प्रक्रियाओं को मार देगा।

[root@CentOS]# killall chrome

मुफ्त कमान

freeएक बहुत ही सरल कमांड है जिसे अक्सर सिस्टम की मेमोरी को जल्दी से जांचने के लिए उपयोग किया जाता है। यह प्रयुक्त भौतिक और स्वैप मेमोरी की कुल मात्रा प्रदर्शित करता है।

[root@CentOS]# free 
             total       used      free      shared      buff/cache      available 
Mem:        1879668     526284    699796     10304        653588          1141412 
Swap:       3145724          0    3145724

[root@CentOS]#

अच्छी आज्ञा

niceसीपीयू usages के संदर्भ में एक व्यवस्थापक प्रक्रिया की समयबद्धन प्राथमिकता निर्धारित करने की अनुमति देगा। अच्छाई मूल रूप से है कि कैसे कर्नेल एक प्रक्रिया या नौकरी के लिए सीपीयू समय स्लाइस अनुसूची करेगा। डिफ़ॉल्ट रूप से, यह माना जाता है कि प्रक्रिया को सीपीयू संसाधनों के बराबर उपयोग दिया जाता है।

सबसे पहले, आइए वर्तमान में चल रही प्रक्रियाओं की अच्छाई की जांच करने के लिए शीर्ष का उपयोग करें।

PID   USER   PR   NI    VIRT    RES    SHR   S  %CPU  %MEM     TIME+    COMMAND
28    root   39   19       0      0      0   S  0.0   0.0    0:00.17    khugepaged
690   root   39   19   16808   1396   1164   S  0.0   0.1    0:00.01    alsactl]
9598  rdc    39   19  980596  21904  10284   S  0.0   1.2    0:00.27    tracker-extract
9599  rdc    39   19  469876   9608   6980   S  0.0   0.5    0:00.04    tracker-miner-a
9609  rdc    39   19  636528  13172   8044   S  0.0   0.7    0:00.12    tracker-miner-f
9611  rdc    39   19  469620   8984   6496   S  0.0   0.5    0:00.02    tracker-miner-u
27    root   25    5       0      0      0   S  0.0   0.0    0:00.00    ksmd
637   rtkit  21    1  164648   1276   1068   S  0.0   0.1    0:00.11    rtkit-daemon
1     root   20    0  128096   6712   3964   S  0.3   0.4    0:03.57    systemd
2     root   20    0       0      0      0   S  0.0   0.0    0:00.01    kthreadd
3     root   20    0       0      0      0   S  0.0   0.0    0:00.50    ksoftirqd/0
7     root   20    0       0      0      0   S  0.0   0.0    0:00.00    migration/0
8     root   20    0       0      0      0   S  0.0   0.0    0:00.00    rcu_bh
9     root   20    0       0      0      0   S  0.0   0.0    0:02.07    rcu_sched

हम NI द्वारा दर्शाए गए NICE कॉलम पर ध्यान केंद्रित करना चाहते हैं । न्यूसिटी रेंज -20 से पॉजिटिव 19 के बीच कहीं भी हो सकती है। -20 उच्चतम दी गई प्राथमिकता को दर्शाता है।

nohup nice --20 ping www.google.com &

अच्छा पुनः

त्याग हमें पहले से चल रही प्रक्रिया की वर्तमान प्राथमिकता को बदलने की अनुमति देता है।

renice 17 -p 30727

उपरोक्त कमांड हमारे पिंग प्रोसेस कमांड की प्राथमिकता को कम करेगी ।