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.


Estoy disponible para trabajar en tu proyecto o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.
Si el post fue de tu agrado muestra tu apoyo compartiéndolo, suscribiéndote al blog, siguiéndome o realizando una donación.

Suscribir por correo

Ingresa tu correo y recibirás mis últimas entradas sobre programación, open source, bases de datos y todo lo relacionado con informática

Únete a otros 1,347 suscriptores


parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

0 Comentarios

Deja un comentario

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

A %d blogueros les gusta esto: