Använda Etckeeper för versionskontroll av /etc

Använda Etckeeper för versionskontroll av /etc

Introduktion

Den /etc/katalogen spelar en avgörande roll i hur en Linux systemfunktioner. Anledningen till detta är att nästan alla systemkonfigurationsfiler finns inuti /etc/. Data som lagras i /etc/är inte bara relaterad till de inbyggda systembiblioteken, utan även för nyinstallerad programvara och dess konfiguration. System- och mjukvaruinstallationer, uppgraderingar och konfigurationsändringar lagras i /etc/. Därför är det en god praxis att använda versionskontroll när man hanterar för /etc/att undvika potentiella fel orsakade av oförutsedda eller oavsiktliga felfunktioner.

Med Etckeeper kan du enkelt hantera /etc/med din versionskontrollmekanism genom att använda ett Git-, Mercurial-, Bazaar- eller Darcs-förråd. Som standard använder Etckeeper git för att upprätthålla /etc/katalogen för versionens arkiv med daglig granularitet för att minimera potentiell dataförlust. Dessutom låter den dig utföra dina ändringar manuellt när som helst.

I den här artikeln ska vi ta en titt på hur man installerar Etckeeper på en CentOS 6-serverinstans, samt hur man manuellt utför en commit och ångrar ändringar.

Förutsättningar

Instruktionerna i den här artikeln validerades på en Vultr CentOS 6-instans med en LEMP-stack. Instruktioner för andra distributioner kan vara annorlunda.

Obs: det är en bra säkerhetspraxis att komma åt ditt system som en icke-rootanvändare med sudo-privilegier.

Steg 1: Installera Etckeeper

Etckeeper ingår i EPEL Yum repo. Du måste ställa in EPEL Yum-repo innan du kan installera Etckeeper:

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

En framgångsrik installation av Etckeeper kommer automatiskt att installera git och andra beroenden.

Du kan anpassa Etckeepers konfiguration genom att redigera konfigurationsfilen som finns på /etc/etckeeper/etckeeper.conf. Men standardkonfigurationen är tillräcklig och vi kommer att använda den för syftet med denna handledning.

Steg 2: Konfigurera /etc som git-arbetskatalogen för Etckeeper

Du kan få Etckeeper att behandla /etc/som git-arbetskatalogen genom att köra följande kommandon:

cd /etc
sudo etckeeper init

Den "init" sub-kommandot ovan kommer att skapa en fil med namnet .gitignoreoch en katalog som heter .giti /etc/.

Den .gitignoreinnehåller en fördefinierad lista med filer och kräver ingen hantering med versionskontroll. Om det behövs kan du lägga till eller ta bort filnamn i den som du vill, kom bara ihåg att sätta ett filnamn per rad mellan raden # begin section managed by etckeeper...och raden # end section managed by etckeeper.

Den .gitkatalogen är platsen för att lagra version förrådet för /etc/katalogen.

Steg 3: Utför den första commit

Innan det första åtagandet kan du ta en titt på vad som kommer att göras:

sudo etckeeper vcs status | more

Den vcsunder behärskar etckeeper kommer åberopa version styrprogram (som är Git) för att utföra följande under kommando i /etc/katalogen. Så kommandot ovan är lika med:

sudo git -C /etc status | more

Tryck på för space baratt vända en sida. Om du hittar några filer som inte bör vara versionskontrollerade, lägg till dem i .gitignorefilen.

Nu kan du överföra allt innehåll i /etc-katalogen (förutom de filer som definieras i .gitignore) till ditt git-förråd. Kom ihåg att skriva några meningsfulla kommentarer mellan två citattecken för granskning.

sudo etckeeper commit "Initial config in /etc"

Här kan du komprimera git-katalogen för att spara diskutrymme:

sudo etckeeper vcs gc

Steg 4: Utför ytterligare en commit efter att ha gjort ändringar i /etc

Tillsammans med git kan Etckeeper spela in alla ändringar som sker i /etc/katalogen, såsom att lägga till, modifiera eller ta bort filer, såväl som ändringar av ägande och/eller behörigheter för filer och kataloger. Allt under /etc/faller under dess versionskontrollpolicy.

