Настройте защитната стена на IPTables на CentOS 6

Въведение

Защитната стена е вид инструмент за мрежова сигурност, който контролира входящия и изходящия мрежов трафик според предварително дефинирания набор от правила. Можем да използваме защитна стена заедно с други мерки за безопасност, за да защитим нашите сървъри от хакерски нападения и атаки.

Дизайнът на защитна стена може да бъде или специален хардуер, или софтуерна програма, работеща на нашата машина. В CentOS 6, програмата за защитна стена по подразбиране е iptables.

В тази статия ще ви покажа как да настроите основна защитна стена на iptables, базирана на приложението Vultr „WordPress на CentOS 6 x64“, което ще блокира целия трафик с изключение на уеб, SSH, NTP, DNS и ping услуги. Това обаче е само предварителна конфигурация, която удовлетворява общите нужди за сигурност. Ще ви трябва по-сложна конфигурация на iptables, ако имате допълнителни изисквания.

Забележка :

Ако добавите IPv6 адрес към вашия сървър, трябва да настроите и услугата ip6tables. Конфигурирането на ip6tables е извън обхвата на тази статия.

За разлика от CentOS 6, iptables вече не е програмата за защитна стена по подразбиране в CentOS 7 и е заменена с програма, наречена firewalld. Ако планирате да използвате CentOS 7, ще трябва да настроите защитната си стена с помощта на firewalld.

Предпоставки

Наскоро разгърнете сървърен екземпляр с приложението Vultr „WordPress на CentOS 6 x64“, след което влезте като root.

Стъпка 1: Определете услугите и портовете, използвани на вашия сървър

Предполагам, че този сървър ще хоства само блог на WordPress и няма да се използва като рутер или да предоставя други услуги (например поща, FTP, IRC и т.н.).

Тук имаме нужда от следните услуги:

  • HTTP (TCP на порт 80)
  • HTTPS (TCP на порт 443)
  • SSH (TCP на порт 22 по подразбиране, може да бъде променен за целите на сигурността)
  • NTP (UDP на порт 123)
  • DNS (TCP и UDP на порт 53)
  • пинг (ICMP)

Всички други ненужни портове ще бъдат блокирани.

Стъпка 2: Конфигурирайте правилата на iptables

Iptables контролира трафика със списък с правила. Когато мрежовите пакети се изпращат до нашия сървър, iptables ще ги инспектира, като използва всяко правило последователно и ще предприеме съответните действия. Ако дадено правило е спазено, другите правила ще бъдат игнорирани. Ако не са спазени правила, iptables ще използва политиката по подразбиране.

Целият трафик може да бъде категоризиран като INPUT, OUTPUT и FORWARD.

  • INPUT трафикът може да бъде нормален или злонамерен, трябва да се разрешава избирателно.
  • OUTPUT трафикът обикновено се счита за безопасен и трябва да бъде разрешен.
  • Трафикът НАПРЕД е безполезен и трябва да бъде блокиран.

Сега нека конфигурираме правилата на iptables според нашите нужди. Всички следните команди трябва да бъдат въведени от вашия SSH терминал като root.

Проверете съществуващите правила:

iptables -L -n

Изчистете всички съществуващи правила:

iptables -F; iptables -X; iptables -Z

Тъй като промените в конфигурацията на iptables ще влязат в сила незабавно, ако неправилно конфигурирате правилата на iptables, може да бъдете блокирани от вашия сървър. Можете да предотвратите случайни блокирания със следната команда. Не забравяйте да замените [Your-IP-Address]със свой публичен IP адрес или диапазон от IP адреси (например 201.55.119.43 или 201.55.119.0/24).

iptables -A INPUT -s [Your-IP-Address] -p tcp --dport 22 -j ACCEPT

Разрешете целия loopback (lo) трафик и пуснете целия трафик до 127.0.0.0/8, различен от lo:

iptables -A INPUT -i lo -j ACCEPT
iptables -A INPUT -d 127.0.0.0/8 -j REJECT

Блокирайте някои често срещани атаки:

iptables -A INPUT -p tcp ! --syn -m state --state NEW -j DROP
iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP
iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP

Приемете всички установени входящи връзки:

iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

Разрешете HTTP и HTTPS входящ трафик:

iptables -A INPUT -p tcp --dport 80 -j ACCEPT
iptables -A INPUT -p tcp --dport 443 -j ACCEPT

Разрешаване на SSH връзки:

iptables -A INPUT -p tcp --dport 22 -j ACCEPT

Разрешаване на NTP връзки:

iptables -A INPUT -p udp --dport 123 -j ACCEPT

Разрешаване на DNS заявки:

iptables -A INPUT -p udp --dport 53 -j ACCEPT
iptables -A INPUT -p tcp --dport 53 -j ACCEPT

