Delte drev med høj tilgængelighed ved hjælp af Vultr Block Storage og GlusterFS

GlusterFS er et netværkstilsluttet filsystem, som effektivt giver dig mulighed for at dele to drev på tværs af flere enheder på netværket. Dette filsystem passer perfekt til Vultrs bloklagringstilbud, da du er i stand til at dele et drev på tværs af netværket, hvilket ikke er muligt direkte fra kassen.

Med hensyn til funktioner, udvidelsesmuligheder og pålidelighed har GlusterFS vist sig at være et af de mest sofistikerede og stabile filsystemer, der findes.

Når der foretages ændringer på drevet på en server, vil de automatisk blive replikeret til den anden server i realtid. For at opnå dette og følge denne vejledning skal du bruge:

  • To Vultr cloud-instanser, der helst kører det samme operativsystem.
  • To bloklagerdrev af samme størrelse.

Efter at have bestilt disse to bloklagringsdrev, skal du vedhæfte dem til VM 1 og VM 2. Da vi vil bruge begge bloklagerdrev til det samme filsystem, vil dividering af den samlede størrelse af begge drev med to give dig den brugbare mængde af GB'er. For eksempel, hvis du har to 100 GB-drev, vil 100 GB kunne bruges (100 * 2 / 2).

Desuden skal begge VM'er være på samme placering, for at de kan være på det samme private netværk. Vi vil oprette forbindelse til serverne ved hjælp af deres interne IP-adresser. Bemærk, at vi sletter dataene på bloklagerdrevet. Sørg for, at de er helt nye og uformaterede.

I denne vejledning vil vi bruge storage1og storage2, henholdsvis med private IP-adresser 10.0.99.10 og 10.0.99.11. Dine servernavne og IP-adresser vil højst sandsynligt afvige, så sørg for at ændre dem i processen med at konfigurere GlusterFS.

Denne vejledning er skrevet med CentOS / RHEL 7 i tankerne. GlusterFS er dog relativt krydskompatibel på tværs af flere Linux-distributioner.

Opsætning af GlusterFS

Trin 1: Rediger /etc/hostsfilen

For at vi hurtigt skal kunne oprette forbindelse til de respektive instanser, bør vi tilføje navne, der er nemme at huske, til hostsfilen. Åbn /etc/hostsfilen og tilføj følgende linjer til bunden af ​​den:

10.0.99.10 storage1
10.0.99.11 storage2

Trin 2: Tilføj disken storage1

SSH ind i storage1og udfør følgende kommandoer. Som standard er tilsluttede bloklagerdrev monteret som /dev/vdb. Hvis dette af en eller anden grund afviger i dit tilfælde, bør du ændre det i kommandoerne nedenfor.

Formater disken:

fdisk /dev/vdb

Tryk på "enter" for de følgende tre spørgsmål (vedrørende partitionsstørrelse og lignende ønsker vi at bruge al tilgængelig plads på bloklagerdrevene) og skriv "w" for at skrive disse ændringer til disken. Efter at dette er blevet gennemført, skriv:

/sbin/mkfs.ext4 /dev/vdb1

Vi er gået videre og oprettet et filsystem nu, da Vultr som standard ikke opretter nogen filsystemer på bloklager.

Dernæst skal vi oprette den mappe, vi vil gemme vores filer på. Du kan ændre dette navn, men du vil ikke se det forekomme meget, så for at eliminere kompleksiteten anbefaler jeg at lade det være.

mkdir /glusterfs1

For automatisk at montere drevet ved opstart skal du åbne /etc/fstabog tilføje følgende linje i bunden af ​​filen:

/dev/vdb1 /glusterfs1      ext4    defaults        1 2

Til sidst monterer du drevet:

mount -a

Monteringen vil forblive vedvarende på tværs af genstarter, så når du genstarter din server, vil drevet automatisk blive monteret igen.

Trin 3: Tilføj disken storage2

Nu hvor vi har tilføjet og monteret disken på storage1, skal vi også oprette disken på storage2. Kommandoerne er næppe forskellige. For fdisk, følg de samme trin som ovenfor.

fdisk /dev/sdb
/sbin/mkfs.ext4 /dev/sdb1
mkdir /glusterfs2

Rediger /etc/fstabog tilføj følgende linje:

/dev/vdb1 /glusterfs2      ext4    defaults        1 2

Ligesom på storage1, vil drevet automatisk blive monteret på tværs af genstarter.

Monter drevet:

mount -a

Lad os endelig tjekke, om vi kan se partitionen dukke op:

df -h

Du bør se dit drev dukke op her. Hvis det ikke gør det, så prøv at følge trinene fra oven.

Trin 4: Installation af GlusterFS på storage1ogstorage2

Vi skal installere GlusterFS næste gang. Tilføj depotet og installer GlusterFS:

rpm  -ivh  http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm
wget -P /etc/yum.repos.d http://download.gluster.org/pub/gluster/glusterfs/3.7/3.7.5/CentOS/glusterfs-epel.repo
yum -y install glusterfs glusterfs-fuse glusterfs-server

Der er en chance for, at du får en fejl, yumfordi signaturen for depotet ikke er rigtig. I så fald er det sikkert at tvinge til ikke at tjekke for GPG-signaturen:

yum -y install glusterfs glusterfs-fuse glusterfs-server --nogpgcheck

På begge servere skal du udføre følgende kommandoer for at starte GlusterFS lige nu og starte det automatisk efter en genstart:

systemctl enable glusterd.service
systemctl start glusterd.service

Hvis du bruger en ældre version af CentOS, kan du bruge serviceog chkconfigkommandoer:

chkconfig glusterd on
service glusterd start

Trin 5: Deaktivering af firewallen på storage1ogstorage2

Selvom det ikke er den bedste løsning i sig selv, er det en god idé at slukke for firewallen for at eliminere mulige konflikter med blokerede porte. Hvis du ikke føler dig tryg ved at gøre dette, så er du velkommen til at ændre reglerne efter din smag, men på grund af GlusterFS' natur anbefaler jeg stærkt at deaktivere firewall'en. I betragtning af at et privat netværk faktisk er privat på Vultr (og du ikke behøver at firewall ud andre kunder), kan du simpelthen blokere al indgående trafik fra internettet og begrænse tilladte forbindelser til det private netværk. Det er dog også tilstrækkeligt at slukke for firewallen og ikke ændre andre systemkonfigurationer:

systemctl stop firewalld.service
systemctl disable firewalld.service

Hvis du bruger en ældre CentOS version, som ikke understøtter systemctl, skal du bruge serviceog chkconfigkommandoer:

service firewalld stop
chkconfig firewalld off

Hvis du ikke bruger firewalld, prøv at deaktivere iptables:

service iptables stop
chkconfig iptables off

Trin 6: Tilføj servere til lagerpuljen

Efter at have slukket firewallen, er vi i stand til at tilføje begge servere til lagerpuljen. Dette er en pool bestående af al tilgængelig opbevaring. Udfør følgende kommando på storage1:

gluster peer probe storage2

Hvad denne kommando gør, er at tilføje storage2til sin egen lagerpulje. Ved at udføre følgende kommando på storage2vil begge drev være synkroniseret:

gluster peer probe storage1

Efter at have udført dette på begge servere, bør vi kontrollere status på begge servere:

gluster peer status

Begge servere bør vise tilstanden "Peers: 1". En almindelig fejl er, at folk forventer at se Peers: 2, men som det storage1vil være at peere med storage2og omvendt, peer de ikke med sig selv. Derfor Peers: 1er det, vi har brug for.

Trin 7: Oprettelse af et fællesdrev på storage1

Nu hvor begge servere er i stand til at forbinde med hinanden gennem GlusterFS, vil vi oprette et fælles drev.

Til storage1, udfør:

gluster volume create mailrep-volume replica 2  storage1:/glusterfs1/files  storage2:/glusterfs2/files force

Volumen er nu oprettet. I GlusterFS skal du "starte" en diskenhed, så den aktivt deles på tværs af flere enheder. Lad os starte det:

gluster volume start mailrep-volume

Vælg derefter en mappe, der skal være på diskenheden og replikeres på tværs af begge servere. I denne øvelse bruger vi mappen /var/files. Det kan naturligvis være alt, hvad du kan lide. Opret det storage1 kun på :

mkdir /var/files

Monter det derefter:

mount.glusterfs storage1:/mailrep-volume /var/files/

Opdater, /etc/fstabså drevet automatisk bliver monteret ved opstart. Tilføj følgende:

storage1:/mailrep-volume /var/files glusterfs defaults,_netdev 0 0

Genmonter drevet:

mount -a

Trin 8: Oprettelse af et fællesdrev på storage2

Nu hvor vi har oprettet et fællesdrev på storage1, skal vi også oprette et på storage2. Opret en mappe med samme placering/sti og navn:

mkdir /var/files
mount.glusterfs storage2:/mailrep-volume /var/files/

Ligesom på storage1, tilføj følgende linje til /etc/fstab:

storage2:/mailrep-volume /var/files glusterfs defaults,_netdev 0 0

