完全用 GNU/Linux 工作

07. 簡易的防火牆 - UFW & GUFW

從 2008 年開始 Ubuntu 8.04 LTS 多了個簡單的防火牆「UFW (Uncomplicated Firewall)」,它簡化了 iptable 複雜的指令及參數,讓人們能快速上手,之後更出現了圖形介面的 GUFW (甚至連指令都免了)。原先為了 Ubuntu 而誕生的 UFW 現在也成功移植到基於 Debian 發展的 GNU/Linux (ezgo, Linux Mint) 以及 Arch Linux

UFW

若系統尚未預載 UFW,請手動安裝。

  1. # Debian, Ubuntu
  2. $ sudo aptitude install ufw
  3. # Arch Linux
  4. $ sudo pacman -S ufw

基礎操作

狀態查詢,預設為閒置 (inactive)。

  1. $ sudo ufw status
  2. Status: inactive

啟動 UFW 服務 (enable)。

  1. $ sudo ufw enable

預設 (default) 全部阻擋 (deny)。

  1. $ sudo ufw default deny

允許 (allow) 所有的 ssh 埠口連線。

  1. $ sudo ufw allow ssh

允許來自 127.0.0.1 (本機) 的 3389 埠口連線 (xrdp)。

  1. $ sudo ufw allow from 127.0.0.1 to any port 3389

狀態查詢,已成功啟動 (active) 並加入自訂規則。

  1. $ sudo ufw status
  2. Status: active
  3. To Action From
  4. -- ------ ----
  5. 22 ALLOW Anywhere
  6. 3389 ALLOW 127.0.0.1

進階使用

允許來自 192.168.1.2 上所有連線。

  1. $ sudo ufw allow from 192.168.1.2

允許來自 192.168.2.1 ~ 192.168.2.254 的所有 22 埠口連線。

  1. $ sudo ufw allow from 192.168.2.1/24 to any port 22

阻擋來自 110.88.4.5 的 22 埠口連線。

  1. $ sudo ufw deny from 110.88.4.5 to any port 22

阻擋來自 27.16.3.1 ~ 27.16.3.254 的所有連線。

  1. $ sudo ufw deny from 27.16.3.0/24

GUFW

圖形介面的 GUFW 必須手動安裝,但不建議純文字環境的 GNU/Linux 安裝,它會與一些桌面環境 (Desktop Environment) 的套件產生相依性,例如 gir1.2-gtk-3.0, notify-osd … 等。

  1. # Debian, Ubuntu
  2. $ sudo aptitude install gufw
  3. # Arch Linux
  4. $ sudo pacman -S gufw

圖形操作

開啟 GUFW:

請於應用程式 (Application) -> 系統 (System) -> 管理 (Administration) -> 防火牆設定 (Firewall configuration)開啟;或直接於終端機輸入指令開啟。

  1. $ gufw

2013-09-24-gufw-01.png

▲ 使用前得先用管理者帳號解鎖 (Unlock)。

2013-09-24-gufw-02.png

▲ 輸入密碼。

2013-09-24-gufw-03.png

▲ 解鎖後可看到先前自訂的規則,以下為新增規則之範例。

2013-09-24-gufw-04.png

▲ 可依應用程式自訂規則。

2013-09-24-gufw-05.png

▲ 也可自行輸入埠口。

2013-09-24-gufw-06.png

▲ 進階設定裡則可依範圍自訂規則。

看完此文後,相信大家都能幫 GNU/Linux 加上一道防護,但 ufw 這面防護罩只適合簡易、單純的環境,若有 NAT 或更進階的使用還請改用 iptable。

資料來源