Todo el mundo conoce VMWare o VirtualBox, es lo más común para montar máquinas virtuales, y, hablando más concretamente, montar un kali. Sin embargo, aunque ambas opciones son buenas, no son las únicas. En este post vamos a ver como instalar y administrar Kali en Docker y algunas razones de porque últimamente me he decantado por esta opción en vez de usar una máquina virtual.
- Descarga e Instalación de Kali y Docker Desktop
- WSL2 vs Docker basado en WSL2
- Tunelizar todo el tráfico del contenedor por Burp Suite
- Comandos para administrar el contenedor
- Referencias
Descarga e Instalación de Kali y Docker Desktop
Lo primero que tenemos que hacer es descargar e instalar Docker Desktop en nuestro equipo:


La instalación es relativamente sencilla, simplemente hay que seguir el propio asistente. Si acaso mencionaría que en uno de los pasos preguntará si se quiere usar HyperV o WSL. La opción que recomendará el propio asistente es WSL, así que la mantenemos.


Una vez se haya instalado, tocará reiniciar el equipo y ya tendremos Docker instalado:


Os recomiendo que tengáis instalado Windows Terminal, ya que dejando a un lado las opciones de personalización que tiene, la estética es mucho más agradable que el de la CMD o PowerShell. En Windows 11 está por defecto, en Windows 10 tendremos que instalarlo.
Una vez tengamos todo esto es hora de ir con la instalación de Kali. Lo primero de todo es descargar la imagen, aquí tenemos varias posibilidades y que podemos ver con más detalles en el siguiente enlace:
Las dos imágenes principales son:
- kalilinux/kali-rolling (actualizada semanalmente)
- kalilinux/kali-last-release (actualizada trimestralmente)
En este caso vamos a instalar la primera de ellas. Para instalar una imagen de Docker es tan sencillo como usar el propio comando que se nos indica en sus respectivos enlaces de Docker Hub:


- docker pull kalilinux/kali-rolling


Después de descargar la imagen ya la podremos visualizar en Docker Desktop:


Una vez tenemos la imagen de Kali descargada, la idea antes de crear el contenedor, es limitar los recursos que usará, ya que si no los limitamos, se pondrá a usar casi todos los recursos del PC. Por ello, debemos de crear el archivo .wslconfig en la siguiente ruta:
- C:\Users\<Usuario>\.wslconfig
- C:\Usuarios\<Usuario>\.wslconfig
El contenido del mismo deberá de ser el siguiente:
# Settings apply across all Linux distros running on WSL 2
[wsl2]
# Limits VM memory to use no more than 4 GB, this can be set as whole numbers using GB or MB
memory=4GB
# Sets the VM to use two virtual processors
processors=2
Estas no son las únicas opciones que se pueden configurar en este archivo, pero sí que son las mínimas para limitar los recursos, que es lo que nos interesa. Para más opciones puedes mirar la propia documentación de Microsoft:
Una vez creado el archivo .wslconfig lo que haremos antes de crear el contenedor será reiniciar el WSL, para ello, cerramos el Docker Desktop y ejecutamos en una CMD o PowerShell lo siguiente:


Todo esto simplemente para que se apliquen los cambios del .wslconfig. Una vez hecho esto, abriremos Docker Desktop de nuevo y crearemos el contenedor, que es básicamente la “VM” de kali. Para crear el contenedor, ejecutamos el siguiente comando:
- docker run -ti -h deephacking –name deephacking kalilinux/kali-rolling
- docker run: es el comando principal de Docker para ejecutar un contenedor.
- -ti: son las opciones que se pasan al comando run. El indicador -t asigna un pseudo TTY (terminal) al contenedor, y el indicador -i permite la interacción con la terminal del contenedor.
- -h deephacking: establece el nombre de host del contenedor como “deephacking”.
- –name deephacking: asigna un nombre al contenedor, en este caso “deephacking”.
- kalilinux/kali-rolling: es el nombre de la imagen de Docker que se utilizará para crear el contenedor.


