最近因為CENTOS 7 辦事會莫名的封閉,查了發現是KENERL問題,所以決意升到CENTOS 8-9,
我的INTEL雙網網卡 來當作家裡的firewall, 於是安裝了CENTOS 8 - 9, 並用pppoe 來毗連中華電信的Router, 而且寫了一些iptables 的rules 來看成firewall 及NAT router.
然則感覺有問題, 有時連不出去. 現象是這樣的:
然則在NAT 後面的電腦,GOOGLE PTT網站 連線都很ok, , 只要碰上yahoo跟遊戲 的連線, 就連不上, ftp 也ok.
這問題擺了很久都沒去理睬. 今天終於有空好好的來追問題的泉源. 發現似乎是跟pppoe 有關.
問了小洲大大才發現
MTU
MTU (Maximum Transmission Unit) 是指網路介面卡上最大傳輸單元, 其單元為bytes. 在大多數的Ehternet 上, 這個值每每是1500. 因為如斯, 在PPPoE 中, 因為還有header問題, 所以這個值就得設的比較小, 平常為1492 (= 1500 – 2(PPP)- 6(PPPoE))
MSS
MSS (Maximum segment size) 是TCP protocol 中的一個參數, 是指TCP 每次資料傳輸分段的最大值. 當TCP 在handshake 時, 雙方host 會查看MSS 這個欄位, 來決議兩邊資料傳輸分段的巨細. 在Ethernet 中MSS 值最大為1460 bytes.
原因是在Ethernet 中 MTU = IP Header + TCP Header + MSS + FCS.
(FCS 是指Frame check sequence, 通常採用CRC演算法, 在Ethernet 中, 它佔4 bytes.)
可是在PPPoE 中MTU 為1492, 所以其MSS 只能設為1452.
問題地點
當CENTOS 8 在開機後, 啟動了ppp0, 其內定將MTU 設為1492, 而且會主動設定一條iptable rule,
因為在NAT 後面的電腦, 並不知道前真個router 是用什麼介面連到internet, 所以它和遠真個電腦設立建設TCP 連線時, 有可能會將MSS 設為1460. 但是由於firewall 或router 端利用PPPoE連線, 若MSS 大於1452會造成資料爆掉, 所以上述的iptable rule 強制偷改其MSS值(在IPV4下 = PMTU – 40, 在IPV6下 = PMTU – 60). 是以MSS 就會被改成1452, 如許子就不會爆掉了.
但是我本身寫的iptable rule script 中, 一最先就用了以下設定, 清除了原來的所有設定
- # 斷根所有法則
- iptables -F -t filter
- iptables -X -t filter
- iptables -Z -t filter
- iptables -F -t mangle
- iptables -X -t mangle
- iptables -Z -t mangle
- iptables -F -t nat
- iptables -X -t nat
- iptables -Z -t nat