hits counter
Este sitio web utiliza cookies para obtener estadísticas de navegación. Si sigue adelante, consideraremos que acepta su uso. Acepto | Más información

Trucos:



Formatear y montar un disco externo USB

Para guardar ficheros (por ejemplo, las descargas de Transmission) lo más práctico es utilizar un disco externo USB (ya sea un HD o un SSD) debido a su velocidad de acceso y a su gran capacidad de almacenamiento. Con ello, además, evitaremos saturar la tarjeta microSD tanto de datos como de carga de trabajo, aparte de que podremos llevar los ficheros de un ordenador a otro sin tener que apagar la Raspberry. Veamos el proceso para formatear y montar un disco HD/SSD en ella y hacer que se monte luego automáticamente cada vez que iniciemos el sistema.


Formateo

Lo primero que tenemos que hacer es conectar la unidad externa a uno de los puertos USB y averiguar el nombre del dispositivo, es decir, la referencias física que le asigna Linux (Raspberry Pi OS en este caso). Lo haremos con este comando:

sudo fdisk -l

que nos mostrará una imagen similar a esta:

Al final (en la parte de abajo de la pantalla) aparecerá el nombre. Si no tenemos ninguna otra unidad USB conectada, muy probablemente será /dev/sda1. Las tres letras (sda) corresponden al nombre del dispositivo y el 1 indica el número de la partición. Lo normal es que sólo haya una partición (es decir, sda1) y así no tendremos que preocuparnos de nada más. Pero si no hay ninguna (en este caso sólo aparecerá sda), habrá que crear una partición; y en el caso de que haya varias (sda1, sda2, sda3,...), las eliminaremos todas y luego crearemos sólo una, como se muestra en los puntos 3, 4 y 5 de este apartado.

A continuación formatearemos el disco. Este proceso sólo puede realizarse si el dispositivo está desmontando (si no lo estuviera, lo desmontamos con el comando sudo umount /dev/sda1). Para usarlo con Raspberry Pi OS, o cualquier otra distribución de Linux, lo mejor es formatearlo con el sistema de ficheros ext4. Podemos realizar esto fácilmente desde la propia consola de comandos con la siguiente orden:

sudo mkfs.ext4 /dev/sda1

Montaje

Concluido el formateo, hay que crear un punto de montaje para nuestro HD/SSD, que será la carpeta desde la que accederemos a él. Para ello, crearemos un carpeta llamada, por ejemplo, hdusb dentro del directorio /media:

cd /media
sudo mkdir hdusb

En este momento ya podemos montar el disco en dicha carpeta con este comando:

sudo mount /dev/sda1 /media/hdusb

Pero para no tener que hacer esto cada vez que iniciemos el sistema, lo mejor es lograr que se monte automáticamente al arrancar la Raspberry. Para conseguirlo tenemos que modificar el fichero /etc/fstab:

sudo nano /etc/fstab

Añadiremos al final del mismo una nueva línea, en la que indicaremos el nombre del dispositivo, la carpeta de montaje y el sistema de ficheros usado (los espacios se insertan con el tabulador):

/dev/sda1    /media/hdusb    ext4    defaults    0    0

El contenido del fichero debe quedar así:

Lo guardamos (Ctrl+o, Intro, Ctrl+x) y reiniciamos el sistema:

sudo reboot

A partir de ahora, cada vez que el sistema se inicie, el disco se montará automáticamente en la carpeta indicada.

Una vez hecho lo anterior, ya podemos crear todas las subcarpetas que necesitemos dentro de la carpeta /media/hdusb. Así pues, nos situamos en ella y creamos, por ejemplo, una carpeta para guardar los ficheros que descarguemos, a la que le daremos todos los permisos para que cualquier usuario pueda acceder a ella:

cd /media/hdusb
sudo mkdir descargas
sudo chmod 777 descargas

Montaje mediante UUID

El UUID (Universally Unique IDentifier) es un identificador único para cada sistema de ficheros. Cuando montamos varios dispositivos USB en la Raspberry es mucho mejor usar el UUID en lugar de la referencia física de la conexión (/dev/sdxx), ya que esta referencia puede variar durante el arranque o el reinicio haciendo que se relacionen de forma incorrecta el dispositivo con su carpeta de montaje correspondiente, lo que podría causar graves problemas en el sistema de ficheros.

El comando sudo blkid nos mostrará los dispositivos y el UUID que corresponde a cada uno:

Luego, editamos el fichero /etc/fstab:

sudo nano /etc/fstab

e incluimos el UUID de cada dispositivo conectado (sin las comillas), como se ve en la siguiente imagen:





Hacer backup de la tarjeta SD en Windows

