在CentOS 6上设置IPTables防火墙

介绍

防火墙是一种网络安全工具,可以根据其预定义的规则集控制入站和出站网络流量。我们可以使用防火墙以及其他安全措施来保护我们的服务器免受黑客的撬动和攻击。

防火墙的设计可以是专用硬件,也可以是运行在我们计算机上的软件程序。在CentOS 6上,默认的防火墙程序是iptables。

在本文中,我将向您展示如何基于Vultr“ CentOS 6 x64上的WordPress”应用程序设置基本的iptables防火墙,该防火墙将阻止除Web,SSH,NTP,DNS和ping服务之外的所有流量。但是,这只是满足常见安全需求的初步配置。如果您还有其他要求,则需要更复杂的iptables配置。

注意事项

如果将IPv6地址添加到服务器,则还应该设置ip6tables服务。配置ip6tables不在本文讨论范围之内。

与CentOS 6不同,iptables不再是CentOS 7上的默认防火墙程序,而已被名为firewalld的程序所替代。如果您打算使用CentOS 7,则需要使用firewalld设置防火墙。

先决条件

使用Vultr“ CentOS 6 x64上的WordPress”应用程序新鲜部署服务器实例,然后以root用户身份登录。

步骤1:确定服务器上使用的服务和端口

我假设此服务器将只托管一个WordPress博客,并且不会用作路由器或提供其他服务(例如,邮件,FTP,IRC等)。

在这里,我们需要以下服务:

  • HTTP(端口80上的TCP)
  • HTTPS(端口443上的TCP)
  • SSH(默认情况下,端口22上的TCP,可以出于安全目的而更改)
  • NTP(UDP在端口123上)
  • DNS(端口53上的TCP和UDP)
  • ping(ICMP)

所有其他不必要的端口将被阻止。

步骤2:配置iptables规则

iptables使用规则列表控制流量。当网络数据包发送到我们的服务器时,iptables将使用每个规则依次检查它们并采取相应的措施。如果满足一个规则,则其他规则将被忽略。如果不满足任何规则,则iptables将使用默认策略。

可以将所有流量分类为INPUT,OUTPUT和FORWARD。

  • 输入流量可以是正常流量,也可以是恶意流量,应有选择地允许它。
  • 通常认为输出流量是安全的,应该允许。
  • 转发流量没有用,应将其阻止。

现在,让我们根据需要配置iptables规则。以下所有命令均应以root用户从SSH终端输入。

检查现有规则:

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

允许所有环回(lo)通信,并将除lo外的所有通信丢弃到127.0.0.0/8:

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

允许ping:

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

如何在CentOS 7上安装Oxwall

如何在CentOS 7上安装Oxwall

Oxwall是一个开源社交网络软件平台,可用于免费构建自定义社交网站(SNS)。在这篇文章中,

如何在CentOS 7上设置vsFTPd

如何在CentOS 7上设置vsFTPd

FTP是用于通过Internet传输文件的有用协议,本指南将向您展示如何设置vsFTPd(非常安全的文件传输协议守护程序)o

使用Nethogs监视网络带宽使用情况

使用Nethogs监视网络带宽使用情况

在本教程中,我们将介绍在CentOS 6x x64上安装和使用nethogs的过程。nethogs是一种网络监视工具,它允许Networ

如何在CentOS 7上安装BoltWire CMS

如何在CentOS 7上安装BoltWire CMS

使用其他系统?简介BoltWire是一个用PHP编写的免费,轻量级的内容管理系统。与大多数其他内容管理人员相比

在CentOS 6上设置SA-MP San Andreas多人服务器

在CentOS 6上设置SA-MP San Andreas多人服务器

欢迎来到另一个Vultr教程。在这里,您将学习如何安装和运行SAMP服务器。本指南是为CentOS 6编写的。先决条件

使用Etckeeper进行/ etc的版本控制

使用Etckeeper进行/ etc的版本控制

简介/ etc /目录在Linux系统运行中起着至关重要的作用。其原因是因为几乎每个系统配置

如何在CentOS 7上安装Microweber

如何在CentOS 7上安装Microweber

使用其他系统?Microweber是一个开放源代码的拖放式CMS和在线商店。Microweber源代码托管在GitHub上。本指南将向您展示

如何在CentOS 7上安装SonarQube

如何在CentOS 7上安装SonarQube

使用其他系统?SonarQube是用于质量系统开发的开源工具。它是用Java编写的,并且支持多个数据库。它提供

如何在CentOS 7上使用Mosh进行远程服务器管理

如何在CentOS 7上使用Mosh进行远程服务器管理

使用其他系统?Mosh是Mobile Shell的缩写,是一种新兴的远程终端应用程序,旨在提供更好的连接和使用

如何在CentOS 7上安装MoinMoin

如何在CentOS 7上安装MoinMoin

MoinMoin是一个使用Python编写的基于文件系统的开源Wiki引擎。如今,MoinMoin已广泛用于开源社区。许多供应商

