Comment tuer un processus s'exécutant sur un port particulier sous Linux?


763

J'ai essayé de fermer le tomcat en utilisant le répertoire ./shutdown.shtomcat /bin. Mais a constaté que le serveur n'était pas fermé correctement. Et donc je n'ai pas pu redémarrer
Mon tomcat fonctionne sur le port 8080.

Je veux tuer le processus tomcat en cours d'exécution 8080. Je veux d'abord avoir la liste des processus en cours d'exécution sur un port spécifique (8080) afin de sélectionner le processus à tuer.


Réponses:


939

Cela vous fuser 8080/tcpaffichera le PID du processus lié sur ce port.

Et cela fuser -k 8080/tcptuera ce processus.

Fonctionne uniquement sur Linux. Plus universel est l'utilisation de lsof -i4(ou 6 pour IPv6).


2
Est-ce que cela ferme également une éventuelle prise connectée au 8080?
fer y

9
Il ne ferme pas correctement le port. Le port est mis dans l'état TIME_WAIT après la fin du processus parent. Le système d'exploitation fermera ensuite complètement le port après environ 60 secondes. Cela signifie que vous ne pouvez pas réutiliser le port pendant au moins 60 secondes (sauf si vous donnez l'option de réutilisation au socket).
Mark Lakata

2
Sur Darwin, vous devez utiliser une version différente de fuser. Ne prend qu'un fichier, ne prend pas en charge -k.
ap

3
'fuser -k -n tcp 8080' tuera le processus aussi
Hesham Yassin

7
@dbliss fuser fait partie de psmisc. Si vous obtenez fuser: command not found, installez psmisc. Pour CentOS / RHEL 7, exécutezsudo yum install psmisc
Tom

700

Pour répertorier tout processus écoutant le port 8080:

lsof -i:8080

Pour tuer tout processus écoutant le port 8080:

kill $(lsof -t -i:8080)

ou plus violemment:

kill -9 $(lsof -t -i:8080)

( -9correspond au SIGKILL - terminate immediately/hard killsignal: voir Liste des signaux de destruction et Quel est le but de l'option -9 dans la commande kill?. Si aucun signal n'est spécifié à kill, le signal TERM aka -15ou soft killest envoyé, ce qui parfois n'est pas suffisant pour tuer un processus.).


9
kill: utilisation: kill [-s sigspec | -n signum | -sigspec] pid | jobspec ... ou kill -l [sigspec] Voici ce que
j'obtiens quand j'exécute

2
@SudhirBelagali l'a fait avec un super utilisateursudo
Marcel Djaman

5
A également fonctionné sur mon Mac
asherbar

2
Je voudrais ajouter que parfois vous n'avez pas les autorisations pour voir l'ID du processus, dans ce cas, vous devez le faire sudo lsof -i:8080.
Akavall

1
pourquoi le deuxième conseil est-il plus violent?
Webwoman

281

Utilisez la commande

 sudo netstat -plten |grep java

utilisé grep javacomme tomcatutilisationsjava que leurs processus.

Il affichera la liste des processus avec le numéro de port et l'identifiant du processus

tcp6       0      0 :::8080                 :::*                    LISTEN      
1000       30070621    16085/java

le nombre avant /javaest un identifiant de processus. Utilisez maintenant la killcommande pour tuer le processus

kill -9 16085

-9 implique que le processus sera tué de force.


11
Vous voudrez peut-être ajouter que l'on pourrait avoir besoin de privilèges root pour obtenir les noms de processus via netstat.
Jonas Schäfer

2
@JonasWielicki, vous pouvez voir ceux que vous possédez sans privilèges root.
dbliss

J'avais besoin de privilèges root pour netstat. Existe-t-il un moyen de savoir d’où vient le processus? Pour autant que je sache, j'ai fermé toutes les applications, mais cela peut provenir d'une fenêtre de terminal où j'ai involontairement poussé les processus vers une tâche en arrière-plan. Peut-être que j'aurais dû exécuter la commande de terminal 'ps' pour voir tous les processus en premier ...
JesseBoyd

150

J'ajouterais ce one-liner pour ne tuer que LISTEN sur un port spécifique:

kill -9 $(lsof -t -i:3000 -sTCP:LISTEN)


9
Je pense que cela devrait être la meilleure réponse. Merci @Gal Bracha
Sam Kah Chiin

2
C'est la meilleure solution car elle ne tue pas aussi mon navigateur!
Russo

Meilleure réponse! Simple, concis et fait le travail correctement.
Tsar Bomba le

116

Vous pouvez utiliser la commande lsof. Soit le numéro de port comme ici est 8090

lsof -i:8090

Cette commande renvoie une liste des processus ouverts sur ce port.

Quelque chose comme…

COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
ssh 75782 eoin 5u IPv6 0x01c1c234 0t0 TCP localhost:8090 (LISTEN)

Pour libérer le port, tuez le processus en l'utilisant (l'ID du processus est 75782)…

kill -9 75782

Celui-ci a fonctionné pour moi. voici le lien du post original: lien


1
pour tuer le processus avec force, vous devrez utiliser -9 comme kill -9 75782; car parfois, peu de processus ne tuent pas avec juste tuer
veer7

73

Si vous voulez tuer un processus exécuté sur le numéro de port 8080, vous devez d'abord trouver le numéro d'identification de processus (PID) du port 8080, puis le tuer. Exécutez la commande suivante pour rechercher le numéro de port 8080 PID:

sudo lsof -t -i:8080

Ici,

  • sudo - commande pour demander le privilège administrateur (identifiant utilisateur et mot de passe).
  • lsof - liste de fichiers (également utilisé pour lister les processus associés)
  • -t - affiche uniquement l'ID de processus
  • -i - affiche uniquement le processus lié aux connexions Internet
  • : 8080 - afficher uniquement les processus dans ce numéro de port

Ainsi, vous pouvez maintenant facilement tuer votre PID en utilisant la commande suivante:

sudo kill -9 <PID>

Ici,

  • kill - commande pour tuer le processus
  • -9 - avec force

Vous pouvez utiliser une commande pour tuer un processus sur un port spécifique à l'aide de la commande suivante:

sudo kill -9 $(sudo lsof -t -i:8080)

Pour en savoir plus, vous pouvez voir le lien suivant Comment tuer un processus sur un port spécifique sous Linux


Merci mon pote. sudo kill -9 $(sudo lsof -t -i:8080)travaillé pour moi
Junaid


41

Cela s'imprime pour afficher les identifiants de processus de tout ce qui fonctionne <port_number>:

fuser -n tcp <port_number> 

Il imprime également certaines choses sur stderr, donc:

fuser -n tcp <port_number> 2> /dev/null

Nous pouvons alors fournir ces identifiants de processus à la killcommande:

sudo kill $(fuser -n tcp <port_number> 2> /dev/null)

Vous pouvez également mettre cela dans une fonction si vous le faites souvent:

function killport() {
    sudo kill $(fuser -n tcp $1 2> /dev/null)
}

35

Obtenez le PID de la tâche et tuez-le.

lsof -ti:8080 | xargs kill

Merci d'avoir répondu. Fonctionne très bien sous Mac OS. Tu es le meilleur. Votez juste.
AMIC MING

1
Fonctionne bien aussi avec les plages de ports lsof -ti:8080-8089 | xargs kill.
dvlsg

34

Pour connaître le pid de service exécuté sur un port particulier:

netstat -tulnap | grep :*port_num*

vous obtiendrez la description de ce processus. Utilisez maintenant kill ou kill -9 pid. Facilement tué.

par exemple

netstat -ap | grep :8080

tcp6       0      0 :::8080       :::*    LISTEN      1880/java 

Maintenant:

kill -9 1880

N'oubliez pas d'exécuter toutes les commandes en tant que root


30

Bon mot

kill -9 $(lsof -t -i tcp:8080)

explication ici: utilisez une combinaison de lsof and kill

root@localhost:~# lsof -i tcp:8080
COMMAND   PID USER   FD   TYPE  DEVICE SIZE/OFF NODE NAME
java    23672 sine  238u  IPv6 3028222      0t0  TCP localhost:http-alt (LISTEN)

sélectionner pid et utiliser kill

kill 23672


16

Choisissez le numéro de port et appliquez la commande grep dans netstat comme indiqué ci-dessous

netstat -ap | grep :7070

Sortie console

tcp 0 0 ::: 7070 ::: * ÉCOUTER 3332 / java

Tuez le service en fonction du PID (Process Identification Number)

kill -9 3332

13
  1. lsof -i tcp:8000 Cette commande répertorie les informations sur le processus en cours d'exécution sur le port 8000

  2. kill -9 [PID] Cette commande tue le processus


Je viens de remarquer que j'ai rétrogradé cela par accident il y a quelques semaines, si vous modifiez légèrement votre réponse, je devrais pouvoir la supprimer
Robin-Hoodie

12

Linux : vous pouvez d'abord trouver le PID de cette commande si vous connaissez le port:

netstat -tulpn 

exemple:-

 Local Address  Foreign Address  State    PID/Program name

  :::3000       :::*             LISTEN    15986/node 

Vous prenez ensuite le processus de mise à mort. exécutez la commande suivante:

tuer -9 PID

Exemple: -

tuer -9 15986


10

Linux : vous pouvez utiliser cette commande si vous connaissez le port:

netstat -plten | grep LISTEN | grep 8080

AIX :

netstat -Aan | grep LISTEN | grep 8080

Vous prenez ensuite la première colonne (exemple: f100050000b05bb8) et exécutez la commande suivante:

rmsock f100050000b05bb8 tcpcb

tuer le processus.


10

Vous pouvez connaître la liste de tous les ports fonctionnant dans le système ainsi que ses détails (pid, adresse, etc.):

netstat -tulpn

Vous pouvez connaître les détails d'un numéro de port particulier en fournissant le numéro de port dans la commande suivante:

sudo netstat -lutnp | grep -w '{port_number}'

ex: sudo netstat -lutnp | grep -w '8080' Les détails seront fournis comme ceci:

Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name

si vous voulez tuer un processus en utilisant pid alors :kill -9 {PID}

si vous voulez tuer un processus en utilisant le numéro de port :fuser -n tcp {port_number}

utiliser sudosi vous n'êtes pas en mesure d'accéder à tout.


6

kill -9 `fuser 8080/tcp|xargs -n 1`, cette commande tue également le processus qui écoute sur le port 8080 avec une connexion TCP


4
sudo apt-get install psmisc (or sudo yum install psmisc)
sudo fuser 80/tcp

Résultat: 80 / tcp: 1858 1867 1868 1869 1871

Tuer les processus un par un

tuer -9 1858


3

Je travaille sur un système Yocto Linux qui dispose d'un ensemble limité d'outils Linux disponibles. Je voulais tuer le processus qui utilisait un port particulier (1883).

Tout d'abord, pour voir quels ports nous écoutons, j'ai utilisé la commande suivante:

root@root:~# netstat -lt
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       
tcp        0      0 0.0.0.0:hostmon         0.0.0.0:*               LISTEN      
tcp        0      0 localhost.localdomain:domain 0.0.0.0:*               LISTEN      
tcp        0      0 0.0.0.0:9080            0.0.0.0:*               LISTEN      
tcp        0      0 0.0.0.0:1883            0.0.0.0:*               LISTEN      
tcp        0      0 :::hostmon              :::*                    LISTEN      
tcp        0      0 localhost:domain        :::*                    LISTEN      
tcp        0      0 :::ssh                  :::*                    LISTEN      
tcp        0      0 :::1883                 :::*                    LISTEN      

Ensuite, j'ai trouvé le nom du processus utilisant le port 1883 de la manière suivante:

root@root:~# fuser 1883/tcp
290 
root@root:~# ps | grep 290
  290 mosquitt 25508 S    /usr/sbin/mosquitto -c /etc/mosquitto/mosquitto.conf
12141 root      8444 S    grep 290

Comme nous pouvons le voir ci-dessus, c'est le programme /usr/sbin/mosquitto qui utilise le port 1883.

Enfin, j'ai tué le processus:

root@root:~# systemctl stop mosquitto

J'ai utilisé systemctlparce que dans ce cas c'était un service systemd.


2

Dans mon cas, cent os a un problème dans la réponse suggérée. J'ai donc utilisé la solution suivante:

  ss -tanp | grep 65432 | head -1 | grep -Po "(?<=pid=).*(?=,)" | xargs kill

1

pour s'appuyer sur ce que @ veer7 a dit:

si vous voulez savoir ce qu'il y avait sur le port, faites-le avant de le tuer.

$ sudo netstat -plten |grep java
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN      1000       906726      25296/java      
tcp6       0      0 :::8009                 :::*                    LISTEN      1000       907503      25296/java      
tcp6       0      0 :::8080                 :::*                    LISTEN      1000       907499      25296/java      
$ ps 25296
  PID TTY      STAT   TIME COMMAND
25296 ?        Sl     0:16 /usr/lib/jvm/java-8-openjdk-amd64/bin/java -Dcatalina.base=/hom

Utilisez 'ps' et le numéro du processus rapporté par netstat


1

Autre façon avec Git Bash:

stopProcessByPortNumber() {
port=":${1}"
portStrLine="$(netstat -ano | findstr LISTENING | findstr $port)"
processId="$(grep -oP '(\d+)(?!.*\d)' <<< $portStrLine)"
echo $processId
taskkill -PID $processId -F
}

1
  1. vérifiez d'abord le processus netstat -lt
  2. vérifier l'identifiant du processus fuser <port number>/tcp
  3. tuer le processus en cours d'exécution sur le port kill <process id>

-3

Sous Windows, ce sera le cas netstat -ano | grep "8080"et nous recevrons le message suivantTCP 0.0.0.0:8080 0.0.0.0:0 LISTENING 10076

NOUS pouvons tuer le PID en utilisant taskkill /F /PID 10076


La question demande clairement l'aide de Linux; pas Windows.
babycakes
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.