Y en un instante, ya estaremos dentro de nuestro kali.
Llegados a este punto, realmente ya tenemos el Kali instalado, lo único es que está casi vacío. Desde la documentación oficial se nos recomienda instalar kali-linux-headless que corresponde a la instalación por defecto sin GUI. Otros paquetes disponibles lo podemos ver en Kali Linux Metapackages. En cualquier caso, procedemos a instalar el paquete que nos recomiendan:
- apt update && apt -y install kali-linux-headless


A lo largo de la instalación de los paquetes, se nos preguntará varias pautas de configuración, yo personalmente lo configuré de la siguiente manera:










Con la instalación finalizada ya tendremos un kali totalmente funcional y con varias herramientas preinstaladas:


WSL2 vs Docker basado en WSL2
Llegados a este punto puede surgir la duda de: ¿Para qué voy a instalar Kali usando Docker, si me puedo ir a la tienda de Microsoft, descargarlo directamente y usarlo con WSL2?


Entre estas dos opciones hay una serie de diferencias que, al menos a mí, me hacen decantarme por la opción de Docker. También por supuesto, todo dependerá de las necesidades de cada uno e incluso los gustos.
En cualquier caso, algunas diferencias entre estas dos opciones son las siguientes:
- Usando WSL2 directamente tienes acceso a los recursos de Windows de manera más directa. Esto puede ser útil si lo que te interesa es interactuar con herramientas o archivos concretos de Windows. Por otro lado, usando Docker estás usando un entorno aislado.
- En WSL2, como los archivos y datos se almacenan directamente en el sistema de archivos de Windows, los tendrás disponibles incluso después de cerrar el Kali. De forma contraria, en Docker, los datos se almacenan dentro del contenedor. Lo dicho, un sistema aislado.
- Usando Docker tendrás todas las ventajas del mismo en cuanto a construir, compartir y administrar contenedores se refiere.
- Docker utiliza una imagen de Linux dentro del contenedor, lo que quizás puede llegar a dar mayor compatibilidad con las aplicaciones y herramientas.
Además, hablando un poco más personalmente, WSL2 a mí me ha dado más problemas de los que me ha dado Docker hasta ahora. Con WSL2 he tenido más de una vez algún problema de DNS mientras que con Docker no. Y oye, también me gusta por simple organización que ambos sistemas estén aislados y no en el mismo sistema de archivos.
En conclusión, ambas opciones tienen sus diferencias y son buenas. Simplemente, al menos por ahora y por propio gusto, me quedo con Docker. Aun así, en el siguiente enlace podéis ver más información de este debate:
Además, a favor de estas dos opciones en lugar de usar una VM, es la capacidad de disco. No me tengo que preocupar por cuantos GB de disco duro tiene, ya que tanto WSL como Docker usan la capacidad del sistema anfitrión en función de sus necesidades.
Tunelizar todo el tráfico del contenedor por Burp Suite
Una de las características que me ha gustado de Docker y que desconocía era la facilidad con la que puedes tunelizar o no el tráfico a través de un Proxy. Por ejemplo, yo uso Burp Suite en Windows debido a que tiene mejor rendimiento que en Linux virtualizado por los recursos disponibles del sistema anfitrión. Por tanto, de forma muy sencilla es posible tunelizar todo el tráfico del contenedor a través de Burp Suite, situado en la máquina anfitrión Windows.
Lo primero de todo es dirigirse a:
- Configuración –> Resources –> Proxies




En este apartado, configuramos el proxy de Burp Suite para que todo el tráfico pase por él:


Ahora, lo que tendremos que hacer es instalar el certificado de Burp Suite en el Kali Linux para las peticiones HTTPS, ya que sino, cuando tratemos con webs que usen este protocolo, saldrá que estamos usando un certificado inseguro:


Para solucionar esto, lo primero de todo es descargar el certificado de Burp Suite, que lo haremos en Windows, ya que nuestro Burp Suite se encuentra ahí:


Ahora, la idea es moverlo al contenedor, para hacerlo podemos hacer uso del propio Docker Desktop, concretamente de la pestaña de “Files” que podemos encontrar al dar click a un contenedor.




Aquí podemos seleccionar y arrastrar un archivo para moverlo del Windows al Kali de forma sencilla sin complicaciones:


Esta característica también se puede usar a la inversa, es posible descargar archivos del contenedor al equipo anfitrión.
De esta manera ya lo tenemos en el contenedor:


Ahora debemos de convertir el certificado que está en formato DER a una clave pública, para ello hacemos uso de openssl:
- openssl x509 -in cacert.der -inform DER -out burp.crt


Una vez tenemos la clave pública, simplemente la movemos al directorio “/usr/local/share/ca-certificates/”:


Por último, simplemente actualizamos los certificados:
- update-ca-certificates


Como podemos observar, se indica que se ha agregado uno.
Ahora, si volvemos a intentar el mismo curl que hicimos al principio:


Funciona sin problemas y conseguimos que todo el tráfico pase por Burp Suite.
Esto es bastante útil para las siguientes situaciones:
- Queremos guardar todas las peticiones que hagamos en el proyecto de Burp Suite.
- Tenemos un exploit y queremos obtener la petición HTTP en RAW para poder jugar con ella desde Burp Suite.
- Estamos montando un script. Burp Suite nos puede ayudar a debuggearlo gracias a que podemos visualizar tanto las peticiones que se mandan como su respectiva respuesta. Lo mismo se puede hacer desde el código, pero oye, verlo en Burp Suite es bastante más cómodo.
- Sobre este punto, a mí me vino genial para la explotación y automatización de una inyección SQL de tipo boolean 🙂
Podemos desactivar o activar el uso del proxy desde la configuración tantas veces como queramos y cuando queramos. No es necesario después de realizar el respectivo cambio reiniciar los contenedores o algo parecido.
Comandos para administrar el contenedor
Ya tenemos el Kali preparado y el certificado de Burp Suite instalado. Llegados a este punto, solo queda ponerse modo Hack. Sin embargo, es importante saber los comandos básicos para administrar el contenedor en caso de que no hayas tocado Docker antes. Por ello, dejo los comandos mínimos a saber para poder tratar con ello:
- Listar todos los contenedores, estén o no en ejecución
- docker ps -a


- Listar contenedores en ejecución
- docker ps


- Iniciar un contenedor que esté parado
- docker start <ID>
- El ID del contenedor corresponde al ID que podemos obtener con docker ps.
- docker start <ID>


- Conectarnos al proceso principal del contenedor
- docker attach <ID>
- En caso de que nos salgamos de este proceso, el contenedor se detendrá, debido a que es el proceso principal.
- docker attach <ID>


- Ejecutar un nuevo proceso en un contenedor
- docker exec -it <ID> <comando>


- Detener un contenedor en ejecución
- docker stop <ID>


Estos son los comandos principales que necesitamos saber para tratar con el Kali que hemos instalado.
Conclusión
Hemos visto como se instala kali linux en Docker. Asimismo, hemos visto un poco el flujo y comandos que se siguen cuando se trata con imágenes y contenedores Docker, lo que nos sirve para tratar con cualquier imagen que veamos de aquí en adelante.
Además, oye, saber otra alternativa a los famosos VirtualBox y VMWare está genial. Como ya he mencionado en el post, ahora mismo mi setup es tal que:
- Burp Suite en Windows
- Kali en Docker
- El cual tunelizo cuando lo necesito por Burp Suite
Por supuesto, este setup prescinde de la parte gráfica de kali, sin embargo, la verdad que no la hecho en falta.
Offtopic: Y aunque ya se escape un poco de la temática del post, también es importante saber qué herramientas valen la pena lanzar desde Windows y cuáles desde Linux. Por ejemplo, un hashcat está claro que será mucho mejor en Windows para poder sacarle todo el partido a la GPU.
Grande sikumi, eres lo maximo.
Osea que para tener varias pesatañas tendrái que abrir n pestañas de Windows Terminal y ejecutar docker exec -it o como sería?
Eso es!
podrias intentar usar tmux
Cómo ejecutar la gui de Kali?
La idea de este kali es que solo sea CLI!
hola, muy buen aporte de verdad, mi pregunta es, esta configuracion vale para los usuarios de Mac?
un saludo y muchas gracias
hello! si! porque se trata de Docker, no importa el sistema siempre y cuando sea compatible con Docker
Excelente posssst Sikumyy, Docker es lo masss 😉
Tu si que eres lo mas <3