Explicación de :(){ :|:& };: en Linux

Introducción

Hay un “comando” (que no es un comando) de Linux que no es tan peligroso si lo ejecutas en tu PC (con un reinicio basta) pero que en un servidor puede causar una denegación de servicios.

Dicho comando es :(){ :|:& };:

El comando en cuestión, como lo dije arriba, no es un comando. Es la definición de una función junto con la llamada a la misma.

Explicación de :(){ :|:& };: en Linux

Parece una serie de emoticones o símbolos raros, pero no lo son. Es la definición de una función que entiende la terminal con el lenguaje bash. Vamos a explicarlo.

Si vienes de PHP, una función se define así:

O en JavaScript:

En Go:

Pues en bash igualmente puedes escribir la función:

Pero a diferencia de los lenguajes que conocemos, bash permite el símbolo “:” como el nombre de una función. Entonces lo que hace :(){ :|:& };: es crear la función llamada “dos puntos” (o sea, : ).

Dentro de la función, se llama a sí misma y la salida la redirige con | a la función dos puntos, es decir, a sí misma de nuevo. Y el & es para que el proceso se ejecute en segundo plano.

Función legible

Entonces si la hacemos bonita se vería así:

Pero para no confundirmos podemos llamar a la función “bomba” y quedaría mejor explicada:

Como vemos, después de la llave ponemos un ; para terminar la definición de la función. Y luego la llamamos.

¿Qué logramos con esto?

Terminar con los recursos de la computadora en donde se ejecuta. No elimina nada, no roba nada pero deja la computadora inservible hasta el siguiente reinicio.

Ya que cada llamada a la función crea dos nuevos subprocesos y así sucesivamente, como en un árbol binario.

Para evitar esto simplemente no escribimos el comando y ya. O limitamos los procesos que un usuario puede tener.

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

No te pierdas ninguno de mis posts

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.

Dejar un comentario