Cuando tengamos la Raspberry configurada a nuestro gusto y todo funcione correctamente, es el momento perfecto de hacer un backup o copia de seguridad de la tarjeta SD. Así, si el sistema deja de funcionar bien o la tarjeta se estropea, podremos coger otra SD y volcar en ella la copia de seguridad, de manera que en unos minutos tendremos nuestro sistema funcionando de nuevo a la perfección.

Para ello emplearemos la utilidad Win32 Disk Imager, la misma con la que creamos la imagen del sistema Raspberry Pi OS en la tarjeta SD, y cuyo aspecto es el siguiente:

El proceso completo, paso a paso, lo haremos del siguiente modo:

  1. 1.) Insertamos la tarjeta SD de la Raspberry en el lector de tarjetas de nuestro PC.
  2. 2.) Creamos un fichero vacío con extensión img (por ejemplo, backupSD.img) en una carpeta del PC.
  3. 3.) Arrancamos el programa Win32 Disk Imager como administrador. Nos aparecerá la ventana de la aplicación, igual a la de la imagen anterior.
  4. 4.) En Device seleccionamos la letra de la unidad de la tarjeta SD. ¡Atención! Comprueba muy bien que has elegido correctamente la letra de la unidad o podrás formatear por error el disco duro.
  5. 5.) En Image File seleccionamos el fichero con extensión img que hemos creado en el paso 2.
  6. 6.) Pulsamos en el botón Read y empezará el proceso de copia de la imagen de la tarjeta SD en el fichero.
  7. 7.) Terminado el proceso, pulsamos en Exit para salir del programa.
  8. 8.) Ya sólo nos queda desmontar el lector y extraer la tarjeta SD.

En el fichero backupSD.img tendremos guardada ahora una imagen de la tarjeta SD tal y como estaba en el momento de hacer el backup, lista para recuperarla cuando lo necesitemos.




Hacer backup de la tarjeta SD desde la RPi

Realizar una copia de seguridad de la tarjeta SD, con el sistema ya instalado y configurado a nuestro gusto, es algo que puede hacerse sin desconectar nuestra placa. Realizaremos la copia en un dispositivo USB conectado a la Raspberry Pi (en este caso, un pendrive) que montaremos en /media/pen (si no lo tenemos instalado, aquí se explica cómo formatearlo y montarlo). Ahí crearemos una carpeta llamada backups para guardar las copias de seguridad. El proceso lo haremos desde la propia Raspberry, sin necesidad de apagarla ni desmontar el sistema operativo.

Vamos a hacer el backup recurriendo al comando dd, que usa varios argumentos: if (el origen de la copia), of (el destino) y bs (el tamaño de los bloques). Añadiremos al final status=progress para que nos muestre el progreso de la copia:

sudo dd if=/dev/mmcblk0 of=/media/pen/backups/raspbian.img bs=1M status=progress

Iremos viendo la evolución del proceso y, una vez terminado, en el directorio /media/pen/backups tendremos una copia de seguridad del sistema (raspbian.img), lista para usar cuando la necesitemos.

Cuando queramos recuperar e instalar el backup, sólo tendremos que recurrir de nuevo al comando anterior, pero teniendo en cuenta que ahora el proceso será inverso:

sudo dd if=/media/pen/backups/raspbian.img of=/dev/mmcblk0 bs=1M status=progress

Para trabajar con la copia de seguridad recuperada, debemos reiniciar antes la Raspberry:

sudo reboot



Enviar correos desde la línea de comandos

Ya que utilizamos la Raspberry casi siempre desde la terminal, en modo texto, puede que en algún momento nos interese enviar un correo a alguien sin tener que recurrir al modo gráfico, haciéndolo directamente desde la propia línea de comandos. Vamos a mostrar dos formas diferentes de conseguirlo: una primera más simple y sencilla, y luego otra algo más compleja, pero también más completa.


1.- Mediante ssmtp

Instalación y configuración

Primero instalamos estos dos paquetes:

sudo apt install ssmtp mailutils

En segundo lugar nos convertirmos en root de forma permanente:

sudo su

Haremos previamente una copia de seguridad del fichero que vamos a editar:

cp /etc/ssmtp/ssmtp.conf /etc/ssmtp/ssmtp.conf.backup

Y ahora editamos el fichero de configuración para el envío de los correos:

nano /etc/ssmtp/ssmtp.conf

Comentamos todas las líneas e incluimos al final lo siguiente:

root=micorreo@servidor.com
mailhub=smtp.server.com:587
FromLineOverride=YES
AuthUser=micorreo@servidor.com
AuthPass=contraseña
UseSTARTTLS=YES

Lo que se ha destacado en negrita debemos cambiarlo, lógicamente, por los datos concretos de nuestra cuenta.

