在CentOS或RHEL防火墙上开启端口

Posted 花生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在CentOS或RHEL防火墙上开启端口相关的知识,希望对你有一定的参考价值。

转载自:https://linux.cn/article-4243-1.html

如果希望在服务器上提供服务,诸如CentOS或RHEL的企业级Linux发行版包含内置的强大防火墙,它们默认的防火墙规则十分严格。因此,如 果你安装了任何定制的服务(比如web服务器、NFS和Samba),那么它们的流量很有可能被防火墙规则阻塞。所以需要在防火墙上开启必要的端口以允许 流量通过。

技术分享

在CentOS/RHEL 6或更早的版本上,iptables服务允许用户与netfilter内核模块交互来在用户空间中配置防火墙规则。然而,从CentOS/RHEL 7开始,一个叫做firewalld新用户空间接口被引入以取代iptables服务。

使用这个命令察看当前的防火墙规则:

$ sudo iptables -L 

技术分享

现在,让我们看看如何在CentOS/RHEL上修改防火墙来开启一个端口。

在CentOS/RHEL 7上开启端口

启动CentOS/RHEL 7后,防火墙规则设置由firewalld服务进程默认管理。一个叫做firewall-cmd的命令行客户端支持和这个守护进程通信以永久修改防火墙规则。

使用这些命令来永久打开一个新端口(如TCP/80)。

$ sudo firewall-cmd --zone=public --add-port=80/tcp --permanent
$ sudo firewall-cmd --reload 

如果不使用“--permanent”标记,把么防火墙规则在重启后会失效。

在CentOS/RHEL 6上开启端口

在CentOS/RHEL 6甚至更早版本系统上,iptables服务负责维护防火墙规则。

使用iptables的第一条命令可以通过防火墙开启一个新TCP/UDP端口。为了永久保存修改过的规则,还需要第二条命令。

$ sudo iptables -I INPUT -p tcp -m tcp --dport 80 -j ACCEPT
$ sudo service iptables save 

另一种方法是通过一个名为system-config-firewall-tui的命令行用户接口(TUI)的防火墙客户端。

$ sudo system-config-firewall-tui

选择位于中间的“Customize”按钮,按下ENTER键即可。

技术分享

如果想要为任何已知的服务(如web服务器)修改防火墙,只需勾选该服务,然后关闭工具。如果想要开启任意一个TCP/UDP端口,选择“Forward”按钮,然后进入下一个界面。

技术分享

选择“Add”按钮添加一条新规则。

技术分享

指定一个端口(如80)或者端口范围(如3000-3030)和协议(如tcp或udp)。

技术分享

最后,保存修改过的配置,关闭工具。这样,防火墙就永久保存了。

技术分享

 

编译自:http://ask.xmodulo.com/open-port-firewall-centos-rhel.html
原创:LCTT https://linux.cn/article-4243-1.html

译者: KayGuoWhu

以上是关于在CentOS或RHEL防火墙上开启端口的主要内容,如果未能解决你的问题,请参考以下文章

在CentOS或RHEL防火墙上开启端口

centos 7怎样在防火墙开通samba端口

centos 系统级别 限制端口 ,如何设置? 不包括iptables

解决docker容器开启端口映射后,会自动在防火墙上打开端口的问题

神州数码 路由器启用ospf协议 防火墙启用rip协议 在防火墙上怎么做路由引入

翻译:如何在 RHEL 8 / CentOS 8 Linux 上打开和关闭端口