Genmonter drevet:

mount -a

Trin 9: Test det delte lager

Naviger til /var/filesmappen på storage1og opret en fil:

cd /var/files
touch created_on_storage1

Gå derefter over til storage2serveren. Udfør, ls -laog du skulle se filen created_on_storage1vises.

storage2, naviger til /var/filesmappen og opret en fil:

cd /var/files
touch created_on_storage2

Gå tilbage til storage1og udfør ls -la /var/files. Du bør se filen created_on_storage2vises her.

Trin 10: Genstart alle servere (valgfrit)

For at dobbelttjekke, om din opsætning forbliver vedholdende på tværs af genstarter, bør du som en bedste praksis genstarte alle servere. Som nævnt skal du vente på, at den ene server er oppe og derefter genstarte den anden, for at det delte drev automatisk bliver monteret.

Genstart storage1først, vent til den er oppe, og genstart derefter storage2. Log nu på og kør på begge servere:

cd /var/files
ls -la

Du skulle nu se begge filer vises. Sørg for at starte uden nogen filer på diskenheden, så fjern de testfiler, vi har oprettet. Du kan gøre dette på storage1, storage2eller begge dele. Ændringer vil blive replikeret øjeblikkeligt:

cd /var/files
rm created_on_storage1
rm created_on_storage2

Du bør have en identisk delt volumen på tværs af begge servere, uanset handlingerne på begge diskenheder.

Du har nu opsat en fuldgyldig GlusterFS-opsætning med 100 GB (eller mere) brugbar plads. Hvis du har brug for mere i fremtiden, er opsætningen let skalerbar for at tilføje mere kapacitet og/eller flere servere, hvis din arbejdsbyrde kræver dette.

Tak fordi du læste!


Vigtig bemærkning vedrørende genmontering

GlusterFS giver mulighed for at holde dine data opdaterede på to drev. Du skal dog bemærke, at når begge servere genstartes på samme tid , bliver du nødt til at tvinge drevene på begge servere. Du skal tvinge monteringen manuelt ved at udføre følgende kommando:

gluster volume start mailrep-volume force

Det er fordi en af ​​serverne fungerer som en server, og den anden fungerer som en klient. Selvom forskellen ikke er mærkbar i praksis, betyder det, at når du skal genstarte begge servere, skal du genstarte den ene, vente til den er oppe, og derefter starte den anden.

Vigtig bemærkning vedrørende sikkerhedskopiering

Selvom dine data vil blive replikeret på tværs af to drev, bør du have dine data replikeret mindst tre gange. Selvom dine data er bedre beskyttet mod datakorruption og lignende, skal du være opmærksom på, at ændringer er øjeblikkelige, og du vil på ingen måde være beskyttet mod menneskelige fejl. Når du fjerner alle filer på det ene drev, vil disse ændringer straks blive replikeret til det andet drev, hvilket betyder, at dine data vil blive slettet på begge forekomster.

Heldigvis er der flere måder at undgå dette på. Først og fremmest anbefaler jeg at aktivere sikkerhedskopier på selve din cloud-instans. Selvom disse sikkerhedskopier ikke inkluderer data på bloklageret, vil det beskytte data på selve instansen.

Når det kommer til at sikkerhedskopiere dataene på selve bloklageret, anbefaler jeg at spinne en separat instans op (for eksempel en SATA-plan), så du for eksempel kan køre en backup fra en af ​​de to tilknyttede servere hver nat. På denne måde vil dine data være sikre på en anden separat enhed.

FAQ

Er jeg i stand til at øge min disklagerplads?

Du er i stand til at øge bloklagerstørrelsen fra Vultr-kontrolpanelet. Du bør ændre størrelsen på disken inde i operativsystemet efter, men det er uden for denne artikels omfang.

Kan jeg tilslutte bloklageret til over to servere?

Selvom denne vejledning er skrevet til to servere (altså to bloklagringsdrev knyttet til begge servere), men det er også muligt at tage denne vejledning og bruge den til over to servere. En opsætning med over to servere/drev kunne se sådan ud for 6 servere, for eksempel:

VM: storage1
VM: storage2
VM: storage3
VM: storage4
Block Storage: attached to storage1
Block Storage: attached to storage2
Block Storage: attached to storage3
Block Storage: attached to storage4

Givet at alle bloklagerdrev har en kapacitet på f.eks. 200 GB, ville du få 200 * 4 / 4. Med andre ord er den brugbare plads altid kapaciteten af ​​et enkelt bloklagerdrev. Det skyldes, at en server med tilknyttet bloklager behandles som "master" af GlusterFS, og den replikeres på tværs af de andre servere. Opsætningen er dog bygget til at kunne overleve uden en masterserver, hvilket gør det til en så redundant og pålidelig, stabil løsning.


