天天看点

Linux有问必答:在CentOS或RHEL防火墙上开启端口Linux有问必答:在CentOS或RHEL防火墙上开启端口

问题:我在centos系统上运行一台网页或文件服务器,打算远程访问服务器。因此,我需要更改防火墙规则以允许访问系统上的某个tcp端口。那么,有什么好方法在centos或rhel系统的防火墙上开启tcp/udp端口?

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

Linux有问必答:在CentOS或RHEL防火墙上开启端口Linux有问必答:在CentOS或RHEL防火墙上开启端口

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

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

Linux有问必答:在CentOS或RHEL防火墙上开启端口Linux有问必答:在CentOS或RHEL防火墙上开启端口

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

<a target="_blank"></a>

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

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

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

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

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

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

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

Linux有问必答:在CentOS或RHEL防火墙上开启端口Linux有问必答:在CentOS或RHEL防火墙上开启端口

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

Linux有问必答:在CentOS或RHEL防火墙上开启端口Linux有问必答:在CentOS或RHEL防火墙上开启端口

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

Linux有问必答:在CentOS或RHEL防火墙上开启端口Linux有问必答:在CentOS或RHEL防火墙上开启端口

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

Linux有问必答:在CentOS或RHEL防火墙上开启端口Linux有问必答:在CentOS或RHEL防火墙上开启端口

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

Linux有问必答:在CentOS或RHEL防火墙上开启端口Linux有问必答:在CentOS或RHEL防火墙上开启端口

原文发布时间:2014-11-17

本文来自云栖合作伙伴“linux中国”

继续阅读