Använda FirewallD för att hantera din brandvägg på CentOS 7

FirewallD är en dynamiskt hanterad brandvägg som ger stöd för IPv4- och IPv6-brandväggsregler och brandväggszoner som är tillgänglig på RHEL 7-baserade servrar. Det är en direkt ersättning för iptablesoch fungerar med kärnans netfilterkod.

I den här artikeln kommer vi att ta en kort titt på hur du hanterar brandväggen på CentOS 7 med firewall-cmdkommandot.

Kontrollerar om FirewallD körs

Det första steget är att kontrollera om FirewallD är installerad och körs. Detta kan göras systemdgenom att köra följande:

$ systemctl status firewalld
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)
   Active: active (running) since Thu 2016-03-10 15:07:00 UTC; 1min 30s ago
   ...

Alternativt kan du kontrollera med hjälp av firewall-cmdverktyget:

$ firewall-cmd --state
running

Hantera zoner

FirewallD använder konceptet zonesdär en zon definierar nivån av förtroende som används för en anslutning. Du kan dela upp olika nätverksgränssnitt i olika zoner för att tillämpa specifika brandväggsregler per gränssnitt eller så kan du använda en zon för alla gränssnitt.

Ur lådan görs allt på standardzonen public, men det finns flera andra förkonfigurerade zoner som också kan tillämpas.

Listar alla tillgängliga zoner

Du kan behöva få en lista över alla tillgängliga zoner, av vilka det finns flera ur lådan. Återigen, detta kan göras med firewall-cmd:

$ firewall-cmd --get-zones
block dmz drop external home internal public trusted work

Kontrollerar standardzonen

Du kan upptäcka standardzonen som för närvarande är konfigurerad med firewall-cmd:

$ firewall-cmd --get-default-zone
public

Om du vill ändra standardzonen (till exempel till home), kan detta göras genom att köra:

$ firewall-cmd --set-default-zone=home
success

Denna information kommer att återspeglas i huvudkonfigurationsfilen, /etc/firewalld/firewalld.conf. Det rekommenderas dock att du inte ändrar den här filen manuellt och istället använder firewall-cmd.

Kontrollerar de för närvarande tilldelade zonerna

Du kan få en lista över de zoner som du har tilldelat gränssnitt genom att köra:

$ firewall-cmd --get-active-zones
public
  interfaces: eth0

Du kan också kontrollera zonen för ett enskilt gränssnitt ( eth0i det här fallet) genom att köra:

$  firewall-cmd --get-zone-of-interface=eth0
public

Skapar zoner

Om de förkonfigurerade standardzonerna inte riktigt passar dina behov är det enklaste sättet att skapa en ny zon ( zone1) igen via firewall-cmd:

$ firewall-cmd --permanent --new-zone=zone1
success

Efter skapandet måste du ladda om:

$ firewall-cmd --reload
success

Applicera en zon på ett gränssnitt

För att permanent tilldela ett nätverksgränssnitt till en zon kan du använda firewall-cmdmen kom ihåg att inkludera --permanentflaggan för att fortsätta ändringen. Om du använder NetworkManager, bör du också vara säker på att använda för nmcliatt ställa in anslutningszonen.

