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.
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í:
<?php
function f(){
echo "hola";
}
O en JavaScript:
function f(){
console.log("Hola");
}
En Go:
func f(){
fmt.Println("Hola")
}
Pues en bash igualmente puedes escribir la función:
f(){
echo hola
};
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.
Entonces si la hacemos bonita se vería así:
#Inicia la definición
:(){
#Cuerpo de la función
:|:&
};
#Fin de la función
#Llamada de la función
:
Pero para no confundirmos podemos llamar a la función “bomba” y quedaría mejor explicada:
bomba(){
bomba | bomba &
};
bomba
Como vemos, después de la llave ponemos un ; para terminar la definición de la función. Y luego la llamamos.
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.
En este post te quiero compartir mi experiencia tramitando un acta de nacimiento de México…
Hoy te voy a presentar un creador de credenciales que acabo de programar y que…
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
Esta web usa cookies.