Observera att att ha /etc/under versionskontroll betyder inte att du kan utföra någon operation på den. Allvarliga felfunktioner kan göra systemet obrukbart innan Etckeeper kan återställa konfigurationen till ett fungerande tillstånd.

För teständamål bör du bara göra säkra ändringar i /etc/, som att lägga till en ny fil, ändra värdnamnet i /etc/hosts, eller installera en ny programvara med Yum.

Till exempel, lägg till filen abcdei /etc/:

sudo touch /etc/abcde

Lägg sedan till raden 192.168.0.2 desktopi /etc/hostsfilen:

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

Äntligen kan du utföra underkommandot "commit" igen:

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

Steg 5: Återkalla dina ändringar

För det första kan du kontrollera git-historiken för att få varje commits id och kommentar:

sudo etckeeper vcs log

För det andra kan du kontrollera detaljerna för varje commit med de första bitarna av dess commit-id. Här antar vi att det första commit-id är 7f5bff, det andra commit-id är 1aa658.

sudo etckeeper vcs show 1aa658

Du kan trycka för jatt flytta ner, tryck för katt flytta upp, mata in för /keyword<Enter>att söka, tryck för qatt avsluta.

För det tredje kan du också jämföra skillnaderna mellan två commits med följande kommando. Var medveten om sekvensen av två commits, en naturlig sekvens är att sätta den förra före den senare.

sudo etckeeper vcs diff 7f5bff..1aa658

Nu upptäcker du att du felkonfigurerade värdnamnet /etc/hostsunder den första commit och den andra commit, men att lägga till filen /etc/abcdeär en korrekt operation, du kan återkalla din ändring i endast /etc/hostsfilen med följande kommando:

sudo etckeeper vcs checkout 7f5bff /etc/hosts

Om du vill återkalla alla ändringar mellan den första commit och den andra commit, kan du använda följande kommando:

sudo etckeeper vcs checkout 7f5bff

Naturligtvis kan du fortfarande återgå till den andra commit:

sudo etckeeper vcs checkout 1aa658

Slutsats

Med Etckeeper korrekt konfigurerat kan du ställa in och underhålla ditt system med mer självförtroende. Var dock medveten om att versionskontroll skiljer sig från säkerhetskopiering och att /etc/katalogen inte är den enda platsen att oroa sig för. För att hålla ditt system i form måste du också säkerhetskopiera ditt system regelbundet förutom versionskontrollmekanismen.


Installera Plesk på CentOS 7

Installera Plesk på CentOS 7

Använder du ett annat system? Plesk är en egen kontrollpanel för webbhotell som tillåter användare att administrera sina personliga och/eller klienters webbplatser, databaser

Hur man installerar Squid Proxy på CentOS

Hur man installerar Squid Proxy på CentOS

Squid är ett populärt, gratis Linux-program som låter dig skapa en webbproxy för vidarebefordran. I den här guiden ser du hur du installerar Squid på CentOS för att förvandla dig

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Inledning Lighttpd är en apachegaffel som syftar till att vara mycket mindre resurskrävande. Den är lätt, därav namnet, och är ganska enkel att använda. Installera

Konfigurera statiskt nätverk och IPv6 på CentOS 7

Konfigurera statiskt nätverk och IPv6 på CentOS 7

VULTR har nyligen gjort ändringar på deras sida, och allt borde nu fungera bra direkt när NetworkManager är aktiverat. Om du vill inaktivera

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Icinga2 är ett kraftfullt övervakningssystem, och när det används i en master-klient-modell kan det ersätta behovet av NRPE-baserade övervakningskontroller. Master-klienten

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Microweber på CentOS 7

Hur man installerar Microweber på CentOS 7

Använder du ett annat system? Microweber är en öppen källkod för dra och släpp CMS och onlinebutik. Microweber källkod finns på GitHub. Denna guide kommer att visa dig

Hur man installerar Vanilla Forum på CentOS 7

Hur man installerar Vanilla Forum på CentOS 7