在CentOS 7上安装H2O Web服务器

在CentOS 7上安装H2O Web服务器

H2O是新一代HTTP服务器,它对所有当前使用的Web服务器都具有出色的,功能齐全的HTTP / 2实现。使用H2O作为您的Web服务器

如何在Debian,CentOS和FreeBSD上使用Sudo

如何在Debian,CentOS和FreeBSD上使用Sudo

在Linux和Unix系统管理员中,使用sudo用户访问服务器并在root级执行命令是一种非常普遍的做法。使用泡沫

如何在Ubuntu 16.10上安装Countly Analytics

如何在Ubuntu 16.10上安装Countly Analytics

使用其他系统?Countly是一个开源Web /移动分析和营销平台。它具有许多用于从Web收集数据的功能

如何在CentOS 7上安装MODX CMS和Nginx

如何在CentOS 7上安装MODX CMS和Nginx

MODX是一个用PHP编写的免费开放源内容管理系统。它使用MySQL或MariaDB来存储其数据库。MODX专为满足以下条件的企业而设计:

如何在CentOS 7 LAMP VPS上安装Lychee 3.1相册

如何在CentOS 7 LAMP VPS上安装Lychee 3.1相册

使用其他系统?Lychee 3.1相册是一种简单,灵活,免费和开源的照片管理工具,可在VPS服务器上运行。安装

如何在CentOS 7上安装ERPNext开源ERP

如何在CentOS 7上安装ERPNext开源ERP

使用其他系统?ERP或企业资源计划是用于管理核心业务流程的企业应用程序套件。ERPNext是免费的

如何在CentOS 7 LAMP VPS上安装Paste 2.1

如何在CentOS 7 LAMP VPS上安装Paste 2.1

使用其他系统?Paste 2.1是一个简单,灵活,免费和开源的pastebin应用程序,用于存储代码,文本等。最初是

如何在CentOS 7上安装Seafile Server

如何在CentOS 7上安装Seafile Server

使用其他系统?Seafile(社区版本)是一个免费和开源的文件同步和共享解决方案,类似于ownCloud。机智

如何在CentOS 7上安装Kolab组件

如何在CentOS 7上安装Kolab组件

使用其他系统?Kolab Groupware是一个免费的基于Web的开源组件软件。它的功能包括电子邮件通信,事件

如何在CentOS 7 LAMP VPS上安装Omeka Classic 2.4 CMS

如何在CentOS 7 LAMP VPS上安装Omeka Classic 2.4 CMS

使用其他系统?Omeka Classic 2.4 CMS是一个免费的开源数字发布平台和用于共享数字内容的内容管理系统(CMS)

AI 能否應對越來越多的勒索軟件攻擊?

AI 能否應對越來越多的勒索軟件攻擊?

勒索軟件攻擊呈上升趨勢,但人工智能能否幫助應對最新的計算機病毒?AI 是答案嗎?在這裡閱讀知道是 AI 布恩還是禍根

ReactOS:這是 Windows 的未來嗎?

ReactOS:這是 Windows 的未來嗎?

ReactOS,一個開源和免費的操作系統,這裡有最新版本。它能否滿足現代 Windows 用戶的需求並打倒微軟?讓我們更多地了解這種老式但更新的操作系統體驗。

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

Whatsapp 終於為 Mac 和 Windows 用戶推出了桌面應用程序。現在您可以輕鬆地從 Windows 或 Mac 訪問 Whatsapp。適用於 Windows 8+ 和 Mac OS 10.9+

人工智能如何將流程自動化提升到新的水平?

人工智能如何將流程自動化提升到新的水平?

閱讀本文以了解人工智能如何在小型公司中變得流行,以及它如何增加使它們成長並為競爭對手提供優勢的可能性。

macOS Catalina 10.15.4 補充更新引發的問題多於解決

macOS Catalina 10.15.4 補充更新引發的問題多於解決

最近,Apple 發布了 macOS Catalina 10.15.4 補充更新以修復問題,但似乎該更新引起了更多問題,導致 mac 機器變磚。閱讀這篇文章以了解更多信息

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

什麼是日誌文件系統,它是如何工作的?

什麼是日誌文件系統,它是如何工作的?

我們的計算機以稱為日誌文件系統的有組織的方式存儲所有數據。這是一種有效的方法,可以讓計算機在您點擊搜索時立即搜索和顯示文件。 https://wethegeek.com/?p=94116&preview=true

技術奇點:人類文明的遙遠未來?

技術奇點:人類文明的遙遠未來?

隨著科學的快速發展,接管了我們的大量工作,我們陷入無法解釋的奇點的風險也在增加。閱讀,奇點對我們意味著什麼。

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

2021 年人工智能對醫療保健的影響

2021 年人工智能對醫療保健的影響

過去幾十年,醫療保健領域的人工智能取得了巨大飛躍。因此,醫療保健中人工智能的未來仍在日益增長。