NOTAS IMPORTANTES:

  1. 1.- Este sistema no funciona con todos los proveedores de correo debido a las estrictas limitaciones que imponen para su uso. Por ejemplo, las cuentas de correo de Gmail no funcionarán a no ser que vayamos a la configuración de la cuenta y activemos el Acceso de aplicaciones poco seguras. En cambio, si poseemos un dominio propio con cuenta/s de email, es muy posible que sí funcione.
  2. 2.- Si el puerto que utiliza el servicor de correo saliente es el 465 en lugar del 587, habrá que usar UseTLS=YES en lugar de UseSTARTTLS=YES.

A continuación editamos este otro fichero:

nano /etc/ssmtp/revaliases

y al final del mismo incluimos esta línea (sustituyendo las negritas por los mismos datos de antes):

piuser:micorreo@servidor.com:smtp.server.com:587

Ya podemos dejar de ser root y volver al usuario normal:

exit

Enviar correos

A partir de ahora, cuando queramos enviar un correo, sólo tenemos que teclear lo siguiente:

echo "Texto del mensaje" | mail -s "Asunto" receptor@dominio.com

Si necesitamos enviar un mensaje más extenso, que incluya saltos de línea, tendremos que crear un archivo con el editor de textos. Por ejemplo:

nano correo.txt

Escribimos en este archivo el contenido del mensaje y lo guardamos. Después lo enviamos así:

cat correo.txt | mail -s "Asunto" receptor@dominio.com

Si deseamos enviar el correo a varios destinatarios, sólo tenemos que separar al final las distintas direcciones de email por comas.


Enviar ficheros adjuntos

Si necesitamos adjuntar algún fichero al correo, tendremos que instalar mpack:

sudo apt install mpack

Lo usaremos indicando la ruta (si no estamos situados ya en ella) y el nombre del fichero que deseamos enviar, así:

mpack -s "Asunto" /home/piuser/fichero receptor@dominio.com

2.- Mediante Mutt

Instalación y configuración

Instalamos el paquete:

sudo apt install mutt

Como lo vamos a usar con nuestro usuario habitual, creamos en la ruta correspondiente dos directorios y un fichero:

mkdir –p ~/.mutt/cache/headers
mkdir –p ~/.mutt/cache/bodies
touch ~/.mutt/certificates

Ahora pasamos a crear el fichero de configuración:

nano ~/.mutt/muttrc

y lo editamos siguiendo esta guía, pero con modificaciones para hacerlo más simple y corregir algún pequeño error. Cambiaremos lo que aparece en negrita por los datos de nuestra cuenta de correo:

#================ IMAP ====================
set imap_user = "micorreo@servidor.com"
set imap_pass = "contraseña"
set spoolfile = "imaps://imap.server.com/INBOX"
set header_cache = "~/.mutt/cache/headers"
set message_cachedir = "~/.mutt/cache/bodies"
set certificate_file = "~/.mutt/certificates"
#================ SMTP ====================
set smtp_url = "smtp://micorreo@servidor.com@smtp.server.com:587/"
set smtp_pass = $imap_pass
#set ssl_force_tls = yes           # puede usarse esta línea o la siguiente
set ssl_starttls = yes
#=============== Composición ================
set editor = "nano"
set edit_headers = yes
set charset = UTF-8           # value of $LANG; also fallback for send_charset
# Sender, email address and sign-off line must match
unset use_domain
set realname = "Mi nombre real"
set from = "micorreo@servidor.com"
set use_from = yes
set timeout = 30
#========================================

Una ventaja de mutt es que podemos configurarlo para que use el conjunto de caracteres UTF-8, por lo que podremos escribir usando acentos y la letra ñ.

Hemos de tener en cuenta que aquí se aplica también lo que dijimos antes en la NOTA 1.- del subapartado anterior.


Enviar correos

Para enviar un correo escrbiremos lo siguiente:

echo "Cuerpo del mensaje" | mutt -s "Asunto" receptor@dominio.com

Si necesitamos adjuntar un fichero, usaremos al final el parámetro -a indicando la ruta, si no estamos situados ya en ella:

echo "Cuerpo mensaje" | mutt -s "Asunto" receptor@dominio.com -a "/home/piuser/fichero"

Mutt como aplicación

Otra manera de usar mutt es ejecutando el comando del mismo nombre:

mutt

Nos preguntará si deseamos crear el directorio /home/piuser/Mail. Contestamos que y se abrirá una ventana con diversas opciones de menú:

Desde aquí podremos escribir un correo (con el editor nano) pulsando m. Se nos pedirá que escribamos el destinatario y el asunto. Es posible abortar la composición del mismo con la combinación de teclas Ctrl+c o, una vez en el editor, con Ctrl+x:

Como se observa en el menú superior de la siguiente imagen, pulsando a podremos adjuntar un archivo y finalmente enviaremos el correo pulsando y:




Encender un ordenador con Wake on LAN

