Initial installation av en CentOS 7-server

Initial installation av en CentOS 7-server

Introduktion

En nyligen aktiverad CentOS 7-server måste anpassas innan den kan tas i bruk som ett produktionssystem. I den här artikeln ges de viktigaste anpassningarna som du måste göra på ett lättförståeligt sätt.

Förutsättningar

En nyligen aktiverad CentOS 7-server, helst setup med SSH-nycklar. Logga in på servern som root.

ssh -l root server-ip-address

Steg 1: Skapa ett standardanvändarkonto

Av säkerhetsskäl är det inte tillrådligt att utföra dagliga datoruppgifter med root-kontot. Istället rekommenderas det att skapa ett standardanvändarkonto som kommer att användas för sudoatt få administrativa rättigheter. För denna handledning, anta att vi skapar en användare som heter joe . För att skapa användarkontot, skriv:

adduser joe

Ange ett lösenord för den nya användaren. Du kommer att uppmanas att ange och bekräfta ett lösenord.

passwd joe

Lägg till den nya användaren i hjulgruppen så att den kan anta root-privilegier med sudo.

gpasswd -a joe wheel

Öppna slutligen en annan terminal på din lokala dator och använd följande kommando för att lägga till din SSH-nyckel till den nya användarens hemkatalog på fjärrservern. Du kommer att uppmanas att autentisera innan SSH-nyckeln installeras.

ssh-copy-id joe@server-ip-address

Efter att nyckeln har installerats loggar du in på servern med det nya användarkontot.

ssh -l joe server-ip-address

Om inloggningen lyckas kan du stänga den andra terminalen. Från och med nu kommer alla kommandon att föregås av sudo.

Steg 2: Tillåt inte rotinloggning och lösenordsautentisering

Eftersom du nu kan logga in som en standardanvändare med hjälp av SSH-nycklar är en bra säkerhetspraxis att konfigurera SSH så att både rotinloggning och lösenordsautentisering är otillåtna. Båda inställningarna måste konfigureras i SSH-demonens konfigurationsfil. Så öppna den med nano.

sudo nano /etc/ssh/sshd_config

Leta efter PermitRootLogin- raden, avkommentera den och ställ in värdet till no .

PermitRootLogin     no

Gör samma sak för PasswordAuthenticationraden, som redan borde vara okommenterad:

PasswordAuthentication      no

Spara och stäng filen. För att tillämpa de nya inställningarna, ladda om SSH.

sudo systemctl reload sshd

Steg 3: Konfigurera tidszonen

Som standard anges tiden på servern i UTC. Det är bäst att konfigurera den för att visa den lokala tidszonen. För att åstadkomma det, leta upp zonfilen för ditt land/geografiska område i /usr/share/zoneinfokatalogen och skapa en symbolisk länk från den till /etc/localtimekatalogen. Om du till exempel är i den östra delen av USA skapar du den symboliska länken med:

sudo ln -sf /usr/share/zoneinfo/US/Eastern /etc/localtime

Efteråt, verifiera att tiden nu är angiven i lokal tid genom att köra datekommandot. Utdata ska likna:

Tue Jun 16 15:35:34 EDT 2015

Den EDT i utgångs bekräftar att det är localtime.

Steg 4: Aktivera IPTables-brandväggen

Som standard är den aktiva brandväggsapplikationen på en nyligen aktiverad CentOS 7-server FirewallD. Även om det är en bra ersättning för IPTables, har många säkerhetsapplikationer fortfarande inte stöd för det. Så om du kommer att använda något av dessa program, som OSSEC HIDS, är det bäst att inaktivera/avinstallera FirewallD.

Låt oss börja med att inaktivera/avinstallera FirewallD:

sudo yum remove -y firewalld

Låt oss nu installera/aktivera IPTables.

sudo yum install -y iptables-services
sudo systemctl start iptables

Konfigurera IPTables att starta automatiskt vid uppstart.

sudo systemctl enable iptables

IPTables på CentOS 7 kommer med en standarduppsättning regler, som du kan se med följande kommando.

sudo iptables -L -n

Utgången kommer att likna:

Chain INPUT (policy ACCEPT)
target     prot opt source               destination         
ACCEPT     all  --  0.0.0.0/0            0.0.0.0/0            state RELATED,ESTABLISHED
ACCEPT     icmp --  0.0.0.0/0            0.0.0.0/0           
ACCEPT     all  --  0.0.0.0/0            0.0.0.0/0           
ACCEPT     tcp  --  0.0.0.0/0            0.0.0.0/0            state NEW tcp dpt:22
REJECT     all  --  0.0.0.0/0            0.0.0.0/0            reject-with icmp-host-prohibited

Chain FORWARD (policy ACCEPT)
target     prot opt source               destination         
REJECT     all  --  0.0.0.0/0            0.0.0.0/0            reject-with icmp-host-prohibited

Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination

Du kan se att en av dessa regler tillåter SSH-trafik, så din SSH-session är säker.

Eftersom dessa regler är körtidsregler och kommer att gå förlorade vid omstart, är det bäst att spara dem i en fil med:

sudo /usr/libexec/iptables/iptables.init save

Det kommandot kommer att spara reglerna i /etc/sysconfig/iptablesfilen. Du kan redigera reglerna när som helst genom att ändra den här filen med din favorittextredigerare.

Steg 5: Tillåt ytterligare trafik genom brandväggen

Eftersom du med största sannolikhet kommer att använda din nya server för att vara värd för vissa webbplatser någon gång, måste du lägga till nya regler i brandväggen för att tillåta HTTP- och HTTPS-trafik. För att göra det, öppna IPTables-filen:

sudo nano /etc/sysconfig/iptables

Precis efter eller före SSH-regeln, lägg till reglerna för HTTP (port 80) och HTTPS (port 443) trafik, så att den delen av filen visas som visas i kodblocket nedan.

-A INPUT -p tcp -m state --state NEW -m tcp --dport 22 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 80 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 443 -j ACCEPT
-A INPUT -j REJECT --reject-with icmp-host-prohibited

Spara och stäng filen och ladda sedan om IPTables.

sudo systemctl reload iptables

När steget ovan har slutförts bör din CentOS 7-server nu vara någorlunda säker och redo att användas i produktionen.


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