Разрешаване на пинг:

iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT

Най-накрая задайте правилата по подразбиране:

iptables -P INPUT DROP
iptables -P OUTPUT ACCEPT
iptables -P FORWARD DROP

Стъпка 3: Запазете конфигурациите

Всяка от промените, които направихме по-горе, влезе в сила, но те не са постоянни. Ако не ги запишем на твърдия диск, те ще бъдат загубени, след като системата се рестартира.

Запазете конфигурацията на iptables със следната команда:

service iptables save

Нашите промени ще бъдат запазени във файла /etc/sysconfig/iptables. Можете да прегледате или промените правилата, като редактирате този файл.

Заобиколни решения за случайно блокиране

Ако сте блокирани от сървъра си поради грешка в конфигурацията, все още можете да си възвърнете достъпа с някои заобиколни решения.

  • Ако все още не сте запазили промените си в правилата на iptables, можете да рестартирате сървъра си от интерфейса на уебсайта Vultr, след което промените ви ще бъдат премахнати.
  • Ако сте запазили промените си, можете да влезете в сървъра си през конзолата от интерфейса на уебсайта на Vultr и да въведете, за iptables -Fда изтриете всички правила на iptables. След това можете да настроите правилата отново.

Leave a Comment

Инсталирайте Plesk на CentOS 7

Инсталирайте Plesk на CentOS 7

Използване на различна система? Plesk е собствен контролен панел за уеб хост, който позволява на потребителите да администрират своите лични и/или клиентски уебсайтове, бази данни

Как да инсталирате Squid Proxy на CentOS

Как да инсталирате Squid Proxy на CentOS

Squid е популярна, безплатна програма за Linux, която ви позволява да създадете уеб прокси за препращане. В това ръководство ще видите как да инсталирате Squid на CentOS, за да ви обърне

Как да инсталирате Lighttpd (LLMP стек) на CentOS 6

Как да инсталирате Lighttpd (LLMP стек) на CentOS 6

Въведение Lighttpd е форк на Apache, чиято цел е да бъде много по-малко ресурсоемка. Той е лек, откъдето идва и името му, и е доста лесен за използване. Инсталирайте

Конфигуриране на статична мрежа и IPv6 на CentOS 7

Конфигуриране на статична мрежа и IPv6 на CentOS 7

VULTR наскоро направи промени от своя страна и вече всичко трябва да работи добре от кутията с активиран NetworkManager. Ако желаете да деактивирате

Промяна на Icinga2 за използване на модел главен/клиент на CentOS 6 или CentOS 7

Промяна на Icinga2 за използване на модел главен/клиент на CentOS 6 или CentOS 7

Icinga2 е мощна система за наблюдение и когато се използва в модел главен-клиент, тя може да замени необходимостта от проверки на базата на NRPE. Главният клиент

Как да инсталирате Apache Cassandra 3.11.x на CentOS 7

Как да инсталирате Apache Cassandra 3.11.x на CentOS 7

Използване на различна система? Apache Cassandra е безплатна система за управление на база данни NoSQL с отворен код, която е проектирана да осигури мащабируемост, висока

Как да инсталирате Microweber на CentOS 7

Как да инсталирате Microweber на CentOS 7

Използване на различна система? Microweber е CMS и онлайн магазин с отворен код за плъзгане и пускане. Изходният код на Microweber се хоства на GitHub. Това ръководство ще ви покаже

Как да инсталирате Mattermost 4.1 на CentOS 7

Как да инсталирате Mattermost 4.1 на CentOS 7

Използване на различна система? Mattermost е самостоятелно хоствана алтернатива с отворен код на Slack SAAS услугата за съобщения. С други думи, с Mattermost, вие ca

Създаване на мрежа от сървъри на Minecraft с BungeeCord на Debian 8, Debian 9 или CentOS 7

Създаване на мрежа от сървъри на Minecraft с BungeeCord на Debian 8, Debian 9 или CentOS 7

Какво ви трябва Vultr VPS с поне 1 GB RAM. SSH достъп (с root/административни привилегии). Стъпка 1: Инсталиране на BungeeCord На първо място

Lets Encrypt на Plesk

Lets Encrypt на Plesk

Контролният панел на Plesk разполага с много приятна интеграция за Lets Encrypt. Lets Encrypt е един от единствените доставчици на SSL, които предоставят пълно сертификати

Позволява криптиране на cPanel

Позволява криптиране на cPanel

Lets Encrypt е сертифициращ орган, посветен на предоставянето на SSL сертификати безплатно. cPanel изгради чиста интеграция, така че вие ​​и вашият клиент

Как да инсталирате Concrete5 на CentOS 7

Как да инсталирате Concrete5 на CentOS 7