Si disponemos en casa de un PC al que necesitamos acceder de vez en cuando para guardar o descargar cosas, tenerlo encendido las 24 horas supondría un gasto energético elevado e innecesario. La solución más fácil y eficiente sería arrancarlo sólo cuando necesitemos acceder a él. Si estamos en casa, eso no supone ningún problema; el problema es hacerlo a distancia, cuando estamos fuera de casa. Para realizarlo de este último modo necesitamos recurrir a Wake on LAN, que nos permite encender un ordenador por medio de su propio adaptador de red Ethernet. Aunque esto es posible hacerlo desde Internet (a través de una app del móvil, por ejemplo), resulta algo problemático, pues depende de ciertas características del router (abrir los puertos 7 y 9 UDP + crear una entrada ARP) que no todos ellos poseen o son tareas complejas de realizar. Así pues, para obviar dichas complicaciones, lo haremos desde otro dispositivo de nuestra red local (LAN), como por ejemplo una Raspberri Pi, a la que accederemos por SSH a través de Internet.


Requisitos previos

Para llevar a cabo esta tarea es preciso tener en cuenta estas tres cosas:

  1. 1.) Raspberry Pi: tener nuestra placa siempre encendida (algo que podemos permitirnos debido a su bajo consumo energético) y conectarnos a ella por SSH. Para ello tendremos que tener previamente instalado en la Raspberry un servicio DDNS que nos permita el acceso desde Internet.
  2. 2.) BIOS: que el ordenador que deseamos arrancar tenga la posibilidad de encendido a través de Wake on LAN y habilitar dicha opción en la BIOS del dispositivo. Para lograr esto, normalmente habrá que cambiar algunas opciones en la BIOS: dependiendo del modelo, puede que en el apartado ACPI o AHCI haya que activar el encendido de los dispositivos PCIe y luego habilitar el arranque mediante LAN. En otros modelos de BIOS puede que baste con activarlo en Opciones avanzadas -- Chipset Configuration -- Boot From Onboard LAN o algo similar. El manual de la placa nos será muy útil para averiguarlo en cada caso.
  3. 3.) Sistema Operativo: en el caso de que el PC que deseamos encender a distancia use Linux, no es necesario hacer nada más. En cambio, con Windows la cosa se complica. En este caso iremos al Panel de Control - Administrador de dispositivos - Adaptadores de red. Elegimos el adaptador Ethernet y con el botón derecho abrimos sus Propiedades. En la pestaña Opciones avanzadas buscamos una opción que diga "Activación con LAN apagado", "Reactivar con Magic Packet", "Remote wake-up", "Wake Up...", "Power up by LAN"... (o algo similar, dependiendo del fabricante del dispositivo) y la activamos. Luego vamos a la pestaña Administrador de energía y desmarcamos la casilla "Permitir que el equipo apague este dispositivo para ahorrar energía"; debajo, marcamos las casillas "Permitir que este dispositivo reactive el equipo" y "Permitir un Magic Packet para reactivar el equipo". Aceptamos y salimos.


Hacer Wake on LAN

Habiendo tenido en cuenta todo lo anterior, para poder hacer Wake on LAN deberemos tener instalado previamente en la Raspberry el servicio adecuado que se encargue de ello, así que nos conectamos por SSH y lo instalamos:

sudo apt install wakeonlan

Ahora necesitamos conocer la dirección MAC del ordenador que queremos poner en marcha. En Linux, para conocer la dirección MAC de los adaptadores de red que posee un ordenador, podemos escribir el comando ifconfig. Si al lanzar este comando obtenemos un error, habrá que instalar previamente otro paquete (sudo apt install net-tools). En el caso de Windows, escribiremos ipconfig /all en la ventana del Símbolo del sistema.

Para realizar el Wake on LAN, entramos remotamente en la Raspberry por SSH y le pasamos la dirección MAC del ordenador de nuestra LAN que queremos encender. Entonces la Raspberry mandará un magic packet (paquete mágico) vía broadcast que será recibido por la máquina destino y se procederá a su arranque. Por ejemplo:

wakeonlan 0e:61:a2:37:4c:5f                [cambiamos esta MAC por la de nuestro dispositivo]

Recordar la MAC

Para que no se nos olvide la MAC del ordenador que deseamos arrancar, podemos crear un fichero de script en nuestra carpeta de usuario (/home/piuser) que incluya dicha dirección MAC. Así que primero creamos el archivo:

nano wol.sh

Y en él incluimos el siguiente contenido:

#!/bin/bash
wakeonlan 0e:61:a2:37:4c:5f

Una vez guardado, le damos permiso de ejecución:

chmod u+x wol.sh

Y ya sólo tenemos que ejecutarlo cuando lo necesitemos:

./wol.sh

Finalmente, añadir que si queremos automatizar esta tarea para que la orden de encendido se ejecute, por ejemplo, todos los días a una determinada hora, podemos añadir el script a cron, cuyo uso se explica detalladamente aquí.




