centos7防火墙配置

CentOS 7默认使用的是firewall作为防火墙。
下面介绍一些防火墙常用的命令

1.firewalld/基本介绍

        Centos7开始已经放弃iptables,转而使用firewalld。从本质意义上讲,iptables和firewalld是防火墙软件,其实现方式都是调用内核Netfilter。firewalld提供了一个动态管理的防火墙,形成网络“zones”规则集,具备支持ipv4和ipv6的能力。firewalld程序提供了图形化的配置工具firewall-confighe、system-config-firewall和命令行firewall-cmd,用于配置firewalld永久性或非永久性规则。

2.firewalld/服务配置

        firewall-cmd命令需要firewalld进程处于运行状态。我们可以使用systemctl status/start/stop/restart firewalld来控制这个守护进程。firewalld进程为防火墙提供服务。

当我们修改了某些配置之后(尤其是配置文件的修改),firewall并不会立即生效。可以通过两种方式来激活最新配置systemctl restart firewalld和firewall-cmd --reload两种方式,前一种是重启firewalld服务,建议使用后一种“重载配置文件”。重载配置文件之后不会断掉正在连接的tcp会话,而重启服务则会断开tcp会话。

  1. 启动服务:systemctl start firewalld
  2. 关闭服务:systemctl stop firewalld
  3. 重启服务:systemctl restart firewalld
  4. 查看服务状态:systemctl status firewalld
  5. 开机自启服务:systemctl enable firewalld
  6. 开机禁用服务:systemctl disable firewalld
  7. 查看是否开机自启:systemctl is-enable firewalld

3.firewalld/端口or服务规则配置

        可以通过两种方式控制端口的开放,一种是指定端口号另一种是指定服务名。虽然开放http服务就是开放了80端口,但是还是不能通过端口号来关闭,也就是说通过指定服务名开放的就要通过指定服务名关闭;通过指定端口号开放的就要通过指定端口号关闭。还有一个要注意的就是指定端口的时候一定要指定是什么协议,tcp还是udp。知道这个之后以后就不用每次先关防火墙了,可以让防火墙真正的生效。

  1. 开放mysql端口:firewall-cmd --add-service=mysql 
  2. 阻止http端口:firewall-cmd --remove-service=http 
  3. 查看开放的服务:firewall-cmd --list-services  
  4. 添加端口:firewall-cmd --add-port=80/tcp --permanent
  5. 移除端口:firewall-cmd --remove-port=80/tcp --permanent
  6. 查看端口状态:firewall-cmd --zone=public --query-port=80/tcp
  7. 查看所有打开的端口:firewall-cmd --list-ports
  8. 查看所有规则:firewall-cmd --list-all
  9. 重载规则:firewall-cmd --reload
  10. 查看区域信息:firewall-cmd --get-active-zones
  11. 查看指定接口所属区域: firewall-cmd --get-zone-of-interface=enp4s0
  12. 拒绝所有包:firewall-cmd --panic-on
  13. 取消拒绝所有包: firewall-cmd --panic-off
  14. 查看是否拒绝: firewall-cmd --query-panic

PS:添加或删除端口后不会立即生效,配置完 --reload后才能生效;--permanent代表永久生效

4.firewalld/端口转发

        端口转发可以将指定地址访问指定的端口时,将流量转发至指定地址的指定端口。转发的目的如果不指定ip的话就默认为本机,如果指定了ip却没指定端口,则默认使用来源端口。当我们想把某个端口隐藏起来的时候,就可以在防火墙上阻止那个端口访问,然后再开一个不规则的端口,之后配置防火墙的端口转发,将流量转发过去。端口转发还可以做流量分发,一个防火墙拖着好多台运行着不同服务的机器,然后用防火墙将不同端口的流量转发至不同机器。

  1. 开启防火墙伪装:firewall-cmd --add-masquerade --permanent    //开启后才能转发端口
  2. 关闭防火墙伪装:firewall-cmd --remove-masquerade --permanent
  3. 添加转发规则:firewall-cmd --add-forward-port=port=80:proto=tcp:toport=8080:toaddr=192.168.1.1 --permanent

如果配置好端口转发之后不能用,可以检查下面两个问题:

比如我将80端口转发至8080端口,首先检查本地的80端口和目标的8080端口是否开放监听了
其次检查是否允许伪装IP,没允许的话要开启伪装IP

示例:

# 将80端口的流量转发至8080

  • firewall-cmd --add-forward-port=port=80:proto=tcp:toport=8080

# 将80端口的流量转发至192.168.0.1

  • firewall-cmd --add-forward-port=port=80:proto=tcp:toaddr=192.168.1.0.1

# 将80端口的流量转发至192.168.0.1的8080端口

  • firewall-cmd --add-forward-port=port=80:proto=tcp:toaddr=192.168.0.1:toport=8080

PS:此规则将本机80端口转发到192.168.1.1的8080端口上,配置完--reload才生效

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

vi /etc/sysctl.conf

在文本内容中添加:net.ipv4.ip_forward = 1

保存文件后,输入命令sysctl -p生效

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值