Brug af Etckeeper til versionskontrol af /etc

Brug af Etckeeper til versionskontrol af /etc

Introduktion

Den /etc/mappe spiller en afgørende rolle i den måde, en Linux systemfunktioner. Årsagen til dette er, fordi næsten alle systemkonfigurationsfiler er placeret inde i /etc/. Dataene, der er gemt i, /etc/er ikke kun relateret til de indbyggede systembiblioteker, men også til nyinstalleret software og dens konfiguration. System- og softwareinstallationer, opgraderinger og konfigurationsændringer er alle gemt i /etc/. Derfor er det en god praksis at bruge versionskontrol, når man styrer for /etc/at undgå potentielle fejl forårsaget af uforudsete eller utilsigtede fejlfunktioner.

Med Etckeeper kan du nemt administrere /etc/med din versionskontrolmekanisme ved at bruge et Git-, Mercurial-, Bazaar- eller Darcs-lager. Som standard bruger Etckeeper git til at vedligeholde /etc/'s version repository mappe med en daglig granularitet for at minimere potentielt datatab. Derudover giver det dig mulighed for at foretage dine ændringer manuelt til enhver tid.

Lad os i denne artikel se på, hvordan man installerer Etckeeper på en CentOS 6-serverinstans, samt hvordan man manuelt udfører en commit og fortryder ændringer.

Forudsætninger

Instruktionerne i denne artikel blev valideret på en Vultr CentOS 6-instans med en LEMP-stak. Instruktioner for andre distributioner kan være anderledes.

Bemærk: det er en god sikkerhedspraksis at få adgang til dit system som en ikke-rootbruger med sudo-rettigheder.

Trin 1: Installer Etckeeper

Etckeeper er inkluderet i EPEL Yum repo. Du skal konfigurere EPEL Yum repo, før du kan installere Etckeeper:

sudo yum install epel-release
sudo yum update
sudo yum install etckeeper

En vellykket installation af Etckeeper vil automatisk installere git og andre afhængigheder.

Du kan tilpasse Etckeepers konfiguration ved at redigere konfigurationsfilen på /etc/etckeeper/etckeeper.conf. Standardkonfigurationen er dog tilstrækkelig, og vi skal bruge den til formålet med denne vejledning.

Trin 2: Konfigurer /etc som git-arbejdsmappen for Etckeeper

Du kan få Etckeeper til at behandle /etc/som git-arbejdsmappen ved at udføre følgende kommandoer:

cd /etc
sudo etckeeper init

"init" underkommandoen ovenfor vil oprette en fil med navn .gitignoreog en mappe med navn .giti /etc/.

Den .gitignoreindeholder en foruddefineret liste over filer og kræver ikke administration med versionskontrol. Hvis det er nødvendigt, kan du tilføje eller slette filnavne i den, som du ønsker, bare husk at sætte et filnavn pr. linje mellem linjen # begin section managed by etckeeper...og linjen # end section managed by etckeeper.

Den .gitmappe er det sted at gemme den version repository af /etc/biblioteket.

Trin 3: Udfør den indledende forpligtelse

Før den indledende forpligtelse kan du se, hvad der vil blive forpligtet:

sudo etckeeper vcs status | more

Den vcssub-kommandoen over etckeeper vil påberåbe sig den version kontrol software (som er git) til at udføre følgende sub-kommando i /etc/biblioteket. Så kommandoen ovenfor er lig med:

sudo git -C /etc status | more

Tryk på for space barat vende en side. Hvis du finder filer, der ikke burde være versionskontrollerede, skal du tilføje dem til .gitignorefilen.

Nu kan du overføre alt indholdet i /etc-mappen (undtagen de filer, der er defineret i .gitignore) i dit git-lager. Husk at skrive nogle meningsfulde kommentarer mellem to anførselstegn til gennemgang.

sudo etckeeper commit "Initial config in /etc"

Her kan du komprimere git-mappen for at spare diskplads:

sudo etckeeper vcs gc

Trin 4: Udfør endnu en commit efter at have foretaget ændringer i /etc

Sammen med git kan Etckeeper optage alle ændringer, der sker i /etc/mappen, såsom tilføjelse, ændring eller sletning af filer, såvel som ejerskab og/eller tilladelsesændringer for filer og mapper. Alt under /etc/falder ind under dens versionskontrolpolitik.

Bemærk venligst, at det at have /etc/versionskontrol ikke betyder, at du kan udføre nogen handling på den. Alvorlige fejlfunktioner kan gøre systemet ubrugeligt, før Etckeeper kan gendanne konfigurationen til en fungerende tilstand.

Til testformål bør du kun foretage sikre ændringer til /etc/, såsom tilføjelse af en ny fil, ændring af værtsnavnet i /etc/hosts, eller installere en ny software ved hjælp af Yum.

Tilføj f.eks. filen abcdei /etc/:

sudo touch /etc/abcde

Tilføj derefter linjen 192.168.0.2 desktopi /etc/hostsfilen:

echo '192.168.0.2 desktop' | sudo tee -a /etc/hosts

Til sidst kan du udføre "commit"-underkommandoen igen:

sudo etckeeper commit "add a file /etc/abcde and add a line to /etc/hosts"

Trin 5: Tilbagekald dine ændringer

For det første kan du tjekke git-historikken for at få hver commits id og kommentar:

sudo etckeeper vcs log

For det andet kan du tjekke detaljerne for enhver commit med de første par bits af dens commit-id. Her antager vi, at det første commit-id er 7f5bff, det andet commit-id er 1aa658.

sudo etckeeper vcs show 1aa658

Du kan trykke for jat flytte ned, tryk for kat flytte op, input for /keyword<Enter>at søge, tryk for qat afslutte.

For det tredje kan du også sammenligne forskellene mellem to commits med følgende kommando. Vær opmærksom på rækkefølgen af ​​to commits, en naturlig sekvens er at sætte den førstnævnte før den sidstnævnte.

sudo etckeeper vcs diff 7f5bff..1aa658

Nu opdager du, at du fejlkonfigurerede værtsnavnet i /etc/hostsunder den første commit og den anden commit, men tilføjelse af filen /etc/abcdeer en korrekt handling, du kan tilbagekalde din ændring i kun /etc/hostsfilen med følgende kommando:

sudo etckeeper vcs checkout 7f5bff /etc/hosts

Hvis du vil tilbagekalde alle ændringerne mellem den første commit og den anden commit, kan du bruge følgende kommando:

sudo etckeeper vcs checkout 7f5bff

Selvfølgelig kan du stadig vende tilbage til den anden commit:

sudo etckeeper vcs checkout 1aa658

Konklusion

Når Etckeeper er konfigureret korrekt, kan du tune og vedligeholde dit system med mere selvtillid. Ikke desto mindre skal du være opmærksom på, at versionskontrol er forskellig fra sikkerhedskopiering, og /etc/mappen er ikke det eneste sted, du skal bekymre dig om. For at holde dit system i form skal du også jævnligt sikkerhedskopiere dit system udover versionskontrolmekanismen.


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