Aumentar el tamaño de la memoria swap

La memoria swap (o memoria de intercambio, en español) la utiliza el sistema operativo, a modo de memoria auxiliar, cuando ha agotado toda la memoria RAM del sistema, reservando para ello una parte del espacio de la tarjeta microSD. Raspberry Pi OS, por defecto, sólo reserva 100 MB para este propósito. Esta cantidad resulta insuficiente para la mayoría de los casos, sobre todo si instalamos muchas aplicaciones en nuestra Raspberry, por lo que se quedará escasa.

Para aumentar su tamaño editamos el correspondiente fichero de configuración:

sudo nano /etc/dphys-swapfile

Buscamos la línea CONF_SWAPSIZE=100 y escribimos al final la cantidad de memoria (en MBs) que deseemos. Por ejemplo:

CONF_SWAPSIZE=1024

Para aplicar los cambios, podemos reiniciar el sistema (sudo reboot) o bien actualizar la propia swap. Si optamos por esto último, haremos lo siguiente:

sudo dphys-swapfile setup
sudo dphys-swapfile swapon

Comprobamos que los cambios se han aplicado correctamente con este comando:

cat /proc/meminfo | grep Swap

Con lo que obtendremos algo similar a esto:

SwapCached:                       0 kB
SwapTotal:               1048572 kB
SwapFree:                1048572 kB

Otra forma de comprobarlo es mediante el comando free, que nos muestra tanto el uso de la memoria RAM como de la memoria swap.

Podemos aprovechar para ajustar los valores de la memoria swap. Para ello editamos el fichero

sudo nano /etc/sysctl.conf

y al final del todo añadimos estas dos líneas:

vm.swappiness=10
vm.vfs_cache_pressure=50

Estos ajustes sólo se activarán cuando reiniciemos el sistema:

sudo reboot



Aumentar el amperaje de los puertos USB

Es posible aumentar la potencia eléctrica de salida de los puertos USB de la Raspberry Pi, lo que puede ser útil para conectar un disco duro, especialmente si es un disco de gran capacidad (más de 1 TB). Hacer esto es muy sencillo; tan sólo hemos de modificar un fichero:

sudo nano /boot/config.txt

y añadir esta línea al final:

max_usb_current=1

Guardamos los cambios y reiniciamos el sistema:

sudo reboot

De esta forma, el puerto USB dará 1,2A en lugar de 0,6A, que es lo que da defecto. Pero esos 1,2A se reparten entre los 4 puertos USB, así que para beneficiarse de esto, sólo debemos usar uno de ellos.

Aparte de este cambio, es imprescindible utilizar un cargador o fuente de alimentación que dé suficiente amperaje: mínimo 3A, y si es de 3,5A o 4A, mucho mejor.




Conexión remota mediante un cliente VNC

Si tenemos instalado Raspberry Pi OS Desktop, podremos acceder al escritorio y utilizar la Raspberry de forma gráfica mediante al servidor VNC que viene ya instalado y activado por defecto. No obstante, para comprobar que efectivamente el servidor está activado, vamos a entrar en la configuración del sistema escribiendo el siguiente comando:

sudo raspi-config

Aparecerá una ventana como la de la figura de abajo para configurar determinados aspectos del sistema:


En el apartado 3 Interface Options podremos activar/desactivar, entre otros servicios, el que corresponde al servidor VNC. Hecho esto, ya debería funcionar una vez reiniciado el sistema.

Pero si queremos tener un mayor control, podemos ponerlo en marcha manualmente y decirle cómo queremos usarlo, indicando el número del servidor, la resolución con la que deseamos que se muestre y la profundidad del color. Por ejemplo:

vncserver :1 -geometry 1920x1080 -depth 24

Como respuesta obtendremos un extenso mensaje al final del cual se nos indicará el nombre del servidor (hostname) y su IP local:

El nuevo escritorio es raspberrypi:1 (192.168.1.33:1)

Con estos datos ya podemos acceder a la Raspberry desde cualquier dispositivo de nuestra red local utilizando un cliente VNC, en el que añadiremos una nueva conexión (clic botón derecho -- Nueva conexión) indicando en VNC Server cualquiera de los datos obtenidos antes (el hostname o la IP seguidos del número del servidor) y en Nombre pondremos un nombre identificativo:

Para poder establecer la conexión se nos pedirá, como es habitual, el nombre de un usuario del sistema y su correspondiente contraseña.

En el caso de tener el cortafuegos ufw activado, será necesario abrir el puerto 5901/tcp. Y si además queremos tener acceso desde el exterior, necesitaremos instalar un sistema de DDNS y luego, en el router, redireccionar el mencionado puerto a la IP local de la Raspberry.




Mover el SO a un dispositivo USB

