Todo sobre los demonios en Linux

SDado que el sistema operativo Linux se caracteriza como un sistema operativo multitarea, un demonio es, por definición, un programa que se ejecuta continuamente como un proceso en segundo plano. En resumen, la ejecución de este proceso no depende de la interacción del sistema de un usuario activo. Un usuario normal del sistema no puede controlar la ejecución periódica de un proceso demonio.

La convención de nomenclatura que define la mayoría de los procesos de demonio es el 'sufijo' de una letra D. Esta convención de nomenclatura hace posible diferenciar entre procesos normales del sistema y procesos impulsados ​​por demonios. Por ejemplo, sshd es un proceso demonio responsable de la gestión de entradas SSH conexiones. Otro ejemplo de proceso de demonio es syslogd. Es responsable de la función de registro del sistema Linux.

En un entorno Linux, el lanzamiento de los demonios se realiza en el momento del arranque. Dado que el sistema Linux es un clon perfecto de Unix, un proceso de inicio califica como el proceso padre de un demonio. Para iniciar y detener demonios en su sistema operativo Linux, primero debe acceder al /etc/init.d directorio de scripts en su sistema operativo.

Índice

Funciones de demonios comunes

  • Permite que su sistema responda correctamente a las solicitudes de la red asociando cada solicitud con un puerto de red compatible. Un puerto de red típico manejado por demonios es el puerto 80.
  • Los demonios permiten ejecutar o ejecutar tareas programadas del sistema. El demonio responsable de esta tarea específica se llama cron. Creará un trabajo cron que se encargará de la ejecución periódica de sus tareas programadas.
  • Los demonios también ofrecen una contribución invaluable para monitorear el desempeño de su sistema. Por ejemplo, pueden verificar la matriz RAID o el estado del disco duro.

Demonios útiles de servicios de Linux

  • amd: Demonio de montaje automático
  • anacron: Ejecución en tiempo de arranque de tareas cron retrasadas
  • apmd: Demonio de administración de energía avanzada
  • atd: Utiliza la funcionalidad de la herramienta para ejecutar trabajos en cola
  • autofs: trabaja de la mano con el demonio del montador automático para facilitar el montaje y desmontaje de los dispositivos del sistema bajo demanda
  • crond: un demonio que maneja la programación de tareas
  • tazasd: un demonio que maneja la impresión CUPS
  • DHCP: demonio para el servidor de protocolo Bootstrap de Internet y el protocolo de configuración dinámica de host.
  • cerrado: Demonio de enrutamiento responsable de múltiples protocolos de enrutamiento. Sustituye enrutado y egpup
  • httpd: un demonio que se ocupa de servidores web como Apache
  • inetd: demonio asociado con Internet Superserver
  • imapd: demonio para el servidor IMAP
  • lpd: Demonio de impresora de línea
  • memcached: demonio de almacenamiento en caché de objetos que se distribuye en memoria
  • mountd: montar demonio
  • MySQL: demonio para el servidor de base de datos MySQL
  • llamado: demonio para servidor DNS
  • nfsd: Demonio de intercambio de archivos de red
  • nfslock: Dado que nfsd está asociado con servicios de bloqueo de archivos, este demonio puede iniciar y detener estos servicios.
  • nmbd: demonio para el bloque de mensajes de red
  • ntpd: demonio para el servicio Network Time Protocol
  • sufijo: un demonio que sirve como agente de transporte de correo. Es una alternativa a sendmail.
  • Postgresql: demonio para el servidor de base de datos de Postgres
  • enrutado: demonio para administrar tablas de enrutamiento
  • rpcbind: demonio asociado con el enlace de llamada a procedimiento remoto
  • enviar correo: un demonio que sirve como agente de transferencia de correo
  • smbd: demonio para el servidor Samba SMB
  • smtpd: demonio para el protocolo simple de transferencia de correo
  • snmpd: demonio para el protocolo simple de administración de redes
  • calamar: demonio asociado con un servidor proxy para el almacenamiento en caché de páginas web
  • sshd: demonio asociado con Secure Shell Server
  • sincronizado: demonio para sincronizar la memoria del sistema con los archivos del sistema
  • Syslog: un demonio que realiza el registro del sistema
  • tcpd: este contenedor de servicio de demonio ejecuta protocolos de restricción de acceso relacionados con los servicios de demonio basados ​​en inetd. Implementa estas restricciones a través de hosts.allow y hosts.deny.
  • Telnetd: demonio para el servidor telnet
  • vsftpd: demonio para un protocolo de transferencia de archivos muy seguro
  • webmin: demonio para el servidor de administración basado en web
  • xinetd: demonio asociado con Enhanced Internet Supervisor
  • xntd: demonio para el servidor de tiempo de red

Ya sea que sea un usuario principiante, intermedio o experto en el mundo del sistema operativo Linux, nunca dejará de familiarizarse con cualquiera de los demonios mencionados anteriormente a medida que avanza en sus habilidades y experiencia dentro de este entorno de sistema operativo.

Iniciar / detener / reiniciar demonios: el enfoque basado en terminales

Ahora que tiene una lista de demonios de Linux útiles para memorizar y explorar, lo primero que necesita saber es cómo iniciar, detener o reiniciar estos demonios. Con su terminal Linux en ejecución, considere las siguientes reglas de sintaxis para iniciar, detener y reiniciar un demonio en su sistema operativo Linux.