Installer Plesk på CentOS 7

Installer Plesk på CentOS 7

Bruger du et andet system? Plesk er et proprietært webhost kontrolpanel, der giver brugerne mulighed for at administrere deres personlige og/eller klienters websteder, databaser

Sådan installeres Squid Proxy på CentOS

Sådan installeres Squid Proxy på CentOS

Squid er et populært, gratis Linux-program, der giver dig mulighed for at oprette en webproxy til videresendelse. I denne vejledning vil du se, hvordan du installerer Squid på CentOS for at gøre dig

Sådan installeres Lighttpd (LLMP Stack) på CentOS 6

Sådan installeres Lighttpd (LLMP Stack) på CentOS 6

Introduktion Lighttpd er en forgrening af Apache, der sigter mod at være meget mindre ressourcekrævende. Den er let, deraf navnet, og den er ret enkel at bruge. Installer

Konfiguration af statisk netværk og IPv6 på CentOS 7

Konfiguration af statisk netværk og IPv6 på CentOS 7

VULTR har for nylig foretaget ændringer i deres ende, og alt skulle nu fungere fint ud af boksen med NetworkManager aktiveret. Skulle du ønske at deaktivere

Ændring af Icinga2 til at bruge Master/Client Model på CentOS 6 eller CentOS 7

Ændring af Icinga2 til at bruge Master/Client Model på CentOS 6 eller CentOS 7

Icinga2 er et kraftfuldt overvågningssystem, og når det bruges i en master-klient-model, kan det erstatte behovet for NRPE-baserede overvågningstjek. Mester-klienten

Sådan installeres Apache Cassandra 3.11.x på CentOS 7

Sådan installeres Apache Cassandra 3.11.x på CentOS 7

Bruger du et andet system? Apache Cassandra er et gratis og open source NoSQL-databasestyringssystem, der er designet til at give skalerbarhed, høj

Sådan installeres Microweber på CentOS 7

Sådan installeres Microweber på CentOS 7

Bruger du et andet system? Microweber er en open source træk og slip CMS og online shop. Microweber-kildekoden er hostet på GitHub. Denne guide vil vise dig

Sådan installeres Mattermost 4.1 på CentOS 7

Sådan installeres Mattermost 4.1 på CentOS 7

Bruger du et andet system? Mattermost er et open source, selvhostet alternativ til Slack SAAS-meddelelsestjenesten. Med andre ord, med Mattermost er du ca

Oprettelse af et netværk af Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Oprettelse af et netværk af Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Hvad skal du bruge En Vultr VPS med mindst 1 GB RAM. SSH-adgang (med root/administrative rettigheder). Trin 1: Installation af BungeeCord Første ting først

Lad os kryptere på Plesk

Lad os kryptere på Plesk

Plesk-kontrolpanelet har en meget flot integration til Lets Encrypt. Lets Encrypt er en af ​​de eneste SSL-udbydere, der udleverer certifikater komplet

Lader kryptere på cPanel

Lader kryptere på cPanel

Lets Encrypt er en certifikatmyndighed dedikeret til at levere SSL-certifikater gratis. cPanel har bygget en pæn integration, så du og din klient

Sådan installeres Concrete5 på CentOS 7

Sådan installeres Concrete5 på CentOS 7

Bruger du et andet system? Concrete5 er et open source CMS, som tilbyder mange karakteristiske og nyttige funktioner til at hjælpe redaktører med at producere indhold nemt og

Sådan installeres Review Board på CentOS 7

Sådan installeres Review Board på CentOS 7

Bruger du et andet system? Review Board er et gratis og open source-værktøj til gennemgang af kildekode, dokumentation, billeder og mange flere. Det er webbaseret software

Konfigurer HTTP-godkendelse med Nginx på CentOS 7

Konfigurer HTTP-godkendelse med Nginx på CentOS 7

I denne vejledning lærer du, hvordan du opsætter HTTP-godkendelse for en Nginx-webserver, der kører på CentOS 7. Krav For at komme i gang skal du bruge

Sådan installeres YOURLS på CentOS 7

Sådan installeres YOURLS på CentOS 7

YOURLS (Your Own URL Shortener) er en open source URL-forkortelse og dataanalyseapplikation. I denne artikel vil vi dække installationsprocessen

Sådan installeres og konfigureres ArangoDB på CentOS 7

