En este artículo, veremos cómo encontrar un nombre de proceso por su número de identificación de proceso (PID). Antes de sumergirnos en la solución real, hablemos brevemente sobre cómo Linux crea e identifica los procesos.
Cada vez que un usuario o el sistema (Linux) inicia un programa, el núcleo creará un proceso. Un proceso mantiene los detalles de ejecución del programa en la memoria, como sus datos de entrada y salida, variables, etc.
Es importante destacar que, dado que Linux es un sistema operativo multitarea, ejecuta varios programas simultáneamente, y esto significa que cada proceso debe identificarse específicamente.
El núcleo identifica cada proceso mediante un ID de proceso (PID ), cada instancia del proceso debe tener un PID único de otros procesos que se asigna cuando se invoca el proceso, para evitar errores de ejecución.
El sistema de archivos /proc almacena información sobre los procesos que se están ejecutando actualmente en su sistema, contiene directorios para cada proceso.
Use el comando ls para enumerar su contenido, sin embargo, la lista puede ser larga, así que emplee una canalización y la utilidad less para ver el contenido de /proc de una manera más conveniente como se muestra a continuación:
$ ls /proc O $ ls /proc | menosLista /Sistema de archivos de Proc
1 168 2230 25 329 584 7386 83 Driver SchedStat10 169 2234 2503 33 603 74 830 Execdomains SCSI1070 17 2247 2507 34 610 7411 833 FB Self1081 1702 2256 2523 349 611 7423 836 Archivessystemsystemsystemssystems 745 839 FS Softirqs11 173 2266 2551 36 613 746 84 Interrupciones Stat110 1760 2273 26 362 62 75 844 IOMEM SWAPS1188 1763 2278 2688 3642 63 7533 85 IOPORTS SYS12 1769 2282 2694 3643 64 7589 86 86 IRQUd sysvipc1209 1773 2285 2698 38 65 7619 87 kcore thread-self1254 18 2287 2699 39 66 7689 9 claves timer_list13 1847 2295 27 3974 67 7690 94 usuarios clave timer_stats15 1914 23 2702 3976 68 77 977 kmsg tty152 1,917 2,308 28 4,273 6,897 7,725 981 kpagecgroup uptime153 1,918 2,309 280 4,374 69 7,729 987 kpagecount version154 1938 2310 2815 4392 6969 7733 997 kpageflags version_signature155 1956 2311 2817 44 6980 78 ACPI loadavg vmallocinfo156 1981 2315 282 45 7 79 Locks Asound vmstat1565 1986 2316 283 4543 70 790 Buddyinfo MdStat ZoneInfo1567 1988 2317 29 46 71 8 BUSMINFO157 2 2324 2935 461 7102 80 Clops Misc1579 20 2342 2944 4686 72 808 CMD 810 cpuinfo mtrr159 2044 2437 3016 5 7311 815 crypto net1590 21 2442 31 515 7322 82 dispositivos pagetypeinfo16 2167 2443 318 5273 7347 820 diskstats particiones1 60 22 2492 32 5274 7367 823 dma sched_debug
De la captura de pantalla anterior, los directorios numerados almacenan archivos de información sobre los procesos en ejecución, donde cada número corresponde a un PID .
A continuación se muestra la lista de archivos para systemd proceso con PID 1 :
$ ls /proc/1Show SystemD Process PID
ls:no se puede leer el enlace simbólico '/proc/1/cwd':Permiso denegado:no se puede leer el enlace simbólico '/proc/1/root':Permiso denegado:no se puede leer el enlace simbólico '/proc/1 /exe':Permiso denegadoattr coredump_filter gid_map mountinfo oom_score schedstat statusautogroup cpuset io mounts oom_score_adj sessionid syscallauxv cwd limits mountstats pagemap setgroups taskcgroup environ loginuid net personalidad smaps timersclear_refs exe map_files ns projid_map stack uid_mapcmdline fd maps numa_maps fda stat mchancomm>Puede monitorear procesos y sus PID usando comandos tradicionales de Linux como ps, top y comandos de vistazos relativamente nuevos y muchos más como en los ejemplos a continuación:
$ p.aux.Mostrar procesos en ejecución con PIDUSER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMANDroot 1 0.0 0.0 185728 6268 ? Ss 10:15 0:01 /sbin/init splashroot 2 0.0 0.0 0 0 ? S 10:15 0:00 [kthreadd]root 3 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/0]raíz 5 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/0:0H]root 7 0.0 0.0 0 0 ? S 10:15 0:09 [rcu_sched]raíz 8 0.0 0.0 0 0 ? S 10:15 0:00 [rcu_bh]raíz 9 0.0 0.0 0 0 ? S 10:15 0:00 [migración/0]raíz 10 0.0 0.0 0 0 ? S 10:15 0:00 [perro guardián/0]raíz 11 0.0 0.0 0 0 ? S 10:15 0:00 [perro guardián/1]raíz 12 0.0 0.0 0 0 ? S 10:15 0:00 [migración/1]raíz 13 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/1]raíz 15 0.0 0.0 0 0 ? S<10:15 0:00 [ktrabajador/1:0H]raíz 16 0.0 0.0 0 0 ? S 10:15 0:00 [perro guardián/2]raíz 17 0.0 0.0 0 0 ? S 10:15 0:00 [migración/2]raíz 18 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/2]raíz 20 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/2:0H]raíz 21 0.0 0.0 0 0 ? S 10:15 0:00 [perro guardián/3]raíz 22 0.0 0.0 0 0 ? S 10:15 0:00 [migración/3]raíz 23 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/3]raíz 25 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/3:0H]raíz 26 0.0 0.0 0 0 ? S 10:15 0:00 [kdevtmpfs]raíz 27 0.0 0.0 0 0 ? S<10:15 0:00 [redes]raíz 28 0.0 0.0 0 0 ? S<10:15 0:00 [perf]...Supervise los procesos de Linux utilizando el comando superior tradicional.
$ superiorSupervise los procesos de Linux usando miradas , una nueva herramienta de monitoreo de procesos en tiempo real para Linux.
$ miradasObtenga más información sobre cómo instalar Glances en sistemas Linux.
Averigüe el número de PID del proceso
Para averiguar el PID de un proceso, puede usar
pidof
, un comando simple para imprimir el PID de un proceso:$ pidof firefox$ pidof python$ pidof canelaVolviendo a nuestro punto de enfoque, asumiendo que ya conoce el PID de un proceso, puede imprimir su nombre usando el siguiente formulario de comando:
$ ps -p PID -o formatodonde:
-p
especifica el PID-o
format habilita un formato definido por el usuarioAverigüe el nombre del proceso usando el número PID
En esta sección, veremos cómo averiguar el nombre de un proceso utilizando su número PID con la ayuda del formato definido por el usuario, es decir,
comm=
lo que significa nombre de comando, igual que el nombre del proceso.$ ps -p 2523 -o comm=$ ps -p 2295 -o comm=Para obtener más información y opciones de uso, consulta el ps man página.
$ hombre pdSi desea eliminar un proceso usando su número de PID, le sugiero que lea Buscar y eliminar procesos de Linux usando su PID.
Eso es todo por el momento, si conoce alguna otra forma mejor de averiguar el nombre de un proceso usando PID , compártalo con nosotros a través de nuestra sección de comentarios a continuación.