कैसे -9 एक पीआईडी ​​जो lsof- आई के माध्यम से पाया जाता है मारने के लिए एक shscript लिखने के लिए


29

मैं टॉमकैट का उपयोग कर रहा हूं, और कभी-कभी जब मैं इसे बंद करने के लिए कहता हूं तो यह प्रक्रिया को ठीक से नहीं मारता है।

इस तरह से मेरा तरीका भी है:

lsof -i tcp:8080

कौन से आउटपुट:

COMMAND PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
java    888 root   35u  IPv6 780659      0t0  TCP *:http-alt (LISTEN)
java    888 root   39r  IPv6 790103      0t0  TCP localhost:58916->localhost:http-alt (CLOSE_WAIT)
java    888 root   40r  IPv6 792585      0t0  TCP localhost:58936->localhost:http-alt (CLOSE_WAIT)
java    888 root   75r  IPv6 785553      0t0  TCP localhost:58701->localhost:http-alt (CLOSE_WAIT)
java    888 root   77r  IPv6 787642      0t0  TCP localhost:58814->localhost:http-alt (CLOSE_WAIT)
java    888 root  130u  IPv6 783894      0t0  TCP localhost:58686->localhost:http-alt (CLOSE_WAIT)
java    888 root  353u  IPv6 780929      0t0  TCP localhost:58632->localhost:http-alt (CLOSE_WAIT)

मैं फिर दौड़ता हूं

kill -9 pid

मुझे सभी पीआईडी ​​नंबर प्राप्त करने और उन्हें मारने का एक तरीका चाहिए। बात यह है कि मैं नहीं जानता कि कैसे उस क्षेत्र को अलग करना है।


1
यदि आप सुनिश्चित हैं कि आपके पास केवल एक tomcatप्रक्रिया खुली है, तो आप उपयोग कर सकते हैंkillall -9 tomcat
यूसुफ आर।

जवाबों:


57

इसमें एक -t(ट्रिक) विकल्प है lsof, जो आपको वही दिख रहा है जो आप देख रहे हैं

$ sudo lsof -ti tcp:80
1387
4538
4539

देख man lsof

-t       specifies  that  lsof should produce terse output with process
         identifiers only and no header - e.g., so that the output  may
         be piped to kill(1).  -t selects the -w option.

यह मानते हुए कि आपके पास आवश्यक अनुमतियां हैं, आप परिणाम को killकमांड प्रतिस्थापन के साथ पीआईडी ​​की सूची के रूप में पारित कर सकते हैं :

kill -9 $(lsof -ti tcp:80)

आपने अब मेरे द्वारा पूछे गए दोनों प्रश्नों के उत्तर दिए हैं ;-)
user2757729

3

मारने का --no-run-if-emptyविकल्प मत भूलना :)

lsof -ti :8080 | xargs --no-run-if-empty kill -9

इस तरह से मार केवल चलाया जाएगा एक प्रक्रिया है सुनने की, खुद को चेक करने की आवश्यकता नहीं है।



1

lsof -i tcp:8080आउटपुट का उत्पादन करता है, फिर | egrep -v "COMMAND PID USER"हेडर लाइन को ड्राप करता है, फिर | awk '{print $2}'2 के फील्ड को प्रिंट | sort -nकरता है , इसके लिए नंबर तैयार करता है | uniq, जो केवल प्रत्येक यूनिक पीआईडी ​​को एक बार आउटपुट करता है। यह सब एक साथ देता है:

 lsof -i tcp:8080 | egrep -v "COMMAND PID USER" | awk '{print $2}' | sort -n | uniq  

लेकिन, pkill -KILL tomcatया killall -KILL tomcatआसान है।


टॉमकैट प्रक्रिया को "टॉमकैट" नाम नहीं दिया गया है, यही समस्या है। यह सिर्फ एक सामान्य जावा प्रक्रिया है, अगर एक ही समय में अन्य जावा प्रक्रिया चल रही है तो सही प्रक्रिया की पहचान करने के लिए अतिरिक्त काम करना होगा।
टेरी वांग

@ टेरीवांग युप, यही समस्या मेरे साथ भी थी। स्टीलड्राइवर्स का जवाब शानदार काम कर रहा है।
user2757729

0

@Wtinator से एक लाइनर महान है।

मैं इसमें कुछ और स्वाद मिलाऊंगा:

lsof -i tcp:8080 | egrep -v "COMMAND PID USER" | awk '{print $2}' | sort -n | uniq | xargs kill -9

या

kill -9 $(lsof -i tcp:8080 | egrep -v "COMMAND PID USER" | awk '{print $2}' | sort -n | uniq)

ध्यान दें: यह अभी भी बहुत बुनियादी है, आपको वास्तविक वातावरण में इसे और अधिक मजबूत बनाने के लिए अधिक नमक और काली मिर्च को जोड़ने की आवश्यकता हो सकती है।


0

यह वह स्क्रिप्ट है जो मैं थोड़ी सी त्रुटि की जाँच के साथ आया था।

#!/bin/bash

PORT=$1

if ! [[ "$PORT" =~ ^[0-9]+$ ]] ;
then
  printf "error: '$PORT' is not a number.\n\nUsage killport <port number>\n"
  exit 1
fi

PID=$(lsof -ti:$PORT)

if ! [[ "$PID" =~ ^[0-9]+$ ]] ;
then
  printf "no proccess found, nothing to kill.\n"
  exit 0
fi

printf "killing process $PID running on $PORT\n"
kill -9 $PID

0

यहाँ एक साधारण मछली खोल समारोह है

function kill-port
  set pids (lsof -ti tcp:$argv)
  if test $pids
    kill -9 $pids
  else
    echo "No proccesses on that port to kill to see for your self -- lsof -i tcp:$argv"
  end
end

बस इस स्थान पर एक फ़ाइल में इस चूसने वाला छड़ी ~/.config/fish/functions/kill-port.fishऔर जाने के लिए अपने अच्छे। आप इसे पसंद कर सकते हैंkill-port 8000

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.