Tabla de contenido:
- Paso 1: mira la versión en video
- Paso 2: lo que necesitará
- Paso 3: Instalar y configurar Raspbian
- Paso 4: Instalación de MPICH
- Paso 5: Instalación de MPI4PY
- Paso 6: copia de la imagen
- Paso 7: Configuración de las Pi de frambuesa restantes
- Paso 8: Verificación de las claves de host
- Paso 9: Ejecución de un programa en su supercomputadora
2025 Autor: John Day | [email protected]. Última modificación: 2025-01-13 06:57
Por sí sola, la Raspberry Pi no cuenta con especificaciones impresionantes. Pero con el precio extremadamente bajo, comprar varios de estos y conectarlos para usarlos, su potencia de procesamiento combinada podría potencialmente hacer una computadora decente de bajo costo. Se han construido varias plataformas impresionantes que conectan docenas de Pi. Entonces, en este instructivo, ¡exploremos cómo la tecnología detrás de la computación en clúster y creemos nuestra propia Bramble Pi!
Paso 1: mira la versión en video
También hice una versión en video de dos partes de este mismo proyecto exacto. Entonces, si no eres de los que leen, ¡relájate y mira los videos! Tenga en cuenta que la versión de video utiliza Raspbian Wheezy. Sin embargo, las instrucciones a continuación son para la Raspbian Distro actual, que es Jessie en el momento en que escribo esto.
Paso 2: lo que necesitará
Para seguir con este proyecto, aquí están las partes que necesitará adquirir
Esto es lo que necesitará:
- 2 o más Raspberry Pi
- Tarjetas SD para cada Pi
- Cables de alimentación para cada Pi
- Hub USB con alimentación (opcional)
- Cables de red
- Un concentrador o un enrutador
COSTO TOTAL: ~ $ 100.00
Paso 3: Instalar y configurar Raspbian
Una vez que tenga todas las partes, el siguiente paso es descargar y configurar el sistema operativo Raspbian en uno de los Raspberry Pi. Este será tu maestro Pi. Estos son los pasos:
- Descarga la imagen de Raspbian desde aquí.
-
Grabe la imagen de Raspbian en cada tarjeta SD que tenga para cada Raspberry Pi.
- Si tiene Windows, puede seguir estas instrucciones.
- Si tiene una Mac, puede seguir estas instrucciones.
- Una vez que la imagen se haya grabado en su tarjeta SD, colóquela en cada una de las Raspberry Pi y enciéndala.
-
En el primer arranque, debería ver Rasbperry Pi Desktop. Haga clic en el icono de menú en la esquina superior izquierda y vaya a Preferencias> Configuración de Raspberry Pi. Estas son las opciones que necesitaremos configurar
- Expanda el Sistema de archivos si es necesario.
- Cambie el nombre de host a Pi01
- Cambie la opción de arranque a CLI (Interfaz de línea de comandos), ya que realmente no usaremos la Interfaz de escritorio.
- Reloj en la pestaña "Interfaces" y asegúrese de que SSH esté habilitado.
- Haga clic en la pestaña "Overclock" y elija "Turbo".
- Cambie la memoria de la GPU a 16 MB.
- Haga clic en la pestaña "Localización" y configure la distribución del teclado para que coincida con la de sus países.
- Termina la configuración y reinicia tu Pi.
Paso 4: Instalación de MPICH
Aún usando solo el Pi como maestro, ahora necesitamos instalar el software principal que nos permitirá usar la potencia de procesamiento de todos los Pi en nuestra red. Ese software se llama MPICH, que es una interfaz de paso de mensajes. Esto es lo que debe hacer para instalarlo:
sudo apt-get update
mkdir mpich2
cd ~ / mpich2
wget
tar xfz mpich-3.1.tar.gz
sudo mkdir / inicio / rpimpi /
sudo mkdir / home / rpimpi / mpi-install
mkdir / home / pi / mpi-build
cd / home / pi / mpi-build
sudo apt-get install gfortran
sudo /home/pi/mpich2/mpich-3.1/configure -prefix = / home / rpimpi / mpi-install
sudo hacer
sudo hacer instalar
nano.bashrc
RUTA = $ RUTA: / home / rpimpi / mpi-install / bin
sudo reiniciar
mpiexec -n 1 nombre de host
Estos comandos descargarán e instalarán MPICH, además de agregarlo como una ruta a su archivo de arranque BASHRC. El último comando ejecuta una prueba para ver si funciona. Si el último comando devuelve "Pi01", entonces hizo todo con éxito.
Paso 5: Instalación de MPI4PY
Tal como está, MPICH puede ejecutar programas C y Fortran. Pero dado que Raspberry Pi tiene el entorno de codificación Python preinstalado, sería más fácil instalar un intérprete de Python a MPI. Estos son los comandos para hacer eso:
sudo aptitude install python-dev
wget
tar -zxf mpi4py-1.3.1
cd mpi4py-1.3.1
python setup.py compilación
instalación de python setup.py
exportar PYTHONPATH = / home / pi / mpi4py-1.3.1
mpiexec -n 5 python demo / helloworld.py
Ese último comando debería devolver cinco respuestas. Cada uno es un proceso diferente en Pi01 que ejecuta el programa de Python "Hello World" que acabamos de hacer.
Paso 6: copia de la imagen
Ahora que hemos configurado con éxito nuestro Pi maestro, necesitamos copiar la imagen de la tarjeta SD de ese Pi a todos los demás Pi. A continuación, le indicamos cómo puede hacerlo en Windows:
- Saque la tarjeta SD maestra del Pi e insértela en su computadora.
- Usando Win32DiskImager, use el botón "Leer" para guardar el contenido de la tarjeta SD en su computadora.
- Expulse la tarjeta SD maestra e inserte una tarjeta SD para uno de los otros Pi. Luego use la opción "Escribir" de Win32DiskImager para escribir la imagen que guardamos en la nueva tarjeta SD.
- Repita el paso 3 hasta que tenga la imagen maestra escrita en todas las tarjetas SD.
Paso 7: Configuración de las Pi de frambuesa restantes
Ahora que tenemos todas las tarjetas SD preparadas, inserte la tarjeta SD maestra nuevamente en el Master Pi, conéctela a un enrutador y reiníciela. Luego, para las Raspberry Pi restantes, inserte tarjetas SD en todas ellas, conéctelas al mismo enrutador que su Master Pi y luego inícielas todas. Ninguno de los Pi secundarios necesita tener teclados, ratones o monitores.
Una vez que todos los Pi estén encendidos, utilizando nuestro Pi principal, deberíamos poder obtener las direcciones IP de cada Pi en la red. Así es cómo:
-
Primero instale NMAP
sudo apt-get update
sudo apt-get install nmap
-
Luego obtenga la IP actual para el Pi maestro
ifconfig
-
Ahora puede escanear la subred de sus enrutadores para las otras direcciones IP de Pi
sudo nmap -sn 192.168.1. *
Copie todas las direcciones IP que pertenecen a las otras Raspberry Pi en la red. Entonces podremos usar esas IP para conectarnos a cada una de las otras Pi usando SSH. Lo que tenemos que hacer primero es cambiar el nombre de cada uno de los Pi secundarios a un nombre de red único. Ahora mismo están todos configurados en Pi01. Suponiendo que una de las direcciones IP de la Pi secundaria es 192.168.0.3, así es como puede conectarse y cambiar su nombre:
-
Establecer una conexión SSH
-
Ejecute raspi-config
sudo raspi-config
- En la interfaz, desplácese hacia abajo hasta la opción Avanzado y luego elija Nombre de host.
- Para el nombre de host, cambie Pi01 al siguiente número secuencial, que es Pi02.
-
Luego salga de la sesión SSH
Salida
Desea repetir esos pasos para cada uno de los otros Pi en la red y cambiarles el nombre a Pi03, Pi04, etc.
En su Pi maestro, desea crear un nuevo archivo de texto llamado "archivo de máquina"
archivo de máquina nano
Y en él, desea escribir cada una de las direcciones IP de Pi (incluida la dirección IP maestra) en una nueva línea y luego guardar el archivo.
En este punto, podríamos ejecutar un archivo de prueba usando
mpiexec -f archivo de máquina -n 4 nombre de host
pero mostrará un error diciendo que hubo un "error de verificación de la clave del host". Entonces, en el siguiente paso, arreglemos eso.
Paso 8: Verificación de las claves de host
Para solucionarlo de modo que la comunicación con cada Pi no resulte en una falla de verificación de la clave del host, necesitamos crear e intercambiar claves para cada una de nuestras Raspberry Pi. Esta parte puede complicarse un poco, pero espero que puedas quedarte conmigo.
-
En el Master Pi, en la carpeta de inicio predeterminada, cree una nueva clave.
cd ~
ssh-keygen
-
Navegue a la carpeta ssh y copie el archivo de clave en un nuevo archivo llamado "pi01"
cd.ssh
cp id_rsa.pub pi01
-
A continuación, desea conectarse a través de SSH en Pi02 y repetir esos mismos pasos para crear un archivo de claves Pi02
ssh-keygen
cd.ssh
cp id_rsa.pub pi02
-
Antes de salir de Pi02, necesitamos copiar el archivo de claves Pi01 y autorizarlo.
scp 192.168.1.2:/home/pi/.ssh/pi01.
cat pi01 >> llaves_autorizadas
Salida
-
Con Pi02 hecho, repita todos esos pasos para Pi03
ssh-keygen
cd.ssh
cp id_rsa.pub pi03
scp 192.168.1.2:/home/pi/.ssh/pi01.
cat pi01 >> llaves_autorizadas
Salida
- Repita el último paso para las Pi restantes que tiene en su red.
-
Después de generar claves para cada uno de los Pi, vuelva a su Master Pi y copie todas las claves generadas en cada uno de los Pi.
cp 192.168.1.3:/home/pi/.ssh/pi02
cat pi02 >> llaves_autorizadas
cp 192.168.1.4:/home/pi/.ssh/pi03
cat pi03 >> llaves_autorizadas
cp 192.168.1.5:/home/pi/.ssh/pi02
cat pi04 >> llaves_autorizadas
- (repita para todos los Pi hay en su red)
Paso 9: Ejecución de un programa en su supercomputadora
Ahora todo debería estar configurado. Mientras todavía está en su Master Pi, intente ejecutar este archivo de máquina nuevamente:
cd ~
mpiexec -f archivo de máquina -n 4 nombre de host
Si todo se hizo correctamente, debería devolver las direcciones IP de todos sus Raspberry Pi. Ahora que hemos probado con éxito nuestra supercomputadora, ejecutemos un programa de Python en ella:
-
Descargue y descomprima mi script de prueba para descifrar contraseñas de Python.
wget
tar -zxf python_test.tar.gz
-
Edite el hash de la contraseña a uno que le gustaría descifrar.
nano python_test / md5_attack.py
-
Copie el archivo Python en todos sus Pi.
scp -r python_test 192.168.1.3:/home/pi
scp -r python_test 192.168.1.4:/home/pi
scp -r python_test 192.168.1.5:/home/pi
- (repita para todos los Pi restantes)
-
Ejecute la secuencia de comandos de Python.
mpiexec -f archivo de máquina -n 5 python python_test / md5_attack.py
¡El script se ejecutará utilizando el poder de procesamiento de todos los Pi en su red! ¡Siéntete libre de probarlo usando tu propio script de Python!
Tercer premio en el Concurso Raspberry Pi 2016