La Raspberry Pi está diseñada para funcionar con el sistema operativo instalado en el lector de tarjetas microSD que incorpora. Pero podemos lograr que el sistema operativo se ejecute también en un dispositivo USB. Para ello es necesario hacer una serie de modificaciones. Técnicamente lo que tenemos que hacer es cambiar de sitio la partición /dev/root de nuestro sistema (que se encuentra en la partición 2 de la tarjeta microSD) para que resida en el dispositivo USB externo. Este procedimiento es válido para los modelos 1, 2, 3 y 3+. Para la RPi 4 usaremos las instrucciones que se detallan en el apartado siguiente. Una vez aclarado esto, vamos a seguir los siguientes pasos:

  1. 1.) Si ya tenemos una tarjeta microSD con el SO configurado y funcionando, vamos al paso 2. Si no es así, instalamos el SO en la tarjeta como se explica aquí, sin olvidar añadir después el fichero vacío ssh en la partición boot.
  2. 2.) Insertamos la tarjeta en la Raspberry, conectamos a ella el dispositivo USB (Pendrive, HD o SSD), la encendemos y accedemos por SSH (como también explicamos aquí).
  3. 3.) Escribimos el siguiente comando:
    sudo fdisk -l
    y nos aparecerá algo parecido a esto:

    En la imagen, /dev/mmcblk0p2 es donde se halla ahora el sistema operativo, mientras que /dev/sda es la unidad USB que hemos conectado.
  4. 4.) Vamos a preparar nuestro USB externo para copiar en él el sistema operativo, así que tecleamos esto:
    sudo fdisk /dev/sda
    En la línea de comandos pulsamos p para ver la lista de particiones y obtendremos esta imagen:

    Pulsamos d para borrar la primera partición (/sda1). Si hay más particiones, repetimos el proceso para borrarlas todas.
  5. 5.) A continuación escribimos n para crear una nueva partición, luego p para que sea una partición primaria, escribimos 1 para indicar la primera partición y finalmente pulsamos Intro dos veces para aceptar los sectores inicial y final propuestos, con lo que la partición ocupará todo el espacio disponible en la unidad externa:

    Para salir y guardar los cambios, escribimos w.
  6. 6.) Ahora formatearemos la partición que hemos creado:
    sudo mkfs.ext4 /dev/sda1
  7. 7.) Crearemos una carpeta en el directorio /media en la que montar la unidad USB:
    sudo mkdir /media/hdd
    Como en nuestro caso se trata de un disco duro, la hemos llamado hdd, pero podemos usar cualquier nombre que resulte identificativo.
  8. 8.) Montamos la partición en su carpeta:
    sudo mount /dev/sda1 /media/hdd
  9. 9.) Copiamos el contenido de la partición root (/) de la tarjeta microSD en la carpeta donde hemos montado la unidad USB:
    sudo rsync -avx / /media/hdd
  10. 10.) Editamos el fichero /etc/fstab de la unidad USB:
    sudo nano /media/hdd/etc/fstab

    y cambiamos la partición / de la microSD por la del dispositivo USB. Para ello, comentamos la partición 02 de la tarjeta y ponemos en su lugar /dev/sda1, como se muestra en la imagen:


  11. 11.) Finalmente modificaremos este fichero de la microSD:
    sudo nano /boot/cmdline.txt
    y sustituimos lo que hay justo a continuación de root= (que será la partición 02 de la tarjeta) por /dev/sda1, de manera que quede así (como se muestra en negrita):
    ... console=tty1 root=/dev/sda1 rootfstype=ext4 ...
  12. 12.) Guardamos los cambios y reiniciamos la Raspberry:
    sudo reboot

Con el comando df -h podremos ver que el SO (/dev/root) se encuentra ahora en la unidad USB, que se corresponde con la raíz /, mientras que la tarjeta (/dev/mmcblk0p1) contiene la partición de arranque /boot.

Como el disco duro externo incluye ahora la partición donde está instalado Raspberry Pi OS, es necesario que este dispositivo esté siempre conectado a la placa. Y lo mismo ocurre con la tarjeta microSD: hay que tenerla insertada para que se pueda realizar el arranque, pues la partición /boot, como hemos comprobado, se encuentra en la tarjeta.




Mover el SO a un USB (en la Pi 4)

