So beenden Sie einen Linux-Prozess nach Portnummer
Veröffentlicht: 2022-10-08
Um einen Linux-Prozess zu beenden, benötigen Sie seine ID oder seinen Namen. Wenn Sie nur den verwendeten Port kennen, können Sie ihn trotzdem beenden? Ja, auf verschiedene Weise.
Tötungsprozesse
Gelegentlich kann ein Linux-Prozess nicht mehr reagieren. Es funktioniert möglicherweise nicht mehr richtig oder es funktioniert weiterhin, ignoriert jedoch Anforderungen zum Herunterfahren oder beginnt, Speicher, CPU oder Netzwerkbandbreite zu verschlingen.
Was auch immer Ihre Motive sind, es gibt Möglichkeiten, einen Prozess von der Linux-Befehlszeile aus zu beenden. Die klassische Methode besteht darin, den Kill-Befehl mit der Prozess-ID des Prozesses zu verwenden, den Sie beenden möchten. Der kill Befehl hat einige nahe Verwandte. Der Befehl pkill einen Prozess nach Namen, und killall beendet alle Prozesse, die er finden kann und die einen Teil eines Namens teilen.
Wenn Sie über einen Prozess nur wissen, dass er einen Port auf Ihrem Computer verwendet, gibt es immer noch Möglichkeiten, ihn zu identifizieren und zu beenden. In Netzwerkbegriffen kann „Port“ eine physische Verbindung bedeuten, in die Sie ein Kabel mit einem Stecker am Ende stecken, z. B. ein CAT5- oder 6-Netzwerkkabel, oder es kann einen Softwareport bedeuten.
Ein Softwareport ist der letzte Teil einer Netzwerkverbindung. Die IP-Adresse eines Geräts identifiziert den Computer oder ein anderes Netzwerkgerät. Die Anwendungen im Computer verwenden unterschiedliche Ports. Diese bieten eine weitere Ebene der Granularität. Der Netzwerkverkehr ist mit der IP-Adresse am richtigen Computer angekommen und kann durch die Verwendung der Port-Adressierung an die richtige Anwendung geliefert werden.
Es ist wie Post, die in einem Hotel ankommt, dann sortiert und in die entsprechenden Zimmer geliefert wird. Die IP-Adresse ist wie die Straßenadresse des Hotels, und die Zimmernummern sind wie die Portnummern.
Wenn Sie Netzwerkaktivität auf einem Port sehen und Sie den Prozess, der sie generiert, nicht erkennen oder sein Verhalten problematisch oder verdächtig ist, möchten Sie vielleicht den Prozess beenden. Selbst wenn Sie nur die Portnummer kennen, können Sie den Prozess aufspüren und beenden.
Verbindungen herstellen mit socat
Damit wir einige Verbindungen beenden müssen, verwenden wir socat , um Netzwerkverbindungen mit verschiedenen Protokollen zu erstellen. Sie müssen socat installieren. Verwenden Sie diesen Befehl, um es unter Ubuntu zu installieren:
sudo apt install socat

Verwenden Sie auf Fedora dnf :
sudo dnf install socat

Auf Manjaro müssen Sie Folgendes eingeben:
sudo pacman -S sokat

Die Syntax für socat ist einfach, wenn auch etwas langatmig. Wir müssen die Quell- und Zieladressen angeben. Für jede davon müssen wir das Protokoll, die IP-Adresse und die Portnummer angeben. Wir können STDIN oder STDOUT als Quelle oder Ziel ersetzen.
Dieser Befehl erstellt eine Verbindung zwischen einem TCP-Überwachungs-Socket an Port 7889 an der Loopback-IP-Adresse 127.0.0.1 und STDOUT. Das kaufmännische Und „ & “ führt den Befehl im Hintergrund aus, sodass wir den Zugriff auf die Befehlszeile behalten.
socat tcp-listen:7889,bind=127.0.0.1 stdout &

Wir werden zwei weitere Verbindungen erstellen, damit wir eine kleine Auswahl an Sockets haben, die unterschiedliche Protokolle verwenden. Wir erstellen eine UDP-Verbindung und eine SCTP-Verbindung. Der einzige Teil des Befehls, der sich ändert, ist das Protokoll.
socat udp-listen:7889,bind=127.0.0.1 stdout &
socat sctp-listen:9999,bind=127.0.0.1 stdout &

VERWANDT: Was ist der Unterschied zwischen TCP und UDP?
Töten verwenden
Natürlich können wir den Prozess mit kill beenden, solange wir die ID des Prozesses kennen. Um die PID zu finden, können wir den Befehl lsof verwenden.
Um die Details des Prozesses auf Port 7889 aufzulisten, der das TCP-Protokoll verwendet, verwenden wir die Option -i (Internetadresse) wie folgt.
lsof -i tcp:7889