Sådan installeres og konfigureres ArangoDB på CentOS 7

Bruger du et andet system? Introduktion ArangoDB er en open source NoSQL-database med en fleksibel datamodel for dokumenter, grafer og nøgleværdier. det er

Brug af Etckeeper til versionskontrol af /etc

Brug af Etckeeper til versionskontrol af /etc

Introduktion /etc/-biblioteket spiller en afgørende rolle i den måde et Linux-system fungerer på. Årsagen til dette er, at næsten alle systemkonfigurationer

Hvorfor skal du bruge SSHFS? Sådan monteres et eksternt filsystem med SSHFS på CentOS 6

Hvorfor skal du bruge SSHFS? Sådan monteres et eksternt filsystem med SSHFS på CentOS 6

Mange systemadministratorer administrerer store mængder servere. Når filer skal tilgås på tværs af forskellige servere, logges ind på hver enkelt individuelt ca

Opsætning af en Half Life 2-server på CentOS 6

Opsætning af en Half Life 2-server på CentOS 6

Denne vejledning vil dække processen med at installere en Half Life 2-spilserver på CentOS 6 System. Trin 1: Installation af forudsætninger For at opsætte ou

Sådan installeres Laravel GitScrum på CentOS 7

Sådan installeres Laravel GitScrum på CentOS 7

Laravel GitScrum eller GitScrum er et open source-produktivitetsværktøj designet til at hjælpe udviklingsteams med at implementere Scrum-metoden på en måde, der ligner t.

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Kunstig intelligens er ikke i fremtiden, det er her lige i nuet I denne blog Læs, hvordan kunstig intelligens-applikationer har påvirket forskellige sektorer.

DDOS-angreb: et kort overblik

DDOS-angreb: et kort overblik

Er du også et offer for DDOS-angreb og forvirret over forebyggelsesmetoderne? Læs denne artikel for at løse dine spørgsmål.

Har du nogensinde spekuleret på, hvordan tjener hackere penge?

Har du nogensinde spekuleret på, hvordan tjener hackere penge?

Du har måske hørt, at hackere tjener mange penge, men har du nogensinde spekuleret på, hvordan tjener de den slags penge? lad os diskutere.

Revolutionære opfindelser fra Google, der vil gøre dit liv lettere.

Revolutionære opfindelser fra Google, der vil gøre dit liv lettere.

Vil du se revolutionerende opfindelser fra Google, og hvordan disse opfindelser ændrede livet for ethvert menneske i dag? Læs derefter til bloggen for at se opfindelser fra Google.

Fredag ​​Essential: Hvad skete der med AI-drevne biler?

Fredag ​​Essential: Hvad skete der med AI-drevne biler?

Konceptet med selvkørende biler til at køre på vejene ved hjælp af kunstig intelligens er en drøm, vi har haft i et stykke tid nu. Men på trods af flere løfter er de ingen steder at se. Læs denne blog for at lære mere...

Teknologisk singularitet: En fjern fremtid for menneskelig civilisation?

Teknologisk singularitet: En fjern fremtid for menneskelig civilisation?

Efterhånden som videnskaben udvikler sig i et hurtigt tempo og overtager en stor del af vores indsats, stiger risikoen for at udsætte os selv for en uforklarlig Singularitet. Læs, hvad singularitet kunne betyde for os.

Udvikling af datalagring – Infografik

Udvikling af datalagring – Infografik

Opbevaringsmetoderne for dataene har været under udvikling, kan være siden fødslen af ​​dataene. Denne blog dækker udviklingen af ​​datalagring på basis af en infografik.

Funktioner af Big Data Reference Architecture Layers

Funktioner af Big Data Reference Architecture Layers

Læs bloggen for at kende forskellige lag i Big Data-arkitekturen og deres funktionaliteter på den enkleste måde.

6 fantastiske fordele ved at have smarte hjemmeenheder i vores liv

6 fantastiske fordele ved at have smarte hjemmeenheder i vores liv

I denne digitalt drevne verden er smarte hjemmeenheder blevet en afgørende del af livet. Her er et par fantastiske fordele ved smarte hjemmeenheder om, hvordan de gør vores liv værd at leve og enklere.

macOS Catalina 10.15.4-tillægsopdatering forårsager flere problemer end at løse

macOS Catalina 10.15.4-tillægsopdatering forårsager flere problemer end at løse

For nylig udgav Apple macOS Catalina 10.15.4 en supplerende opdatering for at løse problemer, men det ser ud til, at opdateringen forårsager flere problemer, hvilket fører til mursten af ​​mac-maskiner. Læs denne artikel for at lære mere