$ firewall-cmd --permanent --zone=internal --change-interface=eth1`
success

Få den permanenta konfigurationen av en zon

För att kontrollera den permanenta konfigurationen av en zon ( publici det här fallet) inklusive de tilldelade gränssnitten, tillåtna tjänster, portinställningar och mer, kör:

$ firewall-cmd --permanent --zone=public --list-all
public (default)
  interfaces:
  sources:
  services: dhcpv6-client ssh
  ports:
  masquerade: no
  forward-ports:
  icmp-blocks:
  rich rules:

Hantera tjänster

När du har tilldelat och konfigurerat dina nödvändiga zoner kan du börja lägga till tjänster till zoner. Tjänster beskriver de protokoll och portar som kan nås för en zon.

Lista befintliga tjänster

Ett antal vanliga tjänster är förkonfigurerade inom brandväggen. Dessa kan listas:

$ firewall-cmd --get-services
RH-Satellite-6 amanda-client bacula bacula-client dhcp dhcpv6 dhcpv6-client dns freeipa-ldap freeipa-ldaps freeipa-replication ftp high-availability http https imaps ipp ipp-client ipsec iscsi-target kerberos kpasswd ldap ldaps libvirt libvirt-tls mdns mountd ms-wbt mysql nfs ntp openvpn pmcd pmproxy pmwebapi pmwebapis pop3s postgresql proxy-dhcp radius rpc-bind rsyncd samba samba-client smtp ssh telnet tftp tftp-client transmission-client vdsm vnc-server wbem-https

Du kan också få en lista över de tjänster som är aktiverade för standardzonen:

$ firewall-cmd --list-services
dhcpv6-client ssh

Lägga till en tjänst i en zon

Du kan aktivera en given tjänst för en zon ( public) permanent med --add-serviceflaggan:

$ firewall-cmd --permanent --zone=public --add-service=http
success

Och ladda sedan om den aktuella brandväggssessionen:

$ firewall-cmd --reload
success

Sedan, för att verifiera att det lades till:

$ firewall-cmd --zone=public --list-services
dhcpv6-client http ssh

Ta bort en tjänst från en zon

Du kan ta bort en given tjänst för en zon ( public) permanent med --remove-serviceflaggan:

$ firewall-cmd --permanent --zone=public --remove-service=http
success

Och ladda sedan om den aktuella brandväggssessionen:

$ firewall-cmd --reload
success

Sedan, för att verifiera att det lades till:

$ firewall-cmd --zone=public --list-services
dhcpv6-client ssh

Lägga till/ta bort flera tjänster från en zon

Du kan lägga till eller ta bort flera tjänster (till exempel httpoch https) från en zon, antingen en åt gången eller alla på en gång genom att linda in de önskade tjänstnamnen i hängslen ( {, }):

$ firewall-cmd --permanent --zone=public --add-service=
success

$ firewall-cmd --permanent --zone=public --list-services
dhcpv6-client http https ssh

Skapar nya tjänster

Ibland kan du behöva lägga till nya anpassade tjänster - till exempel om du har ändrat porten för SSH-demonen. Tjänster definieras med triviala XML-filer, med standardfilerna som finns i /usr/lib/firewalld/services:

$  tree /usr/lib/firewalld/services
/usr/lib/firewalld/services
├── amanda-client.xml
├── bacula-client.xml
├── bacula.xml
├── dhcpv6-client.xml
├── dhcpv6.xml
├── dhcp.xml
├── dns.xml
├── freeipa-ldaps.xml
├── freeipa-ldap.xml
├── freeipa-replication.xml
├── ftp.xml
├── high-availability.xml
├── https.xml
├── http.xml
...

Det enklaste sättet att skapa en ny tjänst är att kopiera en av dessa befintliga tjänstfiler och ändra den. Anpassade tjänster bör finnas i /etc/firewalld/services. Till exempel, för att anpassa SSH-tjänsten:

$ cp /usr/lib/firewalld/services/ssh.xml /etc/firewalld/services/ssh-custom.xml

Innehållet i denna kopierade fil bör se ut så här:

$ cat /etc/firewalld/services/ssh-custom.xml
<?xml version="1.0" encoding="utf-8"?>
<service>
  <short>SSH</short>
  <description>Secure Shell (SSH) is a protocol for logging into and executing commands on remote machines. It provides secure encrypted communications. If you plan on accessing your machine remotely via SSH over a firewalled interface, enable this option. You need the openssh-server package installed for this option to be useful.</description>
  <port protocol="tcp" port="22"/>
</service>

För att ändra porten bör du ändra det korta namnet för tjänsten och porten. Du kan också ändra beskrivningen om du vill, men detta är bara extra metadata som kan användas av ett användargränssnitt eller en annan applikation. I det här exemplet ändrar jag porten till 1234:

$ nano /etc/firewalld/services/ssh-custom.xml
<?xml version="1.0" encoding="utf-8"?>
<service>
  <short>SSH-Custom</short>
  <description>Secure Shell (SSH) is a protocol for logging into and executing commands on remote machines. It provides secure encrypted communications. If you plan on accessing your machine remotely via SSH over a firewalled interface, enable this option. You need the openssh-server package installed for this option to be useful.</description>
  <port protocol="tcp" port="1234"/>
</service>

När du har sparat måste du ladda om brandväggen och sedan kan du tillämpa din regel på din zon:

$ firewall-cmd --reload
success

$ firewall-cmd --permanent --zone=public --add-service=ssh-custom
success

Hamnförvaltning

Förutom att använda tjänster kan du även tillåta portar manuellt efter protokoll. Så här tillåter du TCP-porten 7777för publiczonen:

$ firewall-cmd --permanent --zone=public --add-port=7777/tcp
success

Du kan också lägga till ett portintervall:

$ firewall-cmd --permanent --zone=public --add-port=7000-8000/tcp
success

För att ta bort (och därmed neka) TCP-port 7777för publiczonen:

$ firewall-cmd --permanent --zone=public --remove-port=7777/tcp
success

Du kan också lista de för närvarande tillåtna portarna för en given zon ( public) efter att ha laddat om den aktuella brandväggssessionen:

$ firewall-cmd --zone=public --list-ports
7000-8000/tcp

Aktiverar FirewallD

När du har konfigurerat brandväggen som du vill, bör du vara säker på att aktivera den via systemd för att säkerställa att den startar vid start:

$ systemctl enable firewalld

Slutsats

Det finns en hel del fler inställningar och alternativ inom FirewallD, som portvidarebefordran, maskering och kommunikation med brandväggen via D-Bus. Förhoppningsvis har den här guiden hjälpt dig att förstå grunderna och gett dig verktygen för att komma igång med brandvägg från din server. Lite ytterligare läsning nedan hjälper dig att få ut det mesta av din brandvägg.


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