centos7 配置端口转发

注意此处以 centos7 配置为例,防火墙为 firewall 。

开始配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#查看防护墙是否开启,我这里直接重启
systemctl restart firewalld
#防火墙添加开放原始端口
firewall-cmd --add-port=原始端口/tcp --permanent
#添加转发规则
firewall-cmd --add-forward-port=port=原始端口:proto=tcp:toaddr=新的IP:toport=新的端口 --permanent
#查看端口列表,确定是否开启端口
firewall-cmd --list-all
#重新加载防火墙
firewall-cmd --reload

#内核参数文件sysctl.conf配置ip转发功能
vi /etc/sysctl.conf
#在文本内容中添加:net.ipv4.ip_forward = 1
net.ipv4.ip_forward = 1
#使立即生效
sysctl -p

完成了!

非常简单的就完成了

下面是 firewalld服务 常用命令

firewalld服务配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
启动服务:systemctl start firewalld

关闭服务:systemctl stop firewalld

重启服务:systemctl restart firewalld

查看服务状态:systemctl status firewalld

开机自启服务:systemctl enable firewalld

开机禁用服务:systemctl disable firewalld

查看是否开机自启:systemctl is-enable firewalld

PS:systemctl常见其他命令:

查看已启动的服务列表:systemctl list-unit-files | grep enabled

查看启动失败的服务列表:systemctl --failed

firewalld规则配置

1
2
3
4
5
6
7
8
9
10
11
查看版本:firewall-cmd --version
查看帮助:firewall-cmd --help
查看状态:firewall-cmd --state
查看所有打开的端口:firewalld-cmd --zone=public --list-ports
查看所有规则:firewall-cmd --list-all
重载规则:firewall-cmd --reload
查看区域信息:firewall-cmd --get-active-zones
查看指定接口所属区域: firewall-cmd --get-zone-of-interface=enp4s0
拒绝所有包:firewall-cmd --panic-on
取消拒绝所有包: firewall-cmd --panic-off
查看是否拒绝: firewall-cmd --query-panic

firewalld端口规则

1
2
3
4
添加端口:firewall-cmd --add-port=80/tcp --permanent
移除端口:firewall-cmd --remove-port=80/tcp --permanent
查看端口状态:firewall-cmd --zone=public --query-port=80/tcp
(PS:添加或删除端口后不会立即生效,配置完 --reload后才能生效;--permanent代表永久生效)

firewalld端口转发

1
2
3
4
5
6
7
8
9
10
11
开启防火墙伪装:firewall-cmd --add-masquerade --permanent    //开启后才能转发端口

添加转发规则:firewall-cmd --add-forward-port=port=80:proto=tcp:toport=8080:toaddr=192.168.1.1 --permanent
(PS:此规则将本机80端口转发到192.168.1.1的8080端口上,配置完--reload才生效)

如果配置完以上规则后仍不生效,检查防火墙是否开启80端口,如果80端口已开启,仍无法转发,可能是由于内核参数文件sysctl.conf未配置ip转发功能,具体配置如下:

vi /etc/sysctl.conf

在文本内容中添加:net.ipv4.ip_forward = 1
保存文件后,输入命令sysctl -p生效