Използване на различна система? Concrete5 е CMS с отворен код, който предлага много отличителни и полезни функции за подпомагане на редакторите при лесното създаване на съдържание и

Как да инсталирате табло за преглед на CentOS 7

Как да инсталирате табло за преглед на CentOS 7

Използване на различна система? Review Board е безплатен инструмент с отворен код за преглед на изходен код, документация, изображения и много други. Това е уеб базиран софтуер

Настройте HTTP удостоверяване с Nginx на CentOS 7

Настройте HTTP удостоверяване с Nginx на CentOS 7

В това ръководство ще научите как да настроите HTTP удостоверяване за уеб сървър на Nginx, работещ на CentOS 7. Изисквания За да започнете, ще ви трябва

Как да инсталирате YOURLS на CentOS 7

Как да инсталирате YOURLS на CentOS 7

YOURLS (Your Own URL Shortener) е приложение за съкращаване на URL адреси и анализ на данни с отворен код. В тази статия ще разгледаме процеса на инсталиране

Как да инсталирате и конфигурирате ArangoDB на CentOS 7

Как да инсталирате и конфигурирате ArangoDB на CentOS 7

Използване на различна система? Въведение ArangoDB е NoSQL база данни с отворен код с гъвкав модел на данни за документи, графики и ключ-стойности. то е

Използване на Etckeeper за контрол на версиите на /etc

Използване на Etckeeper за контрол на версиите на /etc

Въведение Директорията /etc/ играе критична роля в начина, по който функционира една Linux система. Причината за това е, че почти всяка системна конфигурация

Защо трябва да използвате SSHFS? Как да монтирате отдалечена файлова система със SSHFS на CentOS 6

Защо трябва да използвате SSHFS? Как да монтирате отдалечена файлова система със SSHFS на CentOS 6

Много системни администратори управляват големи количества сървъри. Когато файловете трябва да бъдат достъпни на различни сървъри, влизането във всеки от тях поотделно ок

Настройване на сървър на Half Life 2 на CentOS 6

Настройване на сървър на Half Life 2 на CentOS 6

Този урок ще обхване процеса на инсталиране на сървър за игри Half Life 2 на CentOS 6 System. Стъпка 1: Инсталиране на предпоставките За да настроите ou

Как да инсталирате Laravel GitScrum на CentOS 7

Как да инсталирате Laravel GitScrum на CentOS 7

Laravel GitScrum или GitScrum е инструмент за производителност с отворен код, предназначен да помогне на екипите за разработка да внедрят методологията на Scrum по подобен начин.

Възходът на машините: Реални приложения на AI

Възходът на машините: Реални приложения на AI

Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.

DDOS атаки: кратък преглед

DDOS атаки: кратък преглед

Вие също сте жертва на DDOS атаки и сте объркани относно методите за превенция? Прочетете тази статия, за да разрешите вашите запитвания.

Чудили ли сте се как хакерите печелят пари?

Чудили ли сте се как хакерите печелят пари?

Може би сте чували, че хакерите печелят много пари, но чудили ли сте се някога как печелят такива пари? нека обсъдим.

Революционни изобретения на Google, които ще улеснят живота ви.

Революционни изобретения на Google, които ще улеснят живота ви.

Искате ли да видите революционни изобретения на Google и как тези изобретения промениха живота на всяко човешко същество днес? След това прочетете в блога, за да видите изобретенията на Google.

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Концепцията за самоуправляващи се автомобили да тръгват по пътищата с помощта на изкуствен интелект е мечта, която имаме от известно време. Но въпреки няколкото обещания, те не се виждат никъде. Прочетете този блог, за да научите повече…

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Тъй като науката се развива с бързи темпове, поемайки много от нашите усилия, рискът да се подложим на необяснима сингулярност също нараства. Прочетете какво може да означава сингулярността за нас.

Еволюция на съхранението на данни – инфографика

Еволюция на съхранението на данни – инфографика

Методите за съхранение на данните може да се развиват от раждането на данните. Този блог обхваща развитието на съхранението на данни на базата на инфографика.

Функционалности на референтните архитектурни слоеве за големи данни

Функционалности на референтните архитектурни слоеве за големи данни

Прочетете блога, за да разберете различни слоеве в архитектурата на големи данни и техните функционалности по най-простия начин.

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

В този дигитално задвижван свят устройствата за интелигентен дом се превърнаха в решаваща част от живота. Ето няколко невероятни предимства на интелигентните домашни устройства за това как те правят живота ни струващ и по-опростен.

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Наскоро Apple пусна macOS Catalina 10.15.4 допълнителна актуализация за отстраняване на проблеми, но изглежда, че актуализацията причинява повече проблеми, водещи до блокиране на mac машини. Прочетете тази статия, за да научите повече