जब मैं अपने लिनक्स सर्वर से बाहर निकलने की कोशिश करता हूं तो मुझे संदेश मिलता है:
रुके हुए काम हैं।
: क्या इनको मारने का एक ही आदेश है?
shopt -s checkjobs
मेरे .bashrc
जब मैं अपने लिनक्स सर्वर से बाहर निकलने की कोशिश करता हूं तो मुझे संदेश मिलता है:
रुके हुए काम हैं।
: क्या इनको मारने का एक ही आदेश है?
shopt -s checkjobs
मेरे .bashrc
जवाबों:
बैश के तहत सभी रुकी नौकरियों को जल्दी से मारने के लिए, दर्ज करें:
kill -9 `jobs -ps`
jobs -ps
-p
रोकी गई ( -s
) नौकरियों की प्रक्रिया आईडी ( ) को सूचीबद्ध करता है ।
kill -9 `jobs -ps`
उन सभी को SIGKILL सिग्नल भेजता है।
sudo kill `jobs -p`
फ्लॉप काम लेकिन स्पष्ट रूप से टाइपिंग पीआईडी किया था।
kill
जैसे कि यह कुछ नहीं करेगा, क्योंकि प्रक्रियाएं रोक दी जाती हैं, वे SIGTERM (-15) को संसाधित नहीं करेंगे जो डिफ़ॉल्ट रूप से उन्हें भेजा जाता है।
इसे टाइप करने का प्रयास करें:
kill -9 $(jobs -p)
स्वीकृत उत्तर सभी नौकरियों को मार देगा (जो इस मामले में पर्याप्त है) और न केवल रुके हुए लोग। क्या आप केवल रूके हुए लोगों को मारना चाहते हैं, दौड़ें:
kill $(jobs -l | grep Stopped | cut -d' ' -f3)
awk '/Stopped/{print $3}')
-s
स्वीकार किए जाते हैं जवाब फिल्टर बस बंद कर दिया वालों पर तर्क
सबसे आसान तरीका वास्तव में तुरंत बाहर निकलने का प्रयास करना है; bash
इसका मतलब यह होगा कि "सभी बंद नौकरियों और बाहर निकलें को मारें"।
for x in `jobs -p` ; do kill -9 $x ; done
बस अगर यह किसी और की मदद करता है - ज्यादातर लोग यहां हैं क्योंकि उनके पास कुछ बंद प्रक्रियाएं हैं जो उन्होंने शुरू की थीं, शायद शेल के माध्यम से पृष्ठभूमि में। मुझे अन्य उपयोगकर्ताओं द्वारा रोकी गई प्रक्रियाओं को रूट के रूप में खोजने की आवश्यकता थी, जिसके लिए jobs
कमांड पर वेरिएंट नहीं करेगा।
आसपास खुदाई करने का एक सा man ps
मुझे यह करने के लिए मिला:
ps -a -o pid,user,cmd,state | grep 'T$'
स्पष्टीकरण: -a
ध्वज कहता है कि सभी प्रक्रियाओं को दिखाएं, फिर -o
आउटपुट को नियंत्रित करता है, प्रत्येक प्रक्रिया के बारे में क्या जानकारी दिखाई जाएगी। मैं चुनने कर रहा हूँ pid
, user
, cmd
(कमांड लाइन), और state
है, जो प्रक्रिया राज्य ।
से man ps
:
PROCESS STATE CODES
Here are the different values that the s, stat and state output specifiers (header "STAT" or "S") will display to describe the
state of a process:
D uninterruptible sleep (usually IO)
R running or runnable (on run queue)
S interruptible sleep (waiting for an event to complete)
T stopped, either by a job control signal or because it is being traced
W paging (not valid since the 2.6.xx kernel)
X dead (should never be seen)
Z defunct ("zombie") process, terminated but not reaped by its parent
इसलिए अंत में मैं इसे grep T$
कहता हूं, जो मुझे अंतिम कॉलम में टी की सभी प्रक्रियाएं दिखाता है।
और फिर मेरे पास अलग-अलग उपयोगकर्ताओं की सभी प्रक्रियाओं की एक अच्छी सूची है जो बंद अवस्था में हैं।
$ ps -a -o pid,user,cmd,state | grep 'T$'
865 joson74+ python T
885 joson74+ sh -c less T
886 joson74+ less T
1014 minames+ python3.4 -i /home/minames T
5352 MooKo nano stdio.h T
7851 harry tmux attach T
12083 harry tmux attach T
13495 gorylla+ python3.4 -i /home/gorylla1 T
18009 conr1d vim T
19664 enythin+ python T
24906 wardlist python T
jobs -ps
इस उत्तर की तुलना में सरल है। यह कहा जा रहा है, यह उत्तर केवल Ctrl-Z
शेल में रोकी गई नौकरियों को नहीं दिखाता है , लेकिन सभी ने नौकरियों को रोक दिया है: अन्य शेल, अन्य उपयोगकर्ता , जिसमें डीबग किए जा रहे जॉब्स शामिल हैं (जैसे जीडीबी द्वारा)।
ps -el | grep T
राज्य 'टी' में प्रक्रियाओं को खोजने के लिए उपयोग करना था ।
यदि आप कुछ रुकी हुई नौकरियों को निकालना चाहते हैं, लेकिन सभी नहीं, तो यह कोशिश करें:
सबसे पहले, नौकरियों की सूची बनाएं, आपको कुछ इस तरह मिलेगा:
$ jobs -l
[2] 4813 Stopped ./parse < call.txt
[3]- 4819 Stopped ./parse < call.txt
एक बंद नौकरी के लिए मार भेजें, यह कुछ भी नहीं है लेकिन कतार से इसे अग्रभूमि में लाने के बजाय, यह समाप्त हो जाएगा
$ fg %2
./parse < call.txt
Terminated
$ jobs -l
[3]- 4819 Stopped ./parse < call.txt
आम तौर पर यदि आपको वह संदेश मिला है, तो आपको दो बार लॉगआउट करने की आवश्यकता है। उदा। पहले Ctrl+Dआपको रुकी हुई नौकरियों के बारे में सूचित करने के लिए आपको चेतावनी संदेश देता है, दूसरी बार दबाने पर आप नौकरियों को मार देंगे। यह वही लागू होता है logout
और exit
आदेश देता है।
उन्हें मैन्युअल रूप से मारने के लिए, प्रयास करें kill $(jobs -p)
:।
यदि आप अपने वर्तमान शेल से नौकरियों को मारना नहीं चाहते हैं, तो आप disown
कमांड का उपयोग करके उन्हें बिना मारे सक्रिय नौकरियों की तालिका से निकाल सकते हैं । उदाहरण के लिए
$ sleep 1000 &
[1] 19404
$ jobs
[1]+ Running sleep 1000 &
$ disown
रुकी हुई नौकरियों को भी प्रक्रिया ( T
चरित्र) की स्थिति से निर्धारित किया जा सकता है, जिसका अर्थ है कि इस प्रक्रिया को सिग्नल द्वारा रोक दिया गया था SIGSTOP
, जैसे कि , SIGTSTP
या अन्य (जैसे SIGTTIN
, या SIGTTOU
)।
यदि jobs
शेल शेल कमांड उपलब्ध नहीं है, तो निम्नलिखित कमांड द्वारा रोकी गई प्रक्रियाओं को सूचीबद्ध किया जा सकता है:
ps wuax | awk '$8 ~ "T"'
उन सभी को मारने के लिए, आप मूल रूप से टाइप कर सकते हैं:
kill -9 $(ps wuax | awk 'NR>1 && $8 ~ "T" {print $2}')
यहाँ एक सरल परीक्षण है:
$ sleep 1000 &
[1] 2014
$ sleep 1000 &
[2] 2015
$ sleep 1000 &
[3] 2016
$ sleep 1000 &
[4] 2017
$ killall -STOP sleep
[1] Stopped sleep 1000
[2] Stopped sleep 1000
[3] Stopped sleep 1000
[4] Stopped sleep 1000
$ ps wuax | awk '$8 ~ "T"'
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
vagrant 2014 0.0 0.0 7228 832 pts/0 T 20:38 0:00 sleep 1000
vagrant 2015 0.0 0.0 7228 708 pts/0 T 20:38 0:00 sleep 1000
vagrant 2016 0.0 0.0 7228 760 pts/0 T 20:38 0:00 sleep 1000
vagrant 2017 0.0 0.0 7228 828 pts/0 T 20:38 0:00 sleep 1000
$ kill -9 $(awk 'NR>1 && $8 ~ "T" {print $2}' <(ps wuax))
$ jobs
[1] Killed sleep 1000
[2] Killed sleep 1000
[3] Killed sleep 1000
[4] Killed sleep 1000