Die PID dieses Prozesses ist 3141, und wir können fortfahren und das mit kill verwenden:
sudo kill 3141
Etwas Aufwand können wir uns sparen, wenn wir Pipes verwenden. Wenn wir die Ausgabe von lsof an awk und awk , nach Zeilen zu suchen, die den Port enthalten, an dem wir interessiert sind – 7889 – und das zweite Feld dieser Zeile ausgeben, isolieren wir die PID.

lsof -i tcp:7889 | awk '/7889/{print $2}' 
Wir können dann die Ausgabe von awk mit xargs in den Befehl kill leiten. Der xargs -Befehl übernimmt seine über Pipe geleitete Eingabe und übergibt sie als Befehlszeilenparameter an einen anderen Befehl. Wir verwenden xargs mit dem kill -Befehl.
lsof -i tcp:7889 | awk '/7889/{print $2}' | Xargs töten 
Wir bekommen kein visuelles Feedback. In der typischen Linux-Manier sind keine Neuigkeiten gute Neuigkeiten. Wenn Sie überprüfen möchten, ob der Prozess beendet wurde, können Sie erneut lsof verwenden.
lsof -i tcp:7889

Da lsof nichts meldet, wissen wir, dass es keine solche Verbindung gibt.
Wir können einen Prozess mit dem UDP-Protokoll einfach entfernen, indem wir in unserem früheren Befehl „tcp“ durch „udp“ ersetzen.
lsof -i udp:7889 | awk '/7889/{print $2}' | Xargs töten 
lsof erkennt jedoch das SCTP-Protokoll nicht.
lsof -i sctp:7889

Dazu können wir den Befehl ss verwenden. Wir verwenden die Option -S (SCTP), um nach SCTP-Sockets zu suchen, die Option -a (all), um nach allen Arten von Sockets zu suchen (lauschend, akzeptierend, verbunden usw.), und die Option -p (Prozesse). um die Details des Prozesses aufzulisten, der den Socket verwendet.
ss-Sap

Wir können diese Ausgabe mit grep und awk parsen. Wir könnten es auch mit grep und einigen PERL-Regexes parsen, aber auf diese Weise ist es viel einfacher zu verstehen. Wenn Sie dies mehr als ein- oder zweimal verwenden würden, würden Sie wahrscheinlich einen Alias oder eine Shell-Funktion daraus machen.
Wir leiten die Ausgabe von ss an grep weiter und suchen nach unserer Portnummer 7889. Wir leiten die Ausgabe von grep an awk weiter. In awk verwenden wir die Option -F (Trennzeichenfolge), um ein Komma „ , “ als Feldtrennzeichen festzulegen. Wir suchen nach einer Zeichenfolge , die „pid=“ enthält, und drucken das zweite kommagetrennte Feld aus dieser Zeichenfolge.
ss-Sap | grep "7889" | awk -F',' '/pid=/{print $2}' 
Das hat uns den String „pid=2859“ gegeben.
Wir können das wieder in awk , das Feldtrennzeichen auf das Gleichheitszeichen „ = “ setzen und das zweite Feld aus dieser Zeichenfolge drucken, das der Text hinter dem Gleichheitszeichen sein wird.
ss-Sap | grep "7889" | awk -F',' '/pid=/{print $2}' | awk -F'=' '{print $2}' 
Wir haben jetzt die Prozess-ID isoliert. Wir können xargs verwenden, um die PID zum kill als Befehlszeilenparameter zu übergeben.
ss-Sap | grep "7889" | awk -F',' '/pid=/{print $2}' | awk -F'=' '{print $2}' | Xargs töten 
Dadurch wird der Prozess beendet, der den SCTP-Protokoll-Socket auf Port 7889 verwendet hat.
Der Fixierer-Befehl
Der Befehl fuser vereinfacht die Dinge erheblich. Der Nachteil ist, dass es nur mit TCP- und UDP-Sockets funktioniert. Auf der positiven Seite sind dies die beiden häufigsten Arten von Steckdosen, mit denen Sie sich befassen müssen. Auf den von uns überprüften Ubuntu-, Fedora- und Manjaro-Rechnern war der fuser Befehl bereits installiert.
Sie müssen lediglich die Option -k (kill) verwenden und den Port und das Protokoll angeben. Sie können entweder die Option -n (Namespace) verwenden und das Protokoll und den Port angeben oder das „forward slash short format“ verwenden und die Portnummer an erster Stelle setzen.
Fixierer -n TCP 7889
Fixiereinheit 7889/udp

Die Portnummer, das Protokoll und die PID des beendeten Prozesses werden im Terminalfenster ausgegeben.
Versuchen Sie zuerst die Fixierstation
Es wird wahrscheinlich auf dem Computer installiert, an dem Sie arbeiten, und das Protokoll ist wahrscheinlich TCP oder UDP, also besteht eine große Chance, dass der einfachste Weg für Sie funktioniert.

