詳述Linux中Firewalld高級配置的使用
IP偽裝與端口轉發(fā)
Firewalld支持兩種類型的網絡地址轉換
IP地址偽裝(masquerade)
- 可以實現局域網多個地址共享單一公網地址上網
- IP地址偽裝僅支持IPv4,不支持IPv6
- 默認external區(qū)域啟用地址偽裝
端口轉發(fā)(Forward-port)
- 也稱為目的地址轉換或端口映射
- 通過端口轉發(fā),指定IP地址及端口的流量將被轉發(fā)到相同計算機上的不同端口,或者轉發(fā)到不同計算機上的端口
地址偽裝配置
為指定區(qū)域增加地址偽裝功能
firewall-cmd [--permanent] [--zone= zone] --add-masquerade [--timeout seconds] //--timeout=seconds:在一段時間后自動刪除該功能
為指定區(qū)域刪除地址偽裝功能
firewall-cmd [--permanent] [--zone= zone] --remove-masquerade
查詢指定區(qū)域是否開啟地址偽裝功能
firewall-cmd [--permanent] [--zone=zone] --query-masquerade
端口轉發(fā)配置
列出端口轉發(fā)配置
firewall-cmd [--permanent] [--zone=zone] --list-forward-ports
添加端口轉發(fā)規(guī)則
firewall-cmd [--permanent] [--zone=zone] --add-forward-port=port=portid[-portid]:proto=protocol[:toport-portid[-portid]][:toaddr-address[/mask]][--timeout=seconds]
刪除端口轉發(fā)規(guī)則
firewall-cmd [--permanent] [--zone=zone] --remove-forward-port=port=portid[-portid]:proto=protocol[:toport=portid[-portid]][:toaddr=address[/mask]]
查詢端口轉發(fā)規(guī)則
firewall-cmd [--permanent] [--zone=zone] --query-forward-port-port-portid[-portid]:proto=protocol[:toport-portid[-portid]][:toaddr=address[/mask]]
Firewalld直接規(guī)則
直接規(guī)則(direct interface)
- 允許管理員手動編寫的iptables、ip6tables和ebtables 規(guī)則插入到Firewalld管理的區(qū)域中
- 通過firewall-cmd命令中的--direct選項實現
- 除顯示插入方式之外,優(yōu)先匹配直接規(guī)則
自定義規(guī)則鏈
Firewalld自動為配置”了 規(guī)則的區(qū)域創(chuàng)建自定義規(guī)則鏈
允許TCP/9000端口的入站流量
irewall-cmd --direct --add-rule ipv4 filter IN work_ allow 0 -p tcp --dport 9000 j ACCEPT
- IN work_ allow: 匹配work區(qū)域的規(guī)則鏈
- 0:代表規(guī)則優(yōu)先級最高,放置在規(guī)則最前面
- 可以增加 --permanent選項表示永久配置
查詢所有的直接規(guī)則
firewall-cmd --direct --get-all-rules ipv4 filter IN_ work _allow 0 -p tcp --dport 9000 -j ACCEPT
可以增加 --permanent選項表示查看永久配置
Firewalld富語言規(guī)則
富語言(rich language)
表達性配置語言,無需了解iptables語法
用于表達基本的允許/拒絕規(guī)則、配置記錄(面向syslog和auditd)、端口轉發(fā)、偽裝和速率限制
rule [family="<rule family>"] [ source address="<address>" [invert "True"] ] [ destination address="<address>" [invert="True"] ] [ <element> ] [ log [prefix="<prefix text>"] [level="<log level>"] [limit value="rate/duration"] ] [ audit ] [ acceptlrejectldrop ]
理解富語言規(guī)則命令
firewall-cmd處理富語言規(guī)則的常用選項
選項 | 說明 |
---|---|
-add-rich-rule= 'RULE' | 向指定區(qū)域中添加RULE,如果沒有指定區(qū)域,則為默認區(qū)域 |
--remove-rich-rule= 'RULE' | 從指定區(qū)域中刪除RULE,如果沒有指定區(qū)域,則為默認區(qū)域 |
--query-rich-rule= 'RULE' | 查詢RULE是否已添加到指定區(qū)域,如果未指定區(qū)域,則為默認區(qū)域。<br/>規(guī)則存在,則返回0,否則返回1 |
--list-rich-rules | 輸出指定區(qū)域的所有富規(guī)則,如果未指定區(qū)域,則為默認區(qū)域 |
已配置富語言規(guī)則顯示方式
firewall-cmd --list-all firewall-cmd --list-all-zones --list-rich-rules
富語言規(guī)則具體語法
source、destination、 element、 service、 port、 protocol、icmp-block、masquerade、 forward-port、 log、 audit、acceptlreject|drop
拒絕從192.168.8.101的所有流量
firewall-cmd --permanent --zone=work --add-rich-rule='rule family=ipv4 source address=192.168.8.101/32 reject'
ddress選項使用source或destination時,必須用family= ipv4 | ipv6
接受192.168.1.0/24子網端口范置8000-9000的TCP流量
firewall-cmd --permanent --one=work --add-rich-rule='rule family=ipv4 source address=192.168.1.0/24 port port=8000-9000 protocol=tcp accept'
丟棄所有icmp包
firewall-cmd --permanent --add-rich-rule='rule protocol value=icmp drop'
接受來自192.168.8.1的http流量,并記錄日志
firewall-cmd --add-rich-rule='rule family=ipv4 source address=192.168.8.1/32 service name="http" log level=notice prefix= "NEW HTTP”limit value "3/s" accept'
以192.168.8.1訪問http,并觀察/var/log/messages
Apr 16 17:09:55 Server kernel: NEW HTTP IN=ens33 OUT= MAC=00:0c:29:69:01:c4:00:50:56:c0:00:08:08:00 SRC=192.168.8.1 DST=192.168.8.131 LEN=52 TOS=0xOO PREC=0x00 TTL =64 ID=20582 DF PROTO=TCP SPT=65289 DPT=80 WINDOW=8192 RES=0x00 SYN URGP=0 Apr 16 17:09:55 Server kernel: NEW HTTP IN=ens33 OUT= MAC=00:0c:29:69:01:c4:00:50:56:c0:00:08:08:00 SRC=192.168.8.1 DST=192.168.8.131 LEN=52 TOS=0x0O PREC=0x0O TTL =64 ID=20590 DF PROTO=TCP SPT=65291 DPT=80 WINDOW=8192 RES=0x00 SYN URGP=0 Apr 16 17:09:55 Server kernel: NEW HTTP IN=ens33 OUT= MAC=00:0c:29:69:01:c4:00:50:56:c0:00:08:08:00 SRC=192.168.8.1 DST=192.168.8.131 LEN=52 TOS=0x0O PREC=0x0O TTL =64 ID=20602 DF PROTO=TCP SPT=65292 DPT=80 WINDOW=8192 RES=0x00 SYN URGP=0
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持我們。
欄 目:Linux/apache
下一篇:Linux命令創(chuàng)建日期文件夾或者文件的實例代碼
本文地址:http://mengdiqiu.com.cn/a1/Linux_apache/10746.html
您可能感興趣的文章
- 04-02linux關閉串口命令 關閉linux端口命令
- 04-02linux文件命令重命名 linux重命名文件名命令
- 04-02linux命令注入過濾 linux 代碼注入
- 04-02linux中jobs命令 shell jobs命令
- 04-02linux依次執(zhí)行命令 linux命令的執(zhí)行過程是怎樣的?新手必讀
- 04-02linux命令免輸入 linux配置免密登錄
- 04-02linux命令注銷vnc linux命令行注銷用戶
- 04-02軟交換linux命令 軟交換網絡主要協(xié)議有哪些
- 04-02linux命令歷史記錄 linux查看歷史記錄的操作命令
- 04-02linux命令頁面 linux命令頁面中文


閱讀排行
本欄相關
- 04-02linux關閉串口命令 關閉linux端口命令
- 04-02linux文件命令重命名 linux重命名文件名
- 04-02linux中jobs命令 shell jobs命令
- 04-02linux命令注入過濾 linux 代碼注入
- 04-02linux依次執(zhí)行命令 linux命令的執(zhí)行過程
- 04-02linux命令注銷vnc linux命令行注銷用戶
- 04-02linux命令免輸入 linux配置免密登錄
- 04-02軟交換linux命令 軟交換網絡主要協(xié)議
- 04-02linux命令歷史記錄 linux查看歷史記錄的
- 04-02linux命令頁面 linux命令頁面中文
隨機閱讀
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-11ajax實現頁面的局部加載
- 08-05dedecms(織夢)副欄目數量限制代碼修改
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-10C#中split用法實例總結
- 08-05DEDE織夢data目錄下的sessions文件夾有什