La Raspberry Pi 4, como los modelos anteriores, está diseñada para funcionar con el sistema operativo instalado en el lector de tarjetas microSD que incorpora. Sin embargo, la RPi4 posee una ROM y un Bootloader más avanzados que ofrecen la posibilidad de que el sistema se ejecute en un dispositivo USB prescindiendo completamente de la tarjeta microSD. Para ello es necesario hacer una serie de modificaciones. Técnicamente lo que tenemos que hacer es cambiar de sitio las particiones raíz y /boot del sistema (que se encuentran en la tarjeta microSD) para que residan en el dispositivo USB externo. Este procedimiento sólo es válido para la Raspberry Pi 4. En el caso de los modelos anteriores seguiremos las instrucciones que explicamos en el apartado anterior. Una vez aclarado esto, vamos a seguir los siguientes pasos:

  1. 1.) Si ya tenemos una tarjeta microSD con el SO configurado y funcionando, vamos al paso 2. Si no es así, instalamos el SO en la tarjeta como se explica aquí, sin olvidar añadir después el fichero vacío ssh en la partición boot.
  2. 2.) Insertamos la tarjeta en la Raspberry, conectamos a ella el dispositivo USB (Pendrive, HD o SSD), la encendemos y accedemos por SSH (como también explicamos aquí).
  3. 3.) Actualizamos el sistema operativo:
    sudo apt update
    sudo apt upgrade -y
  4. 4.) Reiniciamos:
    sudo reboot
  5. 5.) Entramos en la utilidad de configuración:
    sudo raspi-config
    Aparecerá un menú con distintas opciones numeradas. Seleccionamos 6 Advanced Options:

    Ahí, como se ve a continuación, elegimos A7 Boot ROM Version -- E1 Latest para instalar la última versión de la ROM. Al final se nos preguntará: Reset boot ROM to defaults? Contestamos No.

    Luego volvemos al menú anterior, y como se muestra en la siguiente imagen, seleccionamos la opción A6 Boot Order -- B1 USB Boot. Se nos informará de que USB Device is default boot device. Aceptamos el mensaje. Salimos de la aplicación seleccionando <Finish> y cuando se nos pregunte Would you like to reboot now? contestamos No.

  6. 6.) Ahora insertamos la unidad externa en uno de los puertos USB 3.0 y escribimos el siguiente comando:
    sudo fdisk -l
    Nos aparecerá algo parecido a esto:

    En la imagen, /dev/mmcblk0p2 es donde se halla ahora el sistema operativo, mientras que /dev/sda es la unidad USB que hemos conectado.
  7. 7.) Vamos a preparar el dispositivo USB para que contenga tanto el sistema operativo como el arranque del mismo, así que tecleamos esto:
    sudo fdisk /dev/sda
    En la línea de comandos pulsamos p para ver la lista de particiones y obtendremos esta imagen:

    Pulsamos d para borrar la primera partición (/sda1). Si hay más particiones, repetimos el proceso para borrarlas todas.
  8. 8.) A continuación escribimos n para crear una nueva partición, luego p para que sea una partición primaria, escribimos 1 para indicar la primera partición y finalmente pulsamos Intro dos veces para aceptar los sectores inicial y final propuestos, con lo que la partición ocupará todo el espacio disponible en la unidad externa:

    Para salir y guardar los cambios, escribimos w.
  9. 9.) Ahora formatearemos la partición que hemos creado:
    sudo mkfs.ext4 /dev/sda1
  10. 10.) Escribimos el comando lsblk para que nos muestre el nombre de los dispositivos conectados. Aparecerá el USB (sda) y la tarjeta microSD (mmcblk0).

  11. 11.) Ya podemos proceder a copiar el contenido de la tarjeta en la unidad USB:
    sudo dd if=/dev/mmcblk0 of=/dev/sda status=progress bs=1M
  12. 12.) Cuando haya finalizado, apagamos la Raspberry:
    sudo poweroff
    y extraemos la tarjeta microSD.
  13. 13.) Arrancamos de nuevo sin la tarjeta microSD (tarda un poco la primera vez) y con el comando lsblk miramos los dispositivos conectados. Ahora sólo mostrará la unidad sda con dos particiones: sda1 (/boot) y sda2 (/):

  14. 14.) Además, con el comando df -h veremos el espacio usado y también el espacio disponible en la partición /dev/root (/). En el caso de que esta partición no refleje el tamaño completo de la unidad USB (mostará probablemente el mismo tamaño que tenía la tarjeta microSD), tendremos que expandir el sistema de ficheros:
    sudo raspi-config
    Seleccionamos 6 Advanced Options -- A1 Expand Filesystem. Hacemos la expansión eligiendo <Select> y, una vez reiniciado el sistema, ya debería de tener el tamaño correcto.
  15. 15.) Cuando se mueve el SO a un dispositivo USB (HD, SSD, pendrive), suele aumentar el consumo de CPU; además, el led verde de la Raspberry parpadea constantemente. Ambas cosas se deben a que el sistema está comprobando continuamente si hay una microSD insertada. Para evitar esto, tenemos dos opciones: insertar una tarjeta microSD vacía para que el SO la detecte y deje de hacer comprobaciones, o bien editar el fichero /boot/config.txt y añadir al final del mismo la línea dtparam=sd_poll_once. Después de reiniciar, comprobaremos que se ha solucionado el problema.



