En informática , el identificador de proceso (también conocido como ID de proceso o PID ) es un número utilizado por la mayoría de los núcleos de los sistemas operativos , como los de Unix , macOS y Windows, para identificar de forma única un proceso activo . Este número se puede utilizar como parámetro en varias llamadas a funciones, lo que permite manipular procesos, como ajustar la prioridad del proceso o eliminarlo por completo.
Tipo Unix
En los sistemas operativos similares a Unix, la fork()
llamada al sistema crea nuevos procesos . El PID se devuelve al proceso padre , lo que le permite hacer referencia al hijo en otras llamadas a funciones. El padre puede, por ejemplo, esperar a que el hijo termine con la waitpid()
función o terminar el proceso con kill()
.
Hay dos tareas con ID de proceso especialmente distinguidos: swapper o sched tiene ID de proceso 0 y es responsable de la paginación , y en realidad es parte del kernel en lugar de un proceso normal en modo de usuario . El ID de proceso 1 suele ser el proceso de inicio principal responsable de iniciar y apagar el sistema. Originalmente, el proceso ID 1 no estaba reservado específicamente para init por ninguna medida técnica: simplemente tenía este ID como una consecuencia natural de ser el primer proceso invocado por el kernel. Los sistemas Unix más recientes suelen tener componentes de kernel adicionales visibles como "procesos", en cuyo caso PID 1 se reserva activamente para el proceso de inicio para mantener la coherencia con los sistemas más antiguos.
Los ID de proceso, en primer lugar, generalmente se asignan de forma secuencial, comenzando en 0 y aumentando hasta un valor máximo que varía de un sistema a otro. Una vez que se alcanza este límite, la asignación se reinicia en 300 y vuelve a aumentar. En macOS y HP-UX , la asignación se reinicia en 100. Sin embargo, para esta pasada y las posteriores, se omiten los PID que aún estén asignados a los procesos. Algunos consideran que se trata de una vulnerabilidad de seguridad potencial, ya que permite extraer información sobre el sistema o pasar mensajes de forma encubierta entre procesos. Como tal, las implementaciones que están particularmente preocupadas por la seguridad pueden elegir un método diferente de asignación de PID. [1] En algunos sistemas, como MPE / iX , se utiliza el PID más bajo disponible, a veces en un esfuerzo por minimizar el número de páginas del núcleo de información de proceso en la memoria.
El ID del proceso actual lo proporciona una getpid()
llamada al sistema o como una variable $$
en el shell. El ID de proceso de un proceso padre se puede obtener mediante una getppid()
llamada al sistema.
En Linux , el ID de proceso máximo viene dado por el pseudoarchivo /proc/sys/kernel/pid_max
. [2]
Pidfile
Algunos procesos, por ejemplo, el reproductor de música moc y el demonio MySQL , escriben su PID en una ubicación de archivo documentada, para permitir que otros procesos lo busquen.
Microsoft Windows
En la familia de sistemas operativos Windows , se puede obtener el ID del proceso actual usando la GetCurrentProcessId()
función de la API de Windows , [3] y el ID de otros procesos usando GetProcessId()
. [4] Internamente, el ID de proceso se denomina ID de cliente y se asigna desde el mismo espacio de nombres que los ID de subprocesos , por lo que estos dos nunca se superponen. El proceso inactivo del sistema recibe el ID de proceso 0. El proceso del sistema recibe el ID de proceso 8 en Windows 2000 y 4 en Windows XP y Windows Server 2003 . [5] En la familia de sistemas operativos Windows NT , los identificadores de procesos y subprocesos son todos múltiplos de 4, pero no forman parte de la especificación. [6] [7]
Ver también
Referencias
- ^ comp.unix.aix Preguntas frecuentes , consultado el 21 de julio de 2008
- ^ "proc - pseudo-sistema de archivos de información de proceso" , Manual del programador de Linux , consultado el 28 de diciembre de 2009
- ^ "Función GetCurrentProcessId" , Centro de desarrollo de Windows , Microsoft , 5 de diciembre de 2018
- ^ "Función GetProcessId" , Centro de desarrollo de Windows , Microsoft , 5 de diciembre de 2018
- ^ Russinovich, Mark ; David A. Solomon (2005), "Capítulo 2: Arquitectura del sistema", Microsoft Windows Internals (4ª ed.), Microsoft Press, p. 76 , ISBN 0-7356-1917-4
- ^ Chen, Raymond (2008-02-28), "¿Por qué los ID de procesos y subprocesos son múltiplos de cuatro?" , Lo viejo y nuevo , Microsoft
- ^ Identificador de manijas verificado
Este artículo se basa en material extraído del Diccionario gratuito de informática en línea antes del 1 de noviembre de 2008 e incorporado bajo los términos de "renovación de licencias" de la GFDL , versión 1.3 o posterior.