service preferred-daemon-name start

service preferred-daemon-name stop 

service preferred-daemon-name restart

Reemplace la nombre-demonio-preferido argumento de sintaxis con el nombre del demonio del sistema Linux de su elección. Puede elegir uno de la lista de demonios resaltada anteriormente siempre que esté activo o ya esté definido en su sistema Linux. Por ejemplo, podemos implementar el uso práctico de la sintaxis anterior intentando iniciar, detener y reiniciar un demonio. Navega al /etc/init.d directorio en su terminal para la lista de demonios disponibles en su sistema Linux.

enumerar demonios activos en su sistema Linux.png
enumerar demonios activos en su sistema Linux.png

cómo iniciar, detener y reiniciar un servicio demonio en su sistema Linux.png
cómo iniciar, detener y reiniciar un servicio demonio en su sistema Linux.png

Listado de los demonios de sus sistemas Linux

Una forma más eficaz de detectar los demonios disponibles en su sistema Linux en lugar de navegar al /etc/init.d directorio es listar todos los demonios activos e inactivos definidos de ese directorio con un solo comando. El siguiente comando es eficaz para lograr este objetivo.

$ service –status-all

enumerando todos los demonios en su sistema operativo Linux.png
enumerando todos los demonios en su sistema operativo Linux.png

El positivo reforzado [+] y negativo [-] Los signos que preceden a los nombres de demonios enumerados implican que están activos o inactivos, respectivamente.

Trabajar con demonios definidos por el usuario

Deben seguirse reglas o protocolos específicos para crear e implementar con éxito un demonio definido por el usuario. Estos protocolos le ayudan a comprender completamente la ejecución de demonios en cualquier entorno Linux. Los demonios también son lo suficientemente flexibles como para interactuar con los módulos del kernel a través de llamadas al sistema. Esta extensión de funcionalidad de demonio admite su interacción con dispositivos de hardware como PDA (asistentes digitales personales), impresoras y placas controladoras externas viables. Los componentes básicos de los demonios también contribuyen al poder característico y la flexibilidad del sistema operativo Linux.

Sander Marechal demuestra y documenta cuidadosamente una implementación de demonio identificable usando Python. Esté dispuesto a seguir el orden de ejecución al crear este demonio. En primer lugar, su sistema Linux necesita la instalación de paquetes de Python para desarrollar demonios con éxito. Para instalar Python, puede usar el siguiente comando.

$ sudo apt install python3-pip python3-dev

El enlace al código del demonio Python creado por Sander Marechal también ofrece una versión refinada del código Python 3. Sería útil si considerara implementarlo para comprender mejor cómo funcionan los demonios.

Si no está seguro de tener instalado Python, ejecute el siguiente comando en su terminal de Linux.

$ python3 --version

El propósito de cualquier demonio

Dado que un solo demonio está dedicado a manejar una tarea específica, debería ejecutarla a la perfección. La tarea en cuestión puede ser tan simple como crear un informe y enviarlo a un administrador a través de sendmail o tan compleja como administrar varios dominios vinculados a varios buzones de correo. En algún momento, el demonio que va a crear tendrá que comunicarse con otros demonios existentes.

interacción de usuario a demonio

Se desaconseja que el usuario del sistema y el demonio creado se comuniquen directamente. Si es necesario para el demonio, crea para comunicarse con un usuario del sistema. Esta comunicación se puede facilitar a través de algo así como una interfaz gráfica de usuario. Esta plataforma de comunicación puede tener la complejidad GTK + GUI o la simplicidad del conjunto de señales.

Creando tu demonio

Numerosos enfoques apoyan la creación de demonios. Por ejemplo, puede usar su interfaz de línea de comandos para demonizar una secuencia de comandos de Python de la siguiente manera:

$ python my_python_script.py &

Puede guardar el código del demonio Python3 creado por Sander Marechal en un archivo Python y demonizarlo con el comando anterior. Si bien el comando de terminal anterior creará fácilmente un demonio para usted, tendrá que lidiar con desafíos como salidas de terminal impredecibles. Estos desafíos dependen de qué tan bien haya refactorizado el código del demonio de Python. Además, el enfoque anterior no admite la asignación de archivos de bloqueo PID a demonios específicos. Hace que sea imposible controlar cualquier demonio ya que la mayoría de ellos se ejecutarán instantáneamente. Por otro lado, si solo necesita un demonio simple, el enfoque mencionado anteriormente le dará los resultados deseados del demonio.

Estructura básica del demonio

Antes de que un demonio ejecute o realice una función prevista, tendrá que considerar algunas reglas preconcebidas que conducen a su ejecución. Puede pensar en estas reglas como tareas domésticas de bajo nivel que conducen a su tarea real. Estas reglas se pueden dividir en los siguientes pasos.

  • La creación de una bifurcación a partir de un proceso principal se lleva a cabo primero.
  • A continuación, se cambia umask (máscara de modo de archivo)
  • Los registros se abren para escribir
  • Se crea un SID (ID de sesión) único
  • La ejecución cambia del directorio de trabajo actual a una ubicación secundaria para preservar la integridad del archivo
  • Los descriptores de archivo estándar están cerrados
  • Ejecución de código de demonio dirigido

Puede encontrar más información sobre implementaciones de ejemplo de demonios en GitHub.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

Subir