Startpagina » hoe » Hoe een Raspberry Pi in een low-power netwerkopslagapparaat te veranderen

    Hoe een Raspberry Pi in een low-power netwerkopslagapparaat te veranderen

    Meng een Raspberry Pi en een flinke hoeveelheid goedkope externe harde schijven en u hebt het recept voor een apparaat met een ultra-laag en permanent netwerkopslag. Lees verder terwijl we u laten zien hoe u uw eigen op pi-gebaseerde NAS kunt instellen.

    Waarom wil ik dit doen??

    Het voordeel van een altijd aanwezig netwerkopslagapparaat is dat het uiterst handig is om uw gegevens (of back-upbestemming) altijd toegankelijk te hebben voor de computers binnen en buiten uw netwerk. Het nadeel is, in de meeste gevallen, dat je een behoorlijke hoeveelheid stroom verbruikt voor het gemak.

    Onze kantoorserver draait bijvoorbeeld 24/7 en verbruikt bijna $ 200 aan vermogen per jaar. Een op Raspberry Pi gebaseerd netwerkopslagapparaat aan de andere kant verbruikt ongeveer $ 5 aan vermogen per jaar.

    We zullen de eerste zijn om u te laten weten dat een volwaardige server meer opslagruimte en de mogelijkheid heeft om meer werk te doen (zoals het transcoderen van een videoboek van meerdere terabytes binnen een redelijke tijd). Voor de meeste mensen is het belangrijkste doel van het altijd thuis hebben van een computer die altijd in huis is, om te dienen als een bestandsserver en een repository voor bestandsback-ups. Voor dergelijke taken is de Raspberry Pi meer dan krachtig genoeg en bespaart u een groot deel van het stroomverbruik.

    Wat heb ik nodig?

    Deze tutorial bouwt voort op onze vorige tutorial: de HTG-handleiding om aan de slag te gaan met Raspberry Pi en we gaan ervan uit dat je dat al hebt gedaan - met andere woorden: je hebt al je Raspberry Pi, hebt hem ingeschakeld, verslaafd aan een muis en toetsenbord , en je hebt Raspbian erop geïnstalleerd.

    Naast de uitrusting die je nodig hebt in de handleiding Aan de slag met Raspberry Pi, zul je alleen de volgende hardware hebben:

    • Eén (minimaal) USB-externe harde schijf voor eenvoudige netwerkback-ups en bestandsservice

    of

    • Twee (minimaal) USB externe harde schijven voor lokale gegevensredundantie

    Dat is het! Als u alleen een eenvoudig op het netwerk aangesloten station wilt, hebt u slechts één harde schijf nodig. We raden ten zeerste aan om ten minste twee harde schijven te gebruiken om lokale (bij de Raspberry Pi) gegevensredundantie mogelijk te maken. Voor deze tutorial gebruiken we een bijpassend paar Seagate Backup Plus 1 TB draagbare externe harde schijven. Ze zijn superklein, hebben geen externe voedingsbron nodig en waren te koop toen we naar onderdelen aan het winkelen waren.

    Je kunt alle externe harde schijven gebruiken die je bij de hand hebt, maar het is ideaal om zo weinig mogelijk kleine energiezuinige schijven te gebruiken, omdat het hele thema van het project is om een ​​kleine en energiezuinige NAS op te zetten die je gewoon weg kunt stoppen en vergeten.

    Voordat we verder gaan, zijn er een aantal ontwerpkeuzes die we hebben gemaakt in termen van hoe we onze Raspberry Pi NAS configureren, waar je op moet letten. Hoewel de meeste gebruikers precies willen volgen zoals we het hebben gedaan, wilt u misschien specifieke stappen aanpassen om beter aan uw behoeften te voldoen en hoe u de computers in uw netwerk gebruikt..

    Ten eerste maken we gebruik van NTFS-geformatteerde harde schijven. Mocht de Raspberry Pi NAS om de een of andere reden falen of we willen snel informatie kopiëren via een USB 3.0-verbinding in plaats van via het netwerk. Het hebben van NTFS-geformatteerde schijven maakt het doodeenvoudig om de draagbare USB-drives die we gebruiken op de NAS-build te nemen en ze rechtstreeks in een van de vele Windows aan te sluiten machines die we elke dag gebruiken.

    Ten tweede gebruiken we Samba voor onze netwerkshares, wederom vanwege het gemak waarmee de Raspberry Pi NAS kan worden gekoppeld aan ons overwegend Windows-netwerk.

    Voorbereiding en montage van de externe harde schijven

    Zodra je de hardware hebt verzameld, gevolgd door de handleiding Aan de slag met Raspberry Pi om op snelheid te komen (en Raspian draait), is het tijd om je Pi als NAS te beginnen instellen.

    De eerste orde van zaken is om de harde schijven aan te sluiten op de Raspberry Pi (of de aangesloten USB-hub, afhankelijk van uw configuratie en of de harde schijven zelfaangedreven of extern gevoed zijn). Zodra de harde schijven zijn aangesloten en de Pi is ingeschakeld, is het tijd om aan het werk te gaan.

    Notitie: We gebruiken twee harde schijven. Als u hebt besloten om slechts één harde schijf te gebruiken, negeert u gewoon alle opdrachten in deze sectie die bedoeld zijn om de tweede harde schijf te activeren / wijzigen of op een andere manier te gebruiken..

    We gaan al ons werk doen binnen de terminal. Je kunt dus direct op je Raspberry Pi werken met LXTerminal in Raspian of je kunt SSH gebruiken in je Raspberry Pi met een tool als Putty. Beide manieren zijn prima.

    Als je eenmaal op de commandoregel staat, is het eerste dat je moet doen, het toevoegen van ondersteuning aan Rasbian voor NTFS-geformatteerde schijven. Typ hiervoor de volgende opdracht:

    sudo apt-get install ntfs-3g

    Het duurt een minuut of twee voordat de pakketten worden gedownload, uitgepakt en geïnstalleerd. Zodra het NTFS-pakket is geïnstalleerd, wordt het tijd om te zoeken naar de niet-gemonteerde partities van de aangesloten externe harde schijven.

    sudo fdisk -l

    Op zijn minst zou je twee schijven moeten zien, als je in een secundaire schijf hebt toegevoegd voor het spiegelen van gegevens (zoals we hebben) zou je er drie moeten zien zoals zo:

    De eerste schijf / Dev / mmcb1k0 is de SD-kaart in de Raspberry Pi die onze installatie van Raspbian huisvest. We laten die helemaal alleen achter.

    De tweede schijf, / Dev / sda is onze eerste 1TB externe harde schijf. De derde schijf, / Dev / sdb is onze tweede 1TB externe harde schijf. De feitelijke partities waarin we geïnteresseerd zijn, zijn deze / Sda1 / en / Sdb1 /, respectievelijk. Noteer de namen van de harde schijven.

    Voordat we de schijven kunnen aankoppelen, moeten we een map maken om de stations aan te koppelen. Eenvoudigheidshalve gaan we voor elke schijf eenvoudig de map USBHDD1 en USBHDD2 maken. Eerst moeten we de schijven maken. Voer op de opdrachtregel de volgende opdrachten in:

    sudo mkdir / media / USBHDD1

    sudo mkdir / media / USBHDD2

    Nadat u de twee mappen hebt gemaakt, is het tijd om de externe schijfeenheden op elke locatie te koppelen. Voer opnieuw op de opdrachtregel de volgende opdrachten in:

    sudo mount -t auto / dev / sda1 / media / USBHDD1

    sudo mount -t auto / dev / sdb1 / media / USBHDD2

    Op dit punt hebben we de twee externe harde schijven gekoppeld aan respectievelijk de USBHDD1- en USBHDD2-directory's. Het is tijd om een ​​specifieke map aan beide stations toe te voegen om onze gedeelde mappen te bewaren (om de zaken opgeruimd te houden en ons werk op de schijven te compartimenteren). Voer de volgende opdrachten in:

    sudo mkdir / media / USBHDD1 / shares

    sudo mkdir / media / USBHDD2 / shares

    Nu is het tijd om Samba te installeren, zodat we toegang hebben tot de opslag van elders in het netwerk. Voer de volgende opdrachtregel in:

    sudo apt-get installeer samba samba-common-bin

    Wanneer u wordt gevraagd om verder te gaan, typt u Y en voert u in. Leun achterover en ontspan terwijl alles uitpakt en wordt geïnstalleerd. Nadat het Samba-pakket is geïnstalleerd, is het tijd om een ​​kleine configuratie uit te voeren. Voordat we iets anders doen, laten we een reservekopie maken van het Samba-configuratiebestand voor het geval we het terug moeten halen. Typ de volgende opdrachtregel op de opdrachtregel:

    sudo cp /etc/samba/smb.conf /etc/samba/smb.conf.old

    Dit maakt eenvoudig een back-up van het configuratiebestand met de bestandsnaam smb.conf.old en laat het in dezelfde map staan ​​als het originele configuratiebestand.

    Zodra we de back-up hebben gemaakt, is het tijd om wat basisbewerkingen in het Samba-configuratiebestand uit te voeren. Typ het volgende op de opdrachtregel:

    sudo nano /etc/samba/smb.conf

    Hierdoor wordt de nano-teksteditor geopend en kunnen enkele eenvoudige wijzigingen worden doorgevoerd. Als dit de eerste keer is dat u Nano gebruikt, raden we u ten zeerste aan de Beginner's Guide to Nano, de Linux-opdrachtregeleditor, te raadplegen. In uw terminalvenster zou u zoiets als het volgende moeten zien:

    Nano is volledig toetsenbordgestuurd, gebruik de pijltjestoetsen om de cursor naar de locatie te verplaatsen die je wilt bewerken. Terwijl je door de configuratie-instellingen bladert, zie je er een paar die het waard zijn om te noteren of te veranderen.

    De eerste is de werkgroep-ID, standaard werkgroep = WERKGROEP. Als je een andere naam gebruikt voor je thuiswerkgroep, ga je gang en ga je met de pijl om dat nu te wijzigen, anders laat je het standaard staan.

    Onze volgende stop is om gebruikersauthenticatie in te schakelen voor onze samba-opslag, anders kan iedereen met algemene toegang tot ons netwerk (zoals gast-wifi-gebruikers) gewoon naar binnen lopen. Scroll naar beneden in het Samba-configuratiebestand totdat je bij de sectie die luidt:

    Verwijder het symbool # uit de regel security = user (markeer dit met de cursor en druk op delete) om de gebruikersnaam / wachtwoordverificatie voor de Samba-shares in te schakelen.

    Vervolgens gaan we een geheel nieuwe sectie aan het configuratiebestand toevoegen. Blader helemaal naar de onderkant van het bestand en voer de volgende tekst in:

    [Backup]
    comment = Back-upmap
    pad = / media / USBHDD1 / shares
    geldige gebruikers = @users
    force group = gebruikers
    maak masker = 0660
    mapmasker = 0771
    alleen lezen = nee

    Notitie: Wat u ook tussen de haakjes in de bovenste regel plaatst, wordt de naam van de map die wordt weergegeven op de netwerkshare. Als u een andere naam anders dan "Backup" wilt, is dit het moment om het te bewerken.

    Druk op CTRL + X om af te sluiten, druk op Y wanneer u wordt gevraagd of u wijzigingen wilt behouden en het bestaande configuratiebestand wilt overschrijven. Terug bij de opdrachtprompt voert u de volgende opdracht in om de Samba-daemons opnieuw te starten:

    sudo /etc/init.d/samba herstarten

    Op dit punt moeten we een gebruiker toevoegen die toegang heeft tot de samba-shares van de Pi. We gaan een account maken met de gebruikersnaamback-ups en de wachtwoordback-ups4ever. U kunt uw gebruikersnaam en wachtwoord maken wat u maar wilt. Typ hiervoor de volgende opdrachten:

    sudo useradd backups -m -G gebruikers

    sudo passwd back-ups

    U wordt gevraagd om het wachtwoord twee keer in te voeren om te bevestigen. Na het bevestigen van het wachtwoord, is het tijd om "back-ups" toe te voegen als een legitieme Samba-gebruiker. Voer de volgende opdracht in:

    sudo smbpasswd -a backups

    Voer het wachtwoord voor het back-upaccount in wanneer daarom wordt gevraagd. Nadat u het gebruikersaccount en wachtwoord hebt gemaakt, hoeft u de Samba-daemon niet opnieuw te starten, omdat we al hebben aangegeven dat u op zoek moet naar geverifieerde gebruikers. We kunnen nu op elk Samba-apparaat op ons netwerk springen en de connectiviteit testen met de netwerkshare.

    Vanuit een Windows-machine in de buurt hebben we de Windows-bestandsverkenner geopend, op Netwerk geklikt, bevestigd dat de hostnaam RASPBERRYPI in de werkgroep WERKGROEPEN stond en op de gedeelde map klikte Back-ups:

    Voer de referenties in die u in de vorige stap hebt gemaakt wanneer u hierom wordt gevraagd (als u de lijn volgt voor regel, zijn de aanmeldingsgegevens back-ups en is het wachtwoord back-ups4).

    Zodra uw inloggegevens zijn geaccepteerd, wordt u getrakteerd op een lege map omdat er nog niets in de share staat. Om te controleren of alles goed werkt, maken we een eenvoudig bestand vanaf de computer waarop we de verbinding hebben getest (in ons geval de Windows 7-desktop). Maak een txt-bestand zoals:

    Nu, vanaf de opdrachtregel die we al die tijd hebben gebruikt, laten we controleren of het bestand dat we op het Windows-bureaublad hebben gemaakt, correct wordt weergegeven in de gedeelde map die we hebben gemaakt. Typ de volgende opdracht op de opdrachtregel:

    cd / media / USBHDD1 / shares

    ls

    hello-is-het-mij-je-ziet-voor.txt staat in de map; ons eenvoudige gedeelde directory-experiment is een succes!

    Voordat we dit gedeelte van de tutorial verlaten, hebben we nog maar één ding te doen. We moeten onze Pi zo configureren dat wanneer deze opnieuw wordt gestart, de externe harde schijven automatisch worden gemount. Om dit te doen, moeten we de nano-editor opstarten en een snelle bewerking maken. Typ het volgende bij de opdrachtregel:

    sudo nano / etc / fstab

    Dit opent de bestandssysteemtabel in nano, zodat we een paar snelle ingangen kunnen toevoegen. Voeg in de nano-editor de volgende regels toe:

    / dev / sda1 / media / USBHDD1 auto noatime 0 0

    / dev / sda2 / media / USBHDD2 auto noatime 0 0

    Druk op CTRL + X om af te sluiten, druk op Y om te bewaren en overschrijf het bestaande bestand.

    Als u slechts één enkele harde schijf gebruikt voor eenvoudig delen van het netwerk zonder redundantie, dan is dat alles! U bent helemaal klaar met het configuratieproces en kunt beginnen te genieten van uw ultra-low power NAS.

    Uw Raspberry Pi NAS configureren voor eenvoudige gegevensredundantie

    Tot nu toe is onze Raspberry Pi NAS aangesloten op het netwerk, bestandsoverdracht werkt, maar er ontbreekt een opvallend iets. Die secundaire harde schijf is geconfigureerd maar zit volledig inactief.

    In dit gedeelte van de zelfstudie gebruiken we twee eenvoudige maar krachtige Linux-hulpmiddelen, rsync en cron, om onze Raspberry Pi NAS te configureren voor het uitvoeren van een nachtelijke gegevensspiegel uit de map / shares / op de primaire schijf naar de / shares / map op de secundaire schijf. Dit wordt geen realtime RAID-achtige gegevensspiegeling, maar een dagelijkse (of semi-dagelijkse) gegevensback-up naar de secundaire schijf is een prima manier om een ​​nieuwe laag gegevensbeveiliging toe te voegen.

    Allereerst moeten we rsync toevoegen aan onze Rasbian-installatie. Als dit de eerste keer is dat u rsync gebruikt en u wilt een beter overzicht van de opdracht, raden we u aan te controleren hoe u rsync kunt gebruiken om een ​​back-up te maken van uw gegevens op Linux.

    Voer de volgende opdracht in op de opdrachtregel:

    sudo apt-get install rsync

    Nadat rsync is geïnstalleerd, wordt het tijd om een ​​cron-taak in te stellen om het kopiëren van bestanden van USBHDD1 naar USBHDD2 te automatiseren. Voer de volgende opdracht in op de opdrachtregel:

    crontab -e

    De opdracht opent uw cron-planningstabel in de nano-teksteditor, die u op dit moment in de zelfstudie tamelijk bekend zou moeten zijn. Ga je gang en scrol omlaag naar de onderkant van het document en voer de volgende regel in:

    0 5 * * * rsync -av - delete / media / USBHDD1 / shares / media / USBHDD2 / shares /

    Deze opdracht geeft aan dat elke dag om 05:00 (de 0 5 deel), elke dag (* * *, jokertekens in het jaar, maand, dagspots), we willen dat rsync de twee mappen vergelijkt, alles van HDD1 kopieert naar HDD2 en alles in de back-upmap verwijderen dat niet langer overeenkomt met iets in de primaire map, dat wil zeggen als we een filmbestand op HDD1 hebben dat we verwijderen, willen we ook dat dat bestand bij de volgende synchronisatie uit de back-up wordt verwijderd.

    Het belangrijke deel over het configureren van deze opdracht is dat u een tijd selecteert die geen invloed heeft op andere netwerkactiviteiten voor de gedeelde mappen die u mogelijk hebt gepland. Als u bijvoorbeeld uw Raspberry Pi NAS als een back-upbestemming gebruikt voor een soort van geautomatiseerde software die uw bestanden elke ochtend om 5.00 uur naar de NAS kopieert, moet u de back-uptijd in uw back-up software aanpassen of moet u om de tijd voor de cron-taak op de Pi aan te passen, maar u kunt niet zowel de externe back-updumpgegevens op de netwerkshare plaatsen als de Raspberry Pi die gegevens tegelijkertijd tussen lokale stations proberen te synchroniseren.

    Nadat u het crontab-item hebt ingevoerd, klikt u op CTRL + X om af te sluiten en het bestand op te slaan. Als je de rsync onmiddellijk wilt uitvoeren om de gegevens sneller te laten spiegelen en de initiële cron-taak wat lichter op het systeem te maken, ga je gang en voer je hetzelfde rsync-commando als crtab in op de opdrachtregel:

    rsync -av - verwijderen / media / USBHDD1 / shares / media / USBHDD2 / shares /

    Dat is het! Het enige dat u op dit moment hoeft te doen, is om de volgende dag of twee in te checken op uw Raspberry Pi om er zeker van te zijn dat de geplande taak zoals verwacht wordt afgevuurd en de gegevens van / USBHDD1 / aandelen / verschijnt in / USBHDD2 / aandelen /.

    Vanaf nu wordt alles wat u in uw Raspberry Pi-gevoede NAS plaatst dagelijks over beide harde schijven gespiegeld.

    Voordat we het onderwerp volledig verlaten, volgen hier enkele aanvullende How-To Geek-artikelen die u misschien wilt bekijken om meer punch toe te voegen aan uw nieuwe Raspberry Pi-gevoede NAS:

    • Hoe een back-up te maken van je Gmail-account met je Ubuntu-pc - hoewel de instructies voor Ubuntu zijn, kun je ze eenvoudig aanpassen voor Rasbian om je Pi-NAS in een automatische e-mailback-upmachine te veranderen.
    • Welke bestanden moet u back-uppen op uw Windows-pc? -Als u niet zeker weet welke bestanden u moet back-uppen naar uw NAS, is dit een goed begin.
    • Hoe u op afstand uw gegevens op afstand kunt back-uppen met CrashPlan-CrashPlan is een gratis back-uptoepassing die beschikbaar is voor Windows-, Mac- en Linux-machines, waardoor het eenvoudig is om regelmatige back-ups naar een NAS te plannen.

    Heb je een Raspberry Pi-project dat je graag bij ons zou willen zien? Groot of klein, we spelen graag met de Pi-sound in de comments met jouw ideeën.