Solución para los paquetes retenidos

Algunas veces, cuando actualizamos el sistema operativo Raspberry Pi OS mediante los comandos

sudo apt update
sudo apt upgrade

obtenemos un mensaje que nos indica que ciertos paquetes están retenidos:

Los siguientes paquetes se han retenido:
   [lista de paquetes]

La razón es que algunos de los paquetes que hemos instalado recientemente tienen dependencias nuevas y necesitan ser actualizadas, pero esto no puede lograrse con un simple sudo apt upgrade. La solución es teclear el siguiente comando, que actualiza completamente la distribución:

sudo apt dist-upgrade

Una vez hecho, ya no tendremos ningún paquete retenido.

Cuando ocurre esto, normalmente también encontramos uno o varios paquetes autoinstalados que ya no son necesarios. Si es el caso, podemos deshacernos de ellos con

sudo apt autoremove



Eliminar firma GPG y repositorio de Microsoft

En Enero de 2021, en una actualización del sistema operativo Raspberry Pi OS, se introdujo la firma GPG de Microsoft y el repositorio correspondiente para poder instalar el Visual Studio Code de esta empresa, supuestamente con la finalidad de facilitar la programación en la Raspberry Pi Pico. Esto nos lleva a que una actualización pueda extraer una dependencia del repositorio de Microsoft y el sistema confíe automáticamente en ese paquete. Además, a partir de ahora, cada vez que se hace un sudo apt update, estaremos haciendo ping y mostrando nuestra IP a un servidor de Microsoft.

Lo peor de este asunto radica en que esto se ha hecho sin preguntar a los usuarios si desean (o necesitan) la inclusión de ese repositorio de Microsoft cuando realizan la actualización del sistema. Ello ha generado, como es lógico, una gran controversia, pues supone traicionar la confianza que se deposita en el sistema operativo recomendado (que no creado) por la fundación que se encarga del desarrollo de esta placa. Curiosamente, Microsoft y Google son las empresas que más dinero aportan a esta supuesta fundación que desarrolla la Raspberry Pi.


Posibles soluciones

La mejor solución es prescindir de Raspberry Pi OS e instalar otras distribuciones. Con ello zanjaremos este desagradable asunto de una forma eficaz y definitiva.

No obstante, si se va a seguir usando este SO por alguna razón, una forma rápida (aunque provisional) de solventar el problema es eliminar estos dos archivos:

sudo rm -f /etc/apt/trusted.gpg.d/microsoft.gpg
sudo rm -f /etc/apt/sources.list.d/vscode.list

El primero contiene la firma GPG de Microsoft y el segundo, el repositorio para instalar VSCode (que se descarga de packages.microsoft.com). Pero eliminarlos no impide que se puedan volver a instalar en las sucesivas actualizaciones del sistema, por lo que habrá que comprobarlo periódicamente.

Quienes deseen hacer un trabajo más elaborado y exhaustivo, pueden realizar los siguientes pasos:

  1. 1.- Editar el fichero de hosts:
    sudo nano /etc/hosts
    e incluir lo siguiente:
    0.0.0.0         packages.microsoft.com
    (o añadir este subdominio a Pi-hole, si lo tenemos instalado).
  2. 2.- Borrar la clave GPG de Microsoft y el repositorio de VSCode:
    sudo rm -f /etc/apt/trusted.gpg.d/microsoft.gpg
    sudo rm -f /etc/apt/sources.list.d/vscode.list
  3. 3.- Marcar como hold (retenido) el paquete raspberrypi-sys-mods para así evitar que se reinstale o actualice en el futuro, ya que este paquete es el verdadero responsable de que se instalen los dos ficheros anteriores:
    sudo apt-mark hold raspberrypi-sys-mods
  4. 4.- Crear de nuevo ambos ficheros, pero vacíos:
    sudo touch /etc/apt/trusted.gpg.d/microsoft.gpg
    sudo touch /etc/apt/sources.list.d/vscode.list
  5. 5.- Asignar el atributo de inmutable a dichos archivos (impide que se eliminen, se renombren, que se creen enlaces simbólicos hacia ellos o escribir datos en los mismos), de modo que no se puedan volver a instalar ni la clave GPG de Microsoft ni el repositorio:
    sudo chattr +i /etc/apt/trusted.gpg.d/microsoft.gpg
    sudo chattr +i /etc/apt/sources.list.d/vscode.list
  6. Podemos comprobar los nuevos atributos asignados a estos ficheros con
    lsattr /etc/apt/trusted.gpg.d/microsoft.gpg
    lsattr /etc/apt/sources.list.d/vscode.list
    que nos devolverán, respectivamente, lo siguiente:
    ----i--------e---- /etc/apt/trusted.gpg.d/microsoft.gpg
    ----i--------e---- /etc/apt/sources.list.d/vscode.list