Fedora防火墙设置

参考:

FirewallD/zh-cn:(http://fedoraproject.org/wiki/FirewallD/zh-cn#.E4.BB.80.E4.B9.88.E6.98.AF.E5.8C.BA.E5.9F.9F.EF.BC.9F)

Linux Firewall (firewalld, firewall-cmd, firewall-config):(http://oracle-base.com/articles/linux/linux-firewall-firewalld.php)

fedora中iptables与firewall的关系:http://www.tuicool.com/articles/qYnuMj

fedora的firewall配置:http://www.tuicool.com/articles/b6VZNvA


1、firewall与iptables的区别

iptables用于过滤数据包,属于网络层防火墙.firewall能够允许哪些服务可用,那些端口可用.... 属于更高一层的防火墙。firewall的底层是使用iptables进行数据过滤,建立在iptables之上。

Fedora 18 introduced firewalld as a replacement for the previous iptables service. You need to distinguish between the iptables service and the iptables command. Although firewalld is a replacement for the firewall management provided by iptables service, it still uses the iptables command for dynamic communication with the kernel packet filter (netfilter). So it is only the iptables service that is replaced, not the iptables command. 

Fedora 18引入了firewalld来替换之前的iptables.service.另外需要注意iptables service与iptables command是不一样的.虽然firewalld替换了iptables.service,但仍然使用iptables command来与内核的netfilter进行动态交互.


2、基本概念

FirewallD 提供了支持网络/防火墙区域(zone)定义网络链接以及接口安全等级的动态防火墙管理工具。它支持 IPv4, IPv6 防火墙设置以及以太网桥接,并且拥有运行时配置和永久配置选项。它也支持允许服务或者应用程序直接添加防火墙规则的接口。

网络区域(zone)定义了网络连接的可信等级。这是一个一对多的关系,这意味着一次连接可以仅仅是一个区域的一部分,而一个区域可以用于很多连接。

由firewalld 提供的区域按照从不信任到信任的顺序排序。

丢弃

任何流入网络的包都被丢弃,不作出任何响应。只允许流出的网络连接。

阻塞

任何进入的网络连接都被拒绝,并返回 IPv4 的 icmp-host-prohibited 报文或者 IPv6 的 icmp6-adm-prohibited 报文。只允许由该系统初始化的网络连接。

公开

用以可以公开的部分。你认为网络中其他的计算机不可信并且可能伤害你的计算机。只允许选中的连接接入。(You do not trust the other computers on networks to not harm your computer. Only selected incoming connections are accepted.)

外部

用在路由器等启用伪装的外部网络。你认为网络中其他的计算机不可信并且可能伤害你的计算机。只允许选中的连接接入。

隔离区(dmz)

用以允许隔离区(dmz)中的电脑有限地被外界网络访问。只接受被选中的连接。

工作

用在工作网络。你信任网络中的大多数计算机不会影响你的计算机。只接受被选中的连接。

家庭

用在家庭网络。你信任网络中的大多数计算机不会影响你的计算机。只接受被选中的连接。

内部

用在内部网络。你信任网络中的大多数计算机不会影响你的计算机。只接受被选中的连接。

受信任的

允许所有网络连接。


3、常用命令

  • 获取 firewalld 状态
 firewall-cmd --state

此举返回 firewalld 的状态,没有任何输出。可以使用以下方式获得状态输出:

 firewall-cmd --state && echo "Running" || echo "Not running"

在 Fedora 19 中, 状态输出比此前直观:

 # rpm -qf $( which firewall-cmd )
 firewalld-0.3.3-2.fc19.noarch
 # firewall-cmd --state
 not running
  • 在不改变状态的条件下重新加载防火墙:
 firewall-cmd --reload

如果你使用 --complete-reload ,状态信息将会丢失。这个选项应当仅用于处理防火墙问题时,例如,状态信息和防火墙规则都正常,但是不能建立任何连接的情况。

  • 获取支持的区域列表
 firewall-cmd --get-zones

这条命令输出用空格分隔的列表。

  • 获取所有支持的服务
 firewall-cmd --get-services

这条命令输出用空格分隔的列表。

  • 获取所有支持的ICMP类型
 firewall-cmd --get-icmptypes

这条命令输出用空格分隔的列表。

  • 列出全部启用的区域的特性
 firewall-cmd --list-all-zones

输出格式是:

 
   interfaces:  ..
   services:  ..
   ports:  ..
   forward-ports:  ..
   icmp-blocks:  ..
   
   ..
  • 输出区域 全部启用的特性。如果生略区域,将显示默认区域的信息。
 firewall-cmd [--zone=] --list-all
  • 获取默认区域的网络设置
 firewall-cmd --get-default-zone
  • 设置默认区域
 firewall-cmd --set-default-zone=

流入默认区域中配置的接口的新访问请求将被置入新的默认区域。当前活动的连接将不受影响。

  • 获取活动的区域
 firewall-cmd --get-active-zones

这条命令将用以下格式输出每个区域所含接口:

 :   ..
 :  ..
  • 根据接口获取区域
 firewall-cmd --get-zone-of-interface=

这条命令将输出接口所属的区域名称。

  • 将接口增加到区域
 firewall-cmd [--zone=] --add-interface=

如果接口不属于区域,接口将被增加到区域。如果区域被省略了,将使用默认区域。接口在重新加载后将重新应用。

  • 修改接口所属区域
 firewall-cmd [--zone=] --change-interface=

这个选项与 --add-interface 选项相似,但是当接口已经存在于另一个区域的时候,该接口将被添加到新的区域。

  • 从区域中删除一个接口
 firewall-cmd [--zone=] --remove-interface=
  • 查询区域中是否包含某接口
 firewall-cmd [--zone=] --query-interface=

返回接口是否存在于该区域。没有输出。

  • 列举区域中启用的服务
 firewall-cmd [ --zone= ] --list-services
  • 启用应急模式阻断所有网络连接,以防出现紧急状况
 firewall-cmd --panic-on
  • 禁用应急模式
 firewall-cmd --panic-off
Note.png
应急模式在 0.3.0 版本中发生了变化
在 0.3.0 之前的 FirewallD版本中, panic 选项是  --enable-panic 与  --disable-panic.
  • 查询应急模式
 firewall-cmd --query-panic

此命令返回应急模式的状态,没有输出。可以使用以下方式获得状态输出:

 firewall-cmd --query-panic && echo "On" || echo "Off"

处理运行时区域

运行时模式下对区域进行的修改不是永久有效的。重新加载或者重启后修改将失效。

  • 启用区域中的一种服务
 firewall-cmd [--zone=] --add-service= [--timeout=]

此举启用区域中的一种服务。如果未指定区域,将使用默认区域。如果设定了超时时间,服务将只启用特定秒数。如果服务已经活跃,将不会有任何警告信息。

  • 例: 使区域中的 ipp-client 服务生效60秒:
 firewall-cmd --zone=home --add-service=ipp-client --timeout=60
  • 例: 启用默认区域中的http服务:
 firewall-cmd --add-service=http
  • 禁用区域中的某种服务
 firewall-cmd [--zone=] --remove-service=

此举禁用区域中的某种服务。如果未指定区域,将使用默认区域。

  • 例: 禁止 home 区域中的 http 服务:
 firewall-cmd --zone=home --remove-service=http

区域种的服务将被禁用。如果服务没有启用,将不会有任何警告信息。

  • 查询区域中是否启用了特定服务
 firewall-cmd [--zone=] --query-service=

如果服务启用,将返回1,否则返回0。没有输出信息。

  • 启用区域端口和协议组合
 firewall-cmd [--zone=] --add-port=[-]/ [--timeout=]

此举将启用端口和协议的组合。端口可以是一个单独的端口 或者是一个端口范围 - 。协议可以是 tcp 或 udp

  • 禁用端口和协议组合
 firewall-cmd [--zone=] --remove-port=[-]/
  • 查询区域中是否启用了端口和协议组合
 firewall-cmd [--zone=] --query-port=[-]/

如果启用,此命令将有返回值。没有输出信息。

  • 启用区域中的 IP 伪装功能
 firewall-cmd [--zone=] --add-masquerade

此举启用区域的伪装功能。私有网络的地址将被隐藏并映射到一个公有IP。这是地址转换的一种形式,常用于路由。由于内核的限制,伪装功能仅可用于IPv4。

  • 禁用区域中的 IP 伪装
 firewall-cmd [--zone=] --remove-masquerade
  • 查询区域的伪装状态
 firewall-cmd [--zone=] --query-masquerade

如果启用,此命令将有返回值。没有输出信息。

  • 启用区域的 ICMP 阻塞功能
 firewall-cmd [--zone=] --add-icmp-block=

此举将启用选中的 Internet 控制报文协议 (ICMP) 报文进行阻塞。 ICMP 报文可以是请求信息或者创建的应答报文,以及错误应答。

  • 禁止区域的 ICMP 阻塞功能
 firewall-cmd [--zone=] --remove-icmp-block=
  • 查询区域的 ICMP 阻塞功能
 firewall-cmd [--zone=] --query-icmp-block=

如果启用,此命令将有返回值。没有输出信息。

  • 例: 阻塞区域的响应应答报文:
 firewall-cmd --zone=public --add-icmp-block=echo-reply
  • 在区域中启用端口转发或映射
 firewall-cmd [--zone=] --add-forward-port=port=[-]:proto= { :toport=[-] | :toaddr=
| :toport=[-]:toaddr=
}

端口可以映射到另一台主机的同一端口,也可以是同一主机或另一主机的不同端口。端口号可以是一个单独的端口 或者是端口范围 - 。协议可以为 tcp 或udp 。目标端口可以是端口号 或者是端口范围 - 。目标地址可以是 IPv4 地址。受内核限制,端口转发功能仅可用于IPv4。

  • 禁止区域的端口转发或者端口映射
 firewall-cmd [--zone=] --remove-forward-port=port=[-]:proto= { :toport=[-] | :toaddr=
| :toport=[-]:toaddr=
}
  • 查询区域的端口转发或者端口映射
 firewall-cmd [--zone=] --query-forward-port=port=[-]:proto= { :toport=[-] | :toaddr=
| :toport=[-]:toaddr=
}

如果启用,此命令将有返回值。没有输出信息。

  • 例: 将区域 home 的 ssh 转发到 127.0.0.2
 firewall-cmd --zone=home --add-forward-port=port=22:proto=tcp:toaddr=127.0.0.2

处理永久区域

永久选项不直接影响运行时的状态。这些选项仅在重载或者重启服务时可用。为了使用运行时和永久设置,需要分别设置两者。 选项 --permanent 需要是永久设置的第一个参数。

  • 获取永久选项所支持的服务
 firewall-cmd --permanent --get-services
  • 获取永久选项所支持的ICMP类型列表
 firewall-cmd --permanent --get-icmptypes
  • 获取支持的永久区域
 firewall-cmd --permanent --get-zones
  • 启用区域中的服务
 firewall-cmd --permanent [--zone=] --add-service=

此举将永久启用区域中的服务。如果未指定区域,将使用默认区域。

  • 禁用区域中的一种服务
 firewall-cmd --permanent [--zone=] --remove-service=
  • 查询区域中的服务是否启用
 firewall-cmd --permanent [--zone=] --query-service=

如果服务启用,此命令将有返回值。此命令没有输出信息。

  • 例: 永久启用 home 区域中的 ipp-client 服务
 firewall-cmd --permanent --zone=home --add-service=ipp-client
  • 永久启用区域中的一个端口-协议组合
 firewall-cmd --permanent [--zone=] --add-port=[-]/
  • 永久禁用区域中的一个端口-协议组合
 firewall-cmd --permanent [--zone=] --remove-port=[-]/
  • 查询区域中的端口-协议组合是否永久启用
 firewall-cmd --permanent [--zone=] --query-port=[-]/

如果服务启用,此命令将有返回值。此命令没有输出信息。

  • 例: 永久启用 home 区域中的 https (tcp 443) 端口
 firewall-cmd --permanent --zone=home --add-port=443/tcp
  • 永久启用区域中的伪装
 firewall-cmd --permanent [--zone=] --add-masquerade

此举启用区域的伪装功能。私有网络的地址将被隐藏并映射到一个公有IP。这是地址转换的一种形式,常用于路由。由于内核的限制,伪装功能仅可用于IPv4。

  • 永久禁用区域中的伪装
 firewall-cmd --permanent [--zone=] --remove-masquerade
  • 查询区域中的伪装的永久状态
 firewall-cmd --permanent [--zone=] --query-masquerade

如果服务启用,此命令将有返回值。此命令没有输出信息。

  • 永久启用区域中的ICMP阻塞
 firewall-cmd --permanent [--zone=] --add-icmp-block=

此举将启用选中的 Internet 控制报文协议 (ICMP) 报文进行阻塞。 ICMP 报文可以是请求信息或者创建的应答报文或错误应答报文。

  • 永久禁用区域中的ICMP阻塞
 firewall-cmd --permanent [--zone=] --remove-icmp-block=
  • 查询区域中的ICMP永久状态
 firewall-cmd --permanent [--zone=] --query-icmp-block=

如果服务启用,此命令将有返回值。此命令没有输出信息。

  • 例: 阻塞公共区域中的响应应答报文:
 firewall-cmd --permanent --zone=public --add-icmp-block=echo-reply
  • 在区域中永久启用端口转发或映射
 firewall-cmd --permanent [--zone=] --add-forward-port=port=[-]:proto= { :toport=[-] | :toaddr=
| :toport=[-]:toaddr=
}

端口可以映射到另一台主机的同一端口,也可以是同一主机或另一主机的不同端口。端口号可以是一个单独的端口 或者是端口范围 - 。协议可以为 tcp 或udp 。目标端口可以是端口号 或者是端口范围 - 。目标地址可以是 IPv4 地址。受内核限制,端口转发功能仅可用于IPv4。

  • 永久禁止区域的端口转发或者端口映射
 firewall-cmd --permanent [--zone=] --remove-forward-port=port=[-]:proto= { :toport=[-] | :toaddr=
| :toport=[-]:toaddr=
}
  • 查询区域的端口转发或者端口映射状态
 firewall-cmd --permanent [--zone=] --query-forward-port=port=[-]:proto= { :toport=[-] | :toaddr=
| :toport=[-]:toaddr=
}

如果服务启用,此命令将有返回值。此命令没有输出信息。

  • 例: 将 home 区域的 ssh 服务转发到 127.0.0.2
 firewall-cmd --permanent --zone=home --add-forward-port=port=22:proto=tcp:toaddr=127.0.0.2


你可能感兴趣的:(Linux)