Cómo matar procesos desde la terminal de Linux
Conclusiones clave
- Matar un proceso simplemente significa obligarlo a cerrar, y puede ser necesario cuando un proceso no responde o se comporta mal.
- Linux y macOS tienen comandos como kill, pkill y killall que le permiten finalizar procesos ya sea por su PID o por su nombre.
- Es importante tener cuidado al finalizar procesos y asegurarse de finalizar el correcto para evitar consecuencias no deseadas.
A veces, matar un proceso es la única forma de deshacerse de él. A pesar del duro nombre, «matar» un proceso simplemente significa «forzarlo a cerrar». Aquí se explica cómo hacerlo desde la línea de comandos de Linux o macOS.
¿Qué es un proceso?
La ejecución de programas como su navegador web, los procesos en segundo plano asociados con su entorno de escritorio y los servicios del sistema Linux son todos procesos.
Puede agrupar los procesos en dos grupos:
- Los procesos en primer plano son aquellos que han sido iniciados o lanzados por un usuario. Pueden estar en una ventana de terminal o pueden ser una aplicación gráfica.
- Los procesos en segundo plano son todos los procesos que se inician automáticamente y no tienen ninguna interacción con los usuarios. No esperan aportes de los usuarios ni les presentan resultados o resultados. Los procesos en segundo plano son cosas como servicios y demonios.
Si los procesos de primer plano son el personal del teatro y los actores, los procesos de fondo son el equipo detrás del escenario «detrás de escena».
Cuando los procesos se comportan mal o funcionan mal, pueden acaparar demasiado tiempo de CPU, consumir RAM o entrar en un bucle computacional estrecho y dejar de responder. Las aplicaciones gráficas pueden negarse a responder a los clics del mouse. Es posible que las aplicaciones de terminal nunca le devuelvan al símbolo del sistema.
¿Qué hace matar un proceso?
«Matar» un proceso simplemente significa «forzar el proceso a cerrar». Esto puede ser necesario si el proceso se niega a responder.
Linux proporciona los comandos kill
, pkill
y killall
para permitirle hacer precisamente eso. Estos comandos se pueden utilizar con cualquier tipo de proceso, gráfico o de línea de comando, en primer plano o en segundo plano.
El comando matar
Para utilizar kill
, debe conocer el ID del proceso (PID) del proceso que desea finalizar. El ps
comando se puede utilizar para encontrar el PID de un proceso.
Para realizar ps
una búsqueda en todos los procesos, utilice la -e
opción (todos los procesos). Es aconsejable canalizar la salida less
, habrá bastante. Escriba ps
, un espacio, -e
, un espacio |
(un carácter de barra vertical), otro espacio y luego escriba less
. Presione Enter para ejecutar el comando.
ps -e | less
Esto le dará una lista de procesos similar a la siguiente captura de pantalla. Puede buscar hacia adelante less
usando la /
tecla y puede buscar hacia atrás usando la ?
tecla.
Para centrarse en el proceso que le interesa, canalice la salida ps
y grep
especifique el nombre (o parte del nombre) del proceso.
ps -e | grep shutter
Una vez que haya localizado el PID del proceso que desea finalizar, páselo al kill
comando como parámetro. Para finalizar el shutter
proceso identificado por el comando anterior, use este comando:
kill 2099
El kill
comando es un asesino silencioso: no te da ninguna información si tuvo éxito.
También funciona igual para finalizar procesos en macOS .
El comando pkill
El pkill
comando le permite eliminar un proceso (o procesos) por su nombre. No es necesario identificar el proceso por PID. Para utilizarlo pkill
, proporcione un término de búsqueda que pkill
se utilice para comparar con la lista de procesos en ejecución. Los procesos de comparación finalizan. Por lo tanto, debe estar seguro de haber escrito correctamente el término de búsqueda.
Como red de seguridad, puede usar el pgrep
comando antes de usarlo pkill
. El pgrep
comando también acepta un término de búsqueda. Enumerará el PID de cada proceso que coincida con el término de búsqueda. Esto es seguro porque pgrep
no emitirá ninguna señal de finalización para los procesos y, si escribe mal el término de búsqueda, no finalizará otro proceso por error. Puedes asegurarte de haber pensado correctamente el término de búsqueda antes de pasarlo a pkill
. Ambos pkill
y pgrep
tratan el término de búsqueda de la misma manera. Su tratamiento es tan similar que comparten la misma página de manual .
Supongamos que hay un proceso con “subq” en su nombre. Usaremos el ps -u dave | grep
comando para echar un vistazo detrás de la cortina. Puede ver que «subq» coincidirá con ese proceso y solo con ese proceso. Eso fue solo para que puedas ver el nombre completo del proceso.
ps -u dave | grep subq
Supongamos que nuestro usuario no ha hecho eso; lo único que saben es que el nombre del proceso contiene la subcadena “subq”. Lo utilizan pgrep
para comprobar que solo hay una coincidencia con el término de búsqueda. Luego usan ese término de búsqueda con pkill
.
pgrep subq
pkill subq
Puedes usarlo pkill
para matar varios procesos a la vez. Aquí el usuario corre pgrep
para comprobar cuántos procesos ha iniciado Chrome. Solían pkill
matarlos a todos. Luego verifican pgrep
que hayan sido eliminados todos.
pgrep chrome
pkill chrome
pgrep chrome
Si se están ejecutando varios procesos con el mismo nombre, pero no desea eliminarlos todos, puede utilizar pgrep
la -f
opción (línea de comando) para identificar qué proceso es cuál. Un ejemplo simple serían dos ping
procesos. Quieres matar a uno de ellos pero no al otro. Puede utilizar sus líneas de comando para distinguirlos. Tenga en cuenta el uso de comillas para ajustar el parámetro de la línea de comando.
pgrep -f "ping 192.168.4.22"
pkill -f "ping 192.168.4.22"
El comando matar a todos
Advertencia : en los sistemas operativos Solaris y OpenIndiana, el killall
comando eliminará todos los procesos que le pertenecen. ¡Si eres root o si lo has emitido, sudo killall
reiniciarás tu computadora! Durante la investigación para este artículo, este comportamiento se confirmó con la última versión de OpenIndiana Hipster 2018.10.
El killall
comando funciona de manera similar al pkill
comando pero con una diferencia específica. En lugar de pasar un término de búsqueda al comando, debe proporcionar el nombre exacto del proceso.
No puede proporcionar una coincidencia parcial con el nombre de un proceso; debe proporcionar el nombre completo del proceso, como se muestra:
killall shutt
killall shutter
La -y
opción (más joven que) le permite finalizar procesos que se han estado ejecutando durante menos de un período específico. El período se da en números seguidos de una de estas unidades:
- s (segundos)
- m (minutos)
- horas (horas)
- d (días)
- w (semanas)
- M (meses, nota, “M” mayúscula)
- años (años)
Para finalizar un proceso llamado ana
que acaba de iniciarse y dejar cualquier instancia anterior en ana
ejecución, puede usar los siguientes parámetros con killall
, si hubiera reaccionado en dos minutos:
killall -y 2m ana
La -o
opción (más antiguo que) le permite finalizar procesos que se han estado ejecutando durante más tiempo que un período específico. Este comando eliminará todas ssh
las conexiones que hayan estado ejecutándose durante más de un día:
killall -o 1d sshd
¿Puedes matar cualquier proceso?
Estos comandos le permitirán identificar y finalizar correctamente los procesos erróneos con precisión y seguridad. Sin embargo, puede ser demasiado feliz y es completamente posible finalizar un proceso que no debería.
Sea siempre cauteloso. Primero, asegúrese de que el proceso que está a punto de finalizar sea realmente el que desea. En segundo lugar, vuelva a verificar: tenga cuidado y asegúrese de que el proceso objetivo sea el que desea finalizar. Continúe con la finalización del proceso una vez que esté satisfecho.
Si finaliza un proceso accidentalmente, no es el fin del mundo. El resultado más probable es que algo falla y tengas que reiniciar tu PC, o puedes perder el trabajo que has realizado en el programa asociado con el proceso que terminaste.
Comandos de Linux |
|
Archivos |
tar · pv · cat · tac · chmod · grep · diff · sed · ar · man · pushd · popd · fsck · testdisk · seq · fd · pandoc · cd · $PATH · awk · join · jq · fold · uniq · journalctl · tail · stat · ls · fstab · echo · less · chgrp · chown · rev · look · strings · tipo · renombrar · zip · descomprimir · montar · desmontar · instalar · fdisk · mkfs · rm · rmdir · rsync · df · gpg · vi · nano · mkdir · du · ln · parche · convertir · rclone · triturar · srm · scp · gzip · chattr · cortar · buscar · umask · wc · tr |
Procesos |
alias · pantalla · arriba · nice · renice · progreso · strace · systemd · tmux · chsh · historial · at · lote · gratis · which · dmesg · chfn · usermod · ps · chroot · xargs · tty · pinky · lsof · vmstat · tiempo de espera · pared · sí · matar · dormir · sudo · su · tiempo · agregar grupo · usermod · grupos · lshw · apagar · reiniciar · detener · apagar · contraseña · lscpu · crontab · fecha · bg · fg · pidof · nohup · pmap |
Redes |
netstat · ping · traceroute · ip · ss · whois · fail2ban · bmon · dig · finger · nmap · ftp · curl · wget · who · whoami · w · iptables · ssh-keygen · ufw · arping · firewalld |
Deja una respuesta