En la siguiente tabla, se describen los comandos necesarios para gestionar los procesos del sistema.
|
El comando ps permite comprobar el estado de los procesos activos en un sistema y, además, mostrar información técnica sobre los procesos. Estos datos son útiles para tareas administrativas, como la determinación de la manera de definir las prioridades del proceso.
Según las opciones utilizadas, el comando ps proporciona la siguiente información:
Estado actual del proceso
ID de proceso
ID de proceso principal
ID de usuario
Clase de programación
Prioridad
Dirección del proceso
Memoria utilizada
Tiempo de CPU utilizado
En la siguiente lista, se describen algunos campos informados por el comando ps. Los campos que se muestran dependen de la opción seleccionada. Para obtener una descripción de todas las opciones disponibles, consulte la página del comando man ps(1).
El ID de proceso.
El ID de proceso principal.
El uso del procesador para la programación. Este campo no se muestra cuando se utiliza la opción –c.
La clase de programación a la que pertenece el proceso, como tiempo real, sistema o tiempo compartido. Este campo sólo se incluye con la opción –c.
La prioridad de programación del subproceso del núcleo. Los números más altos indican una prioridad superior.
El número de nice del proceso, que contribuye a su prioridad de programación. Aumentar el valor del comando nice de un proceso significa reducir su prioridad.
La dirección de la estructura proc.
El tamaño de la dirección virtual del proceso.
La dirección de un evento o bloqueo para el que el proceso está inactivo.
La hora de inicio del proceso en horas, minutos y segundos.
El terminal desde el cual se inició el proceso o su proceso principal. Un signo de interrogación indica que no existe un terminal de control.
La cantidad total de tiempo de CPU utilizado por el proceso desde que comenzó.
El comando que generó el proceso.
Puede visualizar información detallada sobre los procesos mostrados en el directorio /proc mediante los comandos de proceso. La siguiente tabla muestra los comandos de proceso /proc. El directorio /proc también se conoce como el sistema de archivos de procesos (PROCFS). Las imágenes de los procesos activos se almacenan en PROCFS por número de ID de proceso.
|
Para obtener más información, consulte la página del comando man proc(1).
Las herramientas del proceso son similares a algunas opciones del comando ps, salvo que el resultado proporcionado por estos comandos sea más detallado.
Los comandos de proceso realizan las siguientes acciones:
Muestran más información sobre procesos, como fstat y fcntl, directorios de trabajo y árboles de procesos principales y secundarios.
Proporcionan control sobre los procesos y, de esa manera, permiten a los usuarios detenerlos o reanudarlos.
Puede mostrar información técnica detallada sobre procesos o controlar procesos activos mediante algunos comandos de proceso. La Table 2–2 muestra algunos comandos /proc.
Si un proceso queda atrapado en un bucle infinito o si el proceso tarda demasiado en ejecutarse, es posible que desee detenerlo (terminarlo). Para obtener más información sobre la detención de procesos mediante el comando kill o pkill, consulte Chapter 2, Gestión de procesos del sistema.
El sistema de archivos /proc es una jerarquía de directorios que contiene subdirectorios adicionales para información de estado y funciones de control.
El sistema de archivos /proc también proporciona una utilidad xwatchpoint que se utiliza para reasignar permisos de lectura y escritura en las páginas individuales del espacio de direcciones de un proceso. Esta utilidad no tiene restricciones y admite multiprocesamiento.
Las herramientas de depuración se han modificado para usar la utilidad xwatchpoint, lo que significa que todo el proceso de punto de xwatchpoint es más rápido.
Las siguientes restricciones ya no se aplican al definir xwatchpoints mediante la herramienta de depuración dbx:
Configuración de xwatchpoints en variables locales de la pila debido a ventanas de registro del sistema basado en SPARC.
Configuración de xwatchpoints en procesos multiprocesamiento.
Para obtener más información, consulte las páginas del comando man proc(4) y mdb(1).
$ ps [-efc]
Muestra sólo los procesos que están asociados con la sesión de inicio.
Muestra información completa sobre todos los procesos que se están ejecutando en el sistema.
Muestra información del programador del proceso.
El siguiente ejemplo muestra el resultado del comando ps cuando no se utiliza ninguna opción.
$ ps PID TTY TIME COMD 1664 pts/4 0:06 csh 2081 pts/4 0:00 ps
El siguiente ejemplo muestra la salida del comando ps –ef. Este resultado muestra que el primer proceso que se ejecuta cuando el sistema se inicia es sched (el intercambiador), seguido del proceso init, pageout, etc.
$ ps -ef UID PID PPID C STIME TTY TIME CMD root 0 0 0 18:04:04 ? 0:15 sched root 5 0 0 18:04:03 ? 0:05 zpool-rpool root 1 0 0 18:04:05 ? 0:00 /sbin/init root 2 0 0 18:04:05 ? 0:00 pageout root 3 0 0 18:04:05 ? 2:52 fsflush root 6 0 0 18:04:05 ? 0:02 vmtasks daemon 739 1 0 19:03:58 ? 0:00 /usr/lib/nfs/nfs4cbd root 9 1 0 18:04:06 ? 0:14 /lib/svc/bin/svc.startd root 11 1 0 18:04:06 ? 0:45 /lib/svc/bin/svc.configd daemon 559 1 0 18:04:49 ? 0:00 /usr/sbin/rpcbind netcfg 47 1 0 18:04:19 ? 0:01 /lib/inet/netcfgd dladm 44 1 0 18:04:17 ? 0:00 /sbin/dlmgmtd netadm 51 1 0 18:04:22 ? 0:01 /lib/inet/ipmgmtd root 372 338 0 18:04:43 ? 0:00 /usr/lib/hal/hald-addon-cpufreq root 67 1 0 18:04:30 ? 0:02 /lib/inet/in.mpathd root 141 1 0 18:04:38 ? 0:00 /usr/lib/pfexecd netadm 89 1 0 18:04:31 ? 0:03 /lib/inet/nwamd root 602 1 0 18:04:50 ? 0:02 /usr/lib/inet/inetd start root 131 1 0 18:04:35 ? 0:01 /sbin/dhcpagent daemon 119 1 0 18:04:33 ? 0:00 /lib/crypto/kcfd root 333 1 0 18:04:41 ? 0:07 /usr/lib/hal/hald --daemon=yes root 370 338 0 18:04:43 ? 0:00 /usr/lib/hal/hald-addon-network-discovery root 159 1 0 18:04:39 ? 0:00 /usr/lib/sysevent/syseventd root 236 1 0 18:04:40 ? 0:00 /usr/lib/ldoms/drd root 535 1 0 18:04:46 ? 0:09 /usr/sbin/nscd root 305 1 0 18:04:40 ? 0:00 /usr/lib/zones/zonestatd root 326 1 0 18:04:41 ? 0:03 /usr/lib/devfsadm/devfsadmd root 314 1 0 18:04:40 ? 0:00 /usr/lib/dbus-daemon --system . . .
# pgrep process
El ID de proceso se muestra en la primera columna del resultado.
# /usr/bin/pcommand PID
El comando de proceso que desea ejecutar. La Table 2–2 muestra y describe estos comandos.
Identifica el ID de proceso.
El siguiente ejemplo muestra cómo utilizar los comandos de proceso para visualizar más información sobre un proceso cron.
# pgrep cron Obtains the process ID for the cron process 4780 # pwdx 4780 Displays the current working directory for the cron process 4780: /var/spool/cron/atjobs # ptree 4780 Displays the process tree that contains the cron process 4780 /usr/sbin/cron # pfiles 4780 Displays fstat and fcntl information 4780: /usr/sbin/cron Current rlimit: 256 file descriptors 0: S_IFCHR mode:0666 dev:290,0 ino:6815752 uid:0 gid:3 rdev:13,2 O_RDONLY|O_LARGEFILE /devices/pseudo/mm@0:null 1: S_IFREG mode:0600 dev:32,128 ino:42054 uid:0 gid:0 size:9771 O_WRONLY|O_APPEND|O_CREAT|O_LARGEFILE /var/cron/log 2: S_IFREG mode:0600 dev:32,128 ino:42054 uid:0 gid:0 size:9771 O_WRONLY|O_APPEND|O_CREAT|O_LARGEFILE /var/cron/log 3: S_IFIFO mode:0600 dev:32,128 ino:42049 uid:0 gid:0 size:0 O_RDWR|O_LARGEFILE /etc/cron.d/FIFO 4: S_IFIFO mode:0000 dev:293,0 ino:4630 uid:0 gid:0 size:0 O_RDWR|O_NONBLOCK 5: S_IFIFO mode:0000 dev:293,0 ino:4630 uid:0 gid:0 size:0 O_RDWR
# pgrep process
El ID de proceso se muestra en la primera columna del resultado.
# /usr/bin/pcommand PID
El comando de proceso que desea ejecutar. La Table 2–2 muestra y describe estos comandos.
Identifica el ID de proceso.
# ps -ef | grep PID
Es posible que desee detener (terminar) un proceso que está en un bucle infinito o detener un trabajo grande antes de finalizarlo. Puede terminar cualquier proceso propio. El administrador del sistema puede terminar cualquier proceso del sistema, excepto los procesos que tienen el ID de 0, 1, 2, 3 y 4. Es muy probable que al terminar estos procesos, se produzca un fallo en el sistema.
Para obtener más información, consulte las páginas del comando man pgrep(1), pkill(1) y kill(1).
$ pgrep process
Por ejemplo:
$ pgrep netscape 587 566
El ID de proceso se muestra en el resultado.
Para mostrar todos los procesos de usuario:
# ps -fu user
Para localizar un proceso determinado de un usuario:
# ps -fu user | grep process
$ pkill [signal] PID
Cuando no se incluye ninguna señal en la sintaxis de la línea de comandos pkill, la señal predeterminada que se utiliza es -15 (SIGKILL). Mediante la señal -9 (SIGTERM) con el comando pkill, se garantiza que el proceso terminará de inmediato. Sin embargo, la señal –9 no debe utilizarse para terminar ciertos procesos, como un proceso de base de datos o un proceso de servidor LDAP, ya que se pueden perder datos.
El nombre del proceso que se detendrá.
$ pgrep process
El proceso terminado ya no se debería mostrar en el resultado del comando pgrep.
# ps -fu user
donde user es el propietario del proceso.
El ID de proceso se muestra en la primera columna del resultado.
# kill [signal-number] PID
Cuando no se incluye ninguna señal en la sintaxis de la línea de comandos kill, la señal predeterminada que se utiliza es -15 (SIGKILL). Mediante la señal -9 (SIGTERM) con el comando kill, se garantiza que el proceso terminará de inmediato. Sin embargo, la señal –9 no debe utilizarse para terminar ciertos procesos, como un proceso de base de datos o un proceso de servidor LDAP, ya que se pueden perder datos.
Es el ID del proceso que desea terminar.
$ ps
El proceso terminado ya no se debería mostrar en la salida del comando ps.
El comando pargs y el comando preap mejoran la depuración de procesos. El comando pargs imprime los argumentos y las variables de entorno asociados con un proceso en ejecución o un archivo del núcleo central. El comando preap elimina procesos inactivos (zombie). Un proceso zombie todavía no ha tenido el estado de salida reclamado por el proceso principal. En general, estos procesos son inofensivos, pero pueden consumir los recursos del sistema si son numerosos. Puede utilizar los comandos pargs y preap a fin de examinar los procesos para los que cuenta con privilegios. Al convertirse en administrador, puede examinar cualquier proceso.
Para obtener información sobre el uso del comando preap, consulte la página del comando man preap(1). Para obtener información sobre el uso del comando pargs, consulte la página del comando man pargs(1). Además, consulte la página del comando man proc(1).
Ejemplo 2-3 Depuración de un proceso (pargs)El comando pargs resuelve el antiguo problema de no poder mostrar todos los argumentos que se transfieren a un proceso con el comando ps. El siguiente ejemplo muestra cómo utilizar el comando pargs en combinación con el comando pgrep para mostrar todos los argumentos que se transfieren a un proceso.
# pargs `pgrep ttymon` 579: /usr/lib/saf/ttymon -g -h -p system-name console login: -T sun -d /dev/console -l argv[0]: /usr/lib/saf/ttymon argv[1]: -g argv[2]: -h argv[3]: -p argv[4]: system-name console login: argv[5]: -T argv[6]: sun argv[7]: -d argv[8]: /dev/console argv[9]: -l argv[10]: console argv[11]: -m argv[12]: ldterm,ttcompat 548: /usr/lib/saf/ttymon argv[0]: /usr/lib/saf/ttymon
El siguiente ejemplo muestra cómo utilizar el comando pargs –e para mostrar las variables de entorno asociadas con un proceso.
$ pargs -e 6763 6763: tcsh envp[0]: DISPLAY=:0.0