Table des matières:
- Fournitures
- Étape 1: Avantages et inconvénients
- Étape 2: Préparer la SD: Télécharger Raspbian
- Étape 3: Préparez la SD: Personnalisez la carte
- Étape 4: préparer le Raspberry Pi
- Étape 5: Voie 1: Connectez-vous au Pi à l'aide de l'écran, du clavier et de la souris
- Étape 6: Voie 2: Connectez-vous au Pi à l'aide de VNC depuis votre ordinateur
- Étape 7: préparer le disque dur
- Étape 8: Configurer Rsync: Créer un script de synchronisation
- Étape 9: Configurer Rsync: Effectuer une synchronisation une fois par jour
- Étape 10: préparer la samba
- Étape 11: [Facultatif] Samba: Configurer l'accès en lecture au lecteur réseau Vincent
- Étape 12: [Facultatif] Samba: Accès au journal
- Étape 13: [Facultatif] Samba: Masquer le dossier inutile "/home/pi"
- Étape 14: Accès au lecteur réseau à partir de Windows
- Étape 15: préparer la 2e machine
- Étape 16: Créer SSH entre la machine locale et distante
- Étape 17: Testez la synchronisation
- Étape 18: Configurer les routes Internet
- Étape 19: Bibliographie
2025 Auteur: John Day | [email protected]. Dernière modifié: 2025-01-13 06:57
But
- En cas d'incident à la maison, je souhaite pouvoir récupérer mes principaux documents numériques (photos, papiers d'identité, etc.), et éventuellement les partager.
- Je veux partager cette solution avec quelqu'un d'autre (quelqu'un en qui j'ai confiance, des parents ou un ami)
- Je ne veux pas dépendre d'un cloud public (abonnement, frais, CGV évolutives, etc.)
Principe
- Créez 2 machines de stockage identiques, placez-les dans 2 emplacements différents (par exemple, 2 maisons).
- Attribuez un espace de stockage dédié à chaque emplacement sur chaque machine.
- Synchronisez régulièrement les 2 espaces de stockage.
Fournitures
Matériel
Chaque machine possède:
- 1x Raspberry Pi 4B 1Go
- 1x boîte pour Raspberry Pi 4
- 1x alimentation USB C 5V 3A
- 1x carte SD Kingston SDC10/16 Go
- 1x NAS HDD 1To WD Mobile Rouge
- 1x boîtier de disque dur BX-2525U3
Logiciel Windows
- balena Graveur
- Bureau Raspbian buster plein
- mobaxterme
- Visionneuse VNC (facultatif)
Forfaits Raspbian
- Rsync
- samba
Étape 1: Avantages et inconvénients
Avantages
- Cette solution n'est pas chère: je n'ai pas de frais d'abonnement et le matériel est abordable.
- Ce "RAID distant" est assez simple à réaliser. Je n'ai pas besoin de matériel ou d'outil supplémentaire pour le faire.
- Le Raspberry Pi peut être utilisé pour des applications supplémentaires comme le media center (kodi, …), ou la domotique (jeedom, domoticz, …).
- Mes données ne sont pas disponibles sur un cloud public qui pourrait être la cible d'un piratage massif de données.
- Avec un disque dur de 1To, la consommation électrique moyenne est la même qu'un cloud.
- Le firewall de mon routeur et le cryptage SSH de ma connexion sécurise les échanges de données.
Inconvénients/améliorations
- Quelqu'un d'autre a une copie de mes documents. Dans mon cas, cette personne est de ma famille donc je m'en fiche.
- J'utilise le compte "pi" par défaut, avec un mot de passe dédié pour les deux machines. Je pourrais sécuriser un peu plus l'accès en utilisant un compte spécifique séparé de chaque côté plutôt que le compte "pi".
- Je m'appuie sur mon fournisseur d'accès Internet et le cryptage SSH pour la sécurité de la connexion entre les 2 maisons. Des recherches peuvent être effectuées pour améliorer le niveau de sécurité.
- Pour l'instant, je n'ai fait que 2 partitions par lecteur. Une 3ème partition plus petite (~5Go) pourrait être utile pour d'autres activités Raspbian, afin de préserver la carte µSD.
Étape 2: Préparer la SD: Télécharger Raspbian
Depuis un ordinateur (Windows 10 dans mon cas), suivez le guide d'installation officiel (https://www.raspberrypi.org/downloads/raspbian/) pour installer "Raspbian Buster with desktop".
Ajoutez un fichier vide nommé "ssh" dans le disque "/boot/"
Ajoutez un fichier nommé "wpa_supplicant.conf" dans le disque "/boot/"
Ouvrez wpa_supplicant.conf et saisissez le texte:
pays=États-Unis
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev update_config=1 network= { ssid="MyWiFiNetwork" psk="aVeryStrongPassword" key_mgmt=WPA-PSK }
Enregistrez et fermez le fichier.
Étape 3: Préparez la SD: Personnalisez la carte
Ajoutez un fichier vide nommé "ssh" dans le disque "/boot/"
Ajoutez un fichier nommé "wpa_supplicant.conf" dans le disque "/boot/"
Ouvrez wpa_supplicant.conf et saisissez le texte:
pays=États-Unis
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev update_config=1 network= { ssid="MyWiFiNetwork" psk="aVeryStrongPassword" key_mgmt=WPA-PSK }
Enregistrez et fermez le fichier.
Étape 4: préparer le Raspberry Pi
Insérez votre carte SD dans le Pi
Allumez le Raspberry Pi, choisissez un moyen d'ouvrir un bureau:
- Utilisation d'un câble HDMI, d'un écran, d'un clavier et d'une souris
- Utilisation de VNC depuis votre ordinateur.
Pour plus d'informations, visitez
Étape 5: Voie 1: Connectez-vous au Pi à l'aide de l'écran, du clavier et de la souris
Connectez le port Raspberry Pi HDMI0 à un écran avec un câble micro-hdmi vers hdmi
Branchez un clavier et une souris USB (ou un mini clavier sans fil comme un "Rii Mini i8 Wireless")
Branchez l'alimentation USB C et allumez le Raspberry Pi.
Raspbian doit démarrer sur votre écran.
Une fois le bureau affiché, répondez au panneau de configuration pour terminer la configuration de votre Pi.
Étape 6: Voie 2: Connectez-vous au Pi à l'aide de VNC depuis votre ordinateur
Connectez le Raspberry Pi à votre réseau ethernet (par wifi ou avec un câble).
Depuis votre ordinateur, ouvrez Mobaxterm (ou putty), démarrez une nouvelle connexion ssh (login pi, mot de passe raspberry) et configurez votre Pi:
ssh pi@raspberry_ip
sudo raspi-config
- dans l'option Interfaçage / VNC: définir Oui
- dans Options avancées / Résolution: définissez le mode DMT 82 1920x1080 60Hz 16:9
- dans Options avancées/pilote GL: définissez le lecteur de bureau non-GL G1 Legacy Original
Enregistrer et quitter raspi-config
Redémarrez le Pi:
redémarrage sudo
Depuis votre ordinateur, ouvrez VNC Viewer, et connectez-vous au Pi en utilisant le login pi, mot de passe raspberry: le bureau Pi devrait apparaître.
Répondez au panneau de configuration pour terminer la configuration de votre Pi.
Une fois que vous avez modifié le mot de passe Pi, la connexion VNC peut se fermer. Redémarrez-le en utilisant votre nouveau mot de passe.
Étape 7: préparer le disque dur
- Connectez le disque dur à votre ordinateur.
- Ouvrez le gestionnaire de partition Windows, sélectionnez votre disque dur et créez 2 partitions NTFS (ou 3, si vous voulez un petit espace libre pour préserver la carte µSD). Par exemple, je nomme les 2 parties "loic" et "vincent"
- Connectez le disque dur au Pi: Raspbian devrait monter automatiquement 2 disques sur le bureau. Les lecteurs sont liés au dossier /media/pi/loic/, et /media/pi/vincent/
Étape 8: Configurer Rsync: Créer un script de synchronisation
ouvrir une invite sur le bureau Pi
Dans /home/pi/, créez un script:
mkdir /home/pi/scriptsnano /home/pi/scripts/SB_sync
saisissez le texte:
#!/bin/sh
######## UN CONFIGURATEUR ########### ip_distante="192.168.0.19" port_distant="xxxxx" media_local="/media/pi/loic" media_distant="pi@${ ip_distante}:/media/pi/loic" machine_locale="RPi4_loic" machine_distante="RPi4_vincent" ################################ ## log_local="/home/pi/SB_sync_logs"log_distant="pi@${ip_distante}:/home/pi/SB_sync_logs" currentDate=`date+"%Y-%m-%d %T"`mkdir -p / home/pi/SB_sync_logs #synchro de ${machine_locale} ${media_local}/ vers ${machine_distant} ${media_distant}/ echo $currentDate> ${log_local}/0.synchro_en_cours_${machine_locale}_vers_${machine_distante} echo " Synchronisation en cours: de ${machine_locale} ${media_local}/ vers ${machine_distant} ${media_distant}/ " >> ${log_local}/0.synchro_en_cours_${machine_locale}_vers_${machine_distante} ${machine_distante} ${ media_distant}/ " >> ${log_distant}/0.synchro_en_cours_${machine_locale}_vers_${machine_distante} echo "Compte `whoami`" > ${log_local}/1.${machine_locale}_vers_${machine_distante}.log echo "--------- -Début: "`date +"%Y-%m-%d %T"`"----------" >> ${log_local}/1.${machine_locale}_vers_${machine_distante}.log /usr/bin/rsync -avhPS --chmod=a+rwx --delete -e "ssh -p ${port_distant}" ${media_local}/${media_distant}/ 2>&1 >> ${log_local} /1.${machine_locale}_vers_${machine_distante}.log
echo "----------Fin: "`date +"%Y-%m-%d%T"`"----------" >> ${log_local}/ 1.${machine_locale}_vers_${machine_distante}.log
rm ${log_local}/0.synchro_en_cours_${machine_locale}_vers_${machine_distante}
Configurer les lignes 3 à 7:
- remplacez "loic" et "vincent" par le nom de votre lecteur
- port_distant: pour l'instant, utilisez 22 comme port distant. A la dernière étape, vous devrez le remplacer par une autre valeur de votre choix (exemple: 34567)
enregistrer le fichier et quitter.
Étape 9: Configurer Rsync: Effectuer une synchronisation une fois par jour
Dans l'invite, ouvrez crontab:
sudo crontab -u pi -e
à la fin du fichier, ajoutez un cron:
0 1 * * * /usr/bin/flock -xn /tmp/flocktmp.lock -c"/home/pi/scripts/SB_sync"
Dans ce cron, le script SB_sync sera lancé tous les jours à 1h00 du matin. Choisissez l'heure que vous voulez, mais changez-la entre les 2 machines, ainsi les 2 synchros seront effectuées l'une après l'autre.
Enregistrez et fermez le fichier.
Étape 10: préparer la samba
Samba connecte un stockage Linux au réseau Windows.
Ouvrez une invite et installez les packages:
sudo apt-get install samba samba-common-bin -y
Autoriser le compte "pi" pour accéder à Samba:
sudo smbpasswd -a pi
Enregistrez le fichier de configuration Samba par défaut:
cp /etc/samba/smb.conf /etc/samba/smb.old
Ouvrez le fichier:
sudo nano /etc/samba/smb.conf
Et à la fin du fichier, ajoutez ces lignes pour configurer votre lecteur à partager:
[DOCUMENTS LOI]
comment = NAS de loic path = /media/pi/loic valid users = @users force group = users create mask = 0660 directory mask = 0775 read only = no Browseable = yes public = yes
Enregistrez le fichier et quittez.
Étape 11: [Facultatif] Samba: Configurer l'accès en lecture au lecteur réseau Vincent
Ouvrez le fichier de configuration Samba:
sudo nano /etc/samba/smb.conf
Et à la fin du fichier, ajoutez ces lignes pour configurer l'autre lecteur auquel vous souhaitez accéder:
[DOCUMENTS VINCENT]
comment = backup de vincent path = /media/pi/vincent valid users = @users force group = users create mask = 0660 directory mask = 0775 read only = yes navigable = yes public = yes
Enregistrez le fichier et quittez.
Étape 12: [Facultatif] Samba: Accès au journal
Ouvrez le fichier de configuration Samba:
sudo nano /etc/samba/smb.conf
Et à la fin du fichier, ajoutez ces lignes pour accéder depuis windows au status synchro:
[LOG SYNCHRO]comment = "logs de synchro entre machines"
path = /home/pi/SB_sync_logs/ valid users = @users force group = users create mask = 0660 directory mask = 0771 read only = yes navigable = yes public = yes
Enregistrez le fichier et quittez.
Étape 13: [Facultatif] Samba: Masquer le dossier inutile "/home/pi"
Ouvrez le fichier de configuration Samba:
sudo nano /etc/samba/smb.conf
Dans le fichier, recherchez les lignes suivantes et ajoutez ";" au début pour le commenter:
;[maisons]
; comment = Répertoires personnels; navigable = non; lecture seule = oui; créer un masque = 0700; masque de répertoire = 0700; utilisateurs valides = %S
Enregistrez le fichier et quittez.
Étape 14: Accès au lecteur réseau à partir de Windows
Depuis un ordinateur Windows, ouvrez un explorateur.
Cliquez sur "Réseau" et rafraîchissez la fenêtre.
Un ordinateur portant le nom de votre Rapberry Pi apparaîtra.
Ouvrez-le en utilisant le compte "pi" et votre mot de passe.
Vous devriez voir les dossiers ajoutés précédemment dans le fichier de configuration Samba.
Étape 15: préparer la 2e machine
Votre 1ère machine est prête.
Répétez les étapes précédentes pour la 2ème machine, en remplaçant (par exemple) "loic" par "vincent".
Une fois les 2 machines préparées, vous devrez échanger la clé ssh pour autoriser l'accès entre elles, voir étape suivante.
Étape 16: Créer SSH entre la machine locale et distante
Pour simplifier le partage de clé SSH, chaque Raspberry Pi doit être connecté au même réseau Ethernet.
Sur chaque Raspberry Pi, ouvrez une invite sur le bureau Pi et entrez:
ssh-keygen -q -t rsa -b 2048 -N ''
ssh-copy-id pi@IP_of_other_raspberry
Étape 17: Testez la synchronisation
Vos 2 machines sont prêtes.
Vous pouvez tester la synchro sur votre ordinateur Windows:
- ajouter un fichier dans votre lecteur réseau local (i.e. \Rpi4-loic\documents loic\test\test.txt),
- exécutez le script sur votre bureau Pi local (exécutez SB_sync dans /home/pi/scripts)
- vérifiez que votre fichier apparaît dans le lecteur réseau de sauvegarde (i.e. \Rpi4-vincent\documents loic\test\test.txt).
Vous devriez pouvoir lire et écrire des fichiers dans \Rpi4-loic\documents loic\test\, mais seulement lire des fichiers dans \Rpi4-vincent\documents loic\test\.
La prochaine et dernière étape consiste à déplacer la machine "distante" à l'intérieur d'un réseau d'un autre endroit et à configurer une connexion entre les 2 routeurs via Internet.
Étape 18: Configurer les routes Internet
Dans mon cas, pour la machine locale à la maison, je souscris à un accès internet comprenant un routeur et une IP fixe.
Pour la machine distante, le fournisseur d'accès Internet est le même, donc la configuration est plus facile et je n'ai pas besoin de DNS.
Dans ma maison:
- Dans mon routeur, je crée une route de port de "remote_internet_fixed_IP" à "port_34567" à "my_raspberry_IP" au port "22"
- Dans ma framboise, dans /home/pi/scripts/SB_sync, je remplace la valeur "port_distant" "22" par "port_34567"
Dans l'endroit éloigné:
- Dans le routeur, je crée une route de port de "my_internet_fixed_IP" à "port_34567" à "my_raspberry_IP" au port "22"
- Dans le raspberry distant, dans /home/pi/scripts/SB_sync, je remplace la valeur "port_distant" "22" par "port_34567"
Pour votre candidature:
- Vous devez remplacer les IP et le port_34567 par les vôtres.
- En cas d'IP Internet dynamique, vous devez vous abonner à un DNS.
Avec l'aide du propriétaire de la framboise distante, répétez le test de l'étape précédente.
Fini!
Étape 19: Bibliographie
Installer Raspbian sur la carte µSD
Personnaliser la carte µSD après le formatage (SSH et WiFi)
Utiliser votre Raspberry Pi
Raspberry Pi Sync avec rysnc par feralhosting
Port SSH spécifique pour Rsync
Installer et utiliser Samba