Använder du ett annat system? Vanilla forum är en open source forumapplikation skriven i PHP. Det är en helt anpassningsbar, enkel att använda och stöder externa

Hur man installerar Mattermost 4.1 på CentOS 7

Hur man installerar Mattermost 4.1 på CentOS 7

Använder du ett annat system? Mattermost är ett alternativ med öppen källkod, självvärd till meddelandetjänsten Slack SAAS. Med andra ord, med Mattermost, du ca

Skapa ett nätverk av Minecraft-servrar med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Skapa ett nätverk av Minecraft-servrar med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Vad du behöver En Vultr VPS med minst 1 GB RAM. SSH-åtkomst (med root-/administrativa privilegier). Steg 1: Installera BungeeCord Först till kvarn

Låt oss kryptera på Plesk

Låt oss kryptera på Plesk

Plesks kontrollpanel har en mycket trevlig integration för Lets Encrypt. Lets Encrypt är en av de enda SSL-leverantörerna som ger ut certifikat fullständigt

Låter kryptera på cPanel

Låter kryptera på cPanel

Lets Encrypt är en certifikatmyndighet dedikerad till att tillhandahålla SSL-certifikat gratis. cPanel har byggt en snygg integration så att du och din klient

Hur man installerar Concrete5 på CentOS 7

Hur man installerar Concrete5 på CentOS 7

Använder du ett annat system? Concrete5 är ett CMS med öppen källkod som erbjuder många distinkta och användbara funktioner för att hjälpa redaktörer att producera innehåll enkelt och

Hur man installerar Review Board på CentOS 7

Hur man installerar Review Board på CentOS 7

Använder du ett annat system? Review Board är ett gratis och öppen källkodsverktyg för att granska källkod, dokumentation, bilder och många fler. Det är webbaserad mjukvara

Ställ in HTTP-autentisering med Nginx på CentOS 7

Ställ in HTTP-autentisering med Nginx på CentOS 7

I den här guiden lär du dig hur du ställer in HTTP-autentisering för en Nginx-webbserver som körs på CentOS 7. Krav För att komma igång behöver du

Hur man installerar YOURLS på CentOS 7

Hur man installerar YOURLS på CentOS 7

YOURLS (Your Own URL Shortener) är ett webbadressförkortnings- och dataanalysprogram med öppen källkod. I den här artikeln kommer vi att täcka installationsprocessen

Hur man installerar och konfigurerar ArangoDB på CentOS 7

Hur man installerar och konfigurerar ArangoDB på CentOS 7

Använder du ett annat system? Inledning ArangoDB är en NoSQL-databas med öppen källkod med en flexibel datamodell för dokument, grafer och nyckel-värden. Det är

Använda Etckeeper för versionskontroll av /etc

Använda Etckeeper för versionskontroll av /etc

Inledning Katalogen /etc/ spelar en avgörande roll för hur ett Linux-system fungerar. Anledningen till detta är att nästan varje systemkonfiguration

Varför ska du använda SSHFS? Hur man monterar ett fjärrfilsystem med SSHFS på CentOS 6

Varför ska du använda SSHFS? Hur man monterar ett fjärrfilsystem med SSHFS på CentOS 6

Många systemadministratörer hanterar stora mängder servrar. När filer behöver nås över olika servrar, logga in på var och en individuellt ca

Konfigurera en Half Life 2-server på CentOS 6

Konfigurera en Half Life 2-server på CentOS 6

Denna handledning kommer att täcka processen att installera en Half Life 2-spelserver på CentOS 6 System. Steg 1: Installera förutsättningarna För att ställa in ou

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.

DDOS-attacker: En kort översikt

DDOS-attacker: En kort översikt

Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.

Har du någonsin undrat hur hackare tjänar pengar?

Har du någonsin undrat hur hackare tjänar pengar?

Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...

Technological Singularity: A Distant Future of Human Civilization?

Technological Singularity: A Distant Future of Human Civilization?

När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.

Utveckling av datalagring – Infographic

Utveckling av datalagring – Infographic

Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.

Funktioner för Big Data Reference Architecture Layers

Funktioner för Big Data Reference Architecture Layers

Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer