firewalld服务

1.简介

 firewalld是CentOS 7.0新推出的管理netfilter的工具
 firewalld是配置和监控防火墙规则的系统守护进程。可以实现iptables,ip6tables,ebtables的功能
 firewalld服务由firewalld包提供
 firewalld支持划分区域zone,每个zone可以设置独立的防火墙规则
 归入zone顺序:
 先根据数据包中源地址,将其纳为某个zone
 纳为网络接口所属zone
 纳入默认zone,默认为public zone,管理员可以改为其它zone
 网卡默认属于public zone,lo网络接口属于trusted zone

2.firewalld zone分类

Paste_Image.png

Paste_Image.png

3.firewalld配置

 firewall-cmd --get-services 查看预定义服务列表
 /usr/lib/firewalld/services/*.xml预定义服务的配置
 三种配置方法
 firewall-config (firewall-config包)图形工具
 firewall-cmd (firewalld包)命令行工具
 /etc/firewalld 配置文件,一般不建议

firewalld-cmd命令选项

 --get-zones 列出所有可用区域
 --get-default-zone 查询默认区域
 --set-default-zone=<ZONE> 设置默认区域
 --get-active-zones 列出当前正使用的区域
 --add-source=<CIDR>[--zone=<ZONE>]
添加源地址的流量到指定区域,如果无--zone= 选项,使用默认区域
 --remove-source=<CIDR> [--zone=<ZONE>]
从指定区域中删除源地址的流量,如果无--zone= 选项,使用默认区域
 --add-interface=<INTERFACE>[--zone=<ZONE>]
添加来自于指定接口的流量到特定区域,如果无--zone= 选项,使用默认区域
 --change-interface=<INTERFACE>[--zone=<ZONE>]
改变指定接口至新的区域,如果无--zone= 选项,使用默认区域
 --list-all [--zone=<ZONE>]
列出指定区域的所有配置信息,包括接口,源地址,端口,服务等,如果无--zone=选项,使用默认区域
 --add-service=<SERVICE> [--zone=<ZONE>]
允许服务的流量通过,如果无--zone= 选项,使用默认区域
 --add-port=<PORT/PROTOCOL>[--zone=<ZONE>]
允许指定端口和协议的流量,如果无--zone= 选项,使用默认区域
 --change-interface=<INTERFACE>[--zone=<ZONE>]
改变指定接口至新的区域,如果无--zone= 选项,使用默认区域
 --list-all [--zone=<ZONE>]
列出指定区域的所有配置信息,包括接口,源地址,端口,服务等,如果无--zone= 选项,使用默认区域
 --add-service=<SERVICE> [--zone=<ZONE>]
允许服务的流量通过,如果无--zone= 选项,使用默认区域
 --add-port=<PORT/PROTOCOL>[--zone=<ZONE>]
允许指定端口和协议的流量,如果无--zone= 选项,使用默认区域

eg:

 查看默认zone
firewall-cmd --get-default-zone
 默认zone设为dmz
firewall-cmd --set-default-zone=dmz
 在internal zone中增加源地址192.168.0.0/24的永久规则
firewall-cmd --permanent --zone=internal --
add-source=192.168.0.0/24
 在internal zone中增加协议mysql的永久规则
firewall-cmd --permanent –zone=internal --addservice=mysql
 加载新规则以生效
firewall-cmd --reload

4.配置firewalld

 systemctl mask iptables
 systemctl mask ip6tables
 systemctl status firewalld
 systemctl enable firewalld
 systemctl start firewalld
 firewall-cmd --get-default-zone
 firewall-cmd --set-default-zone public
 firewall-cmd --permanent --zone=public --list-all
 firewall-cmd --permanent --zone=public --addport 8080/tcp
 firewall-cmd ---reload

5.其他规则

 当基本firewalld语法规则不能满足要求时,可以使用以下更
复杂的规则
 rich-rules 富规则,功能强,表达性语言
 Direct configuration rules 直接规则,灵活性差
帮助:man 5 firewalld.direct

(1)管理rich规则

 rich规则比基本的firewalld语法实现更强的功能,不仅实现
允许/拒绝,还可以实现日志syslog和auditd,也可以实现端
口转发,伪装和限制速率
 rich语法:
rule
[source]
[destination]
service|port|protocol|icmp-block|masquerade|forward-port
[log]
[audit]
[accept|reject|drop]
 man 5 firewalld.richlanguage
rich规则选项

Paste_Image.png

 拒绝从192.168.0.11的所有流量,当address 选项使用source 或 destination时,必须用family= ipv4 |ipv6.
firewall-cmd --permanent --zone=classroom --add-richrule='rule family=ipv4 source address=192.168.0.11/32 reject‘
 限制每分钟只有两个连接到ftp服务
firewall-cmd --add-rich-rule=‘rule service name=ftp limit value=2/m accept’
 抛弃esp( IPsec 体系中的一种主要协议)协议的所有数据包
firewall-cmd --permanent --add-rich-rule='rule protocol value=esp drop'
 接受所有192.168.1.0/24子网端口范置7900-7905的TCP流量
firewall-cmd --permanent --zone=vnc --add-rich-rule='rule family=ipv4 source address=192.168.1.0/24 port port=7900-7905 protocol=tcp accept'

(2)rich服务

 log [prefix="<PREFIX TEXT>" [level=<LOGLEVEL>] [limit value="<RATE/DURATION>"]
 <LOGLEVEL> 可以是 emerg,alert, crit, error, warning, notice, info, debug.
 <DURATION> s:秒, m:分钟, h:小时, d:天
 audit [limit value="<RATE/DURATION>"]
eg:

 接受ssh新连接,记录日志到syslog的notice级别,每分钟最多三条信息
firewall-cmd --permanent --zone=work --add-richrule='rule service name="ssh" log prefix="ssh " level="notice" limit value="3/m" accept
 从2001:db8::/64子网的DNS连接在5分钟内被拒绝,并记录到日志到audit,每小时最大记录一条信息。
firewall-cmd --add-rich-rule='rule family=ipv6 source address="2001:db8::/64" service name="dns" audit limit value="1/h" reject' --timeout=300

6.规则演示

 firewall-cmd --permanent --add-rich-rule='rule
family=ipv4 source address=172.25.X.10/32 service
name="http" log level=notice prefix="NEW HTTP "
limit value="3/s" accept'
 firewall-cmd --reload
 tail -f /var/log/messages
 curl http://serverX.example.com

7.伪造和端口转发

 NAT网络地址转换,firewalld支持伪造和端口转发两种NAT方式
 伪造NAT
 firewall-cmd --permanent --zone=<ZONE> --addmasquerade
 firewall-cmd --permanent --zone=<ZONE> --addrich-rule='rule family=ipv4 source address=192.168.0.0/24 masquerade'

(1)端口转发

 端口转发:将发往本机的特定端口的流量转发到本机或不同机器的另一个端口。通常要配合地址伪造才能实现
 firewall-cmd --permanent --zone=<ZONE> --addforwardport=port=<PORTNUMBER>:proto=<PROTOCOL>[:toport=<PORTNUMBER>][:toaddr=<IPADDR>]
说明:toport= 和toaddr= 至少要指定一个
 示例:
转发传入的连接513/TCP,到访火墙的132/TCP到public zone的192.168.0.254
firewall-cmd --permanent --zone=public --addforward-port=port=513:proto=tcp:toport=132:toaddr=192.168.0.254

(2)rich规则语法

 rich规则语法:
 forward-port port=<PORTNUM> protocol=tcp|udp [toport=<PORTNUM>]
[to-addr=<ADDRESS>]
 示例:
转发从192.168.0.0/26来的,发往80/TCP的流量到防火墙的端口8080/TCP
firewall-cmd --permanent --zone=work --add-richrule='rule
family=ipv4 source address=192.168.0.0/26
forward-port port=80 protocol=tcp to-port=8080'
eg:

 firewall-cmd --permanent --add-rich-rule 'rule family=ipv4 source address=172.25.X.10/32 forwardport port=443 protocol=tcp to-port=22'
 firewall-cmd --reload
 ssh -p 443 serverX.example.com
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,099评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,473评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,229评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,570评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,427评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,335评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,737评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,392评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,693评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,730评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,512评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,349评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,750评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,017评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,290评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,706评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,904评论 2 335

推荐阅读更多精彩内容