Login

Navigation

This articles is published 1016 days ago and last updated 998 days ago, some information may be out of date.

MikroTik RouterOS 7 回流問題解決方案

Hairpin-NAT-setup.jpg

前言:
官方Hairpin NAT是指NAT Loopback 即我們所說的回流,意思是LAN(同一內網)的裝置透過Public IP地址訪問LAN內的另一部伺服器,而沒有得到回應的問題。
如何產生回流-範例:
  • LAN內網裝置A(10.1.1.10)想透過Public IP (221.112.252.254)訪問LAN內網的WEB伺服器B(10.1.1.99)。
  • WEB伺服器B回應裝置A時,因為是同一網段10.1.1.0/24,所以WEB伺服器B不會經路由器(MikroTik Router)的Public IP作回應,而是直接回覆內網裝置A(10.1.1.10)使用10.1.1.99作為源地址。
  • 內網裝置A(10.1.1.10)收到封包是WEB伺服器B(10.1.1.99),而不是原Public IP (221.112.252.254)的封包,最終會被丟棄。

解決方案:

處理流程:
利用官方 Hairpin NAT 的解決方案
內網段伺服器IP端口
12.2.2.0/2412.2.2.9980,443

2022-04-08_142530.png

2022-04-08_142546.png

Terminal 設定

端口轉發(Port Forwarding) rules

/ip firewall nat
add action=masquerade chain=srcnat out-interface=WAN
add action=dst-nat chain=dstnat dst-port=80,443 protocol=tcp to-addresses=12.2.2.99

解決方法,新增src-nat rule

ip firewall nat add action=masquerade chain=srcnat out-interface=LAN protocol=tcp src-address=12.2.2.0/24

返回目錄內容

利用DDNS功能的解決方案 (更多應用於動態的Public IP)
如果是官方購買的路由器可以到IP > Cloud 啟用DDNS功能,也可以用購買的域名做DNS A記錄。

IP > Firewall > Address Lists > 新增 + (官方的DDNS網址或購買的域名)

Name:Dynamic_IP(可隨意)

Address: 購買的域名地址

2022-04-08_153742.png

啟用動態流量偽裝

2022-04-08_153913.png

建立端口轉發(Port Forwarding) rules

2022-04-08_153948.png

2022-04-08_154002.png

解決方法: Advanced > Dst.Address List: 選取剛建立的Address Lists 名稱為Dynamic_IP

2022-04-08_153956.png

Terminal 設定

啟用動態流量偽裝

/ip firewall nat
add action=masquerade chain=srcnat

解決方法:
利用DDNS建立Address Lists

/ip firewall address-list
add address=kingtam.win list=Dynamic_IP

修改原有的端口轉發(Port Forwarding) rules內的Address Lists

/ip firewall nat
add action=dst-nat chain=dstnat dst-address-list=Dynamic_IP dst-port=80 protocol=tcp to-addresses=12.2.2.99 to-ports=80
add action=dst-nat chain=dstnat dst-address-list=Dynamic_IP dst-port=443 protocol=tcp to-addresses=12.2.2.99 to-ports=443

返回目錄內容

利用 Jump 命令的解決方案

建立腳本(script)及排程(Scheduler),用於更新動態的Public IP

2022-04-08_112955.png

腳本(script)內容

:global addold
:global addnew
:set addnew [/interface get [/interface find name="WAN"] running]
:if ($addnew=true) do={
:set addold [/ip address get [/ip address find dynamic=yes interface="WAN"] address]
:set addold [:pick $addold 0 ([:len $addold ] -3)]
/ip firewall nat set [/ip firewall nat find comment="dynamic_nat"] dst-address=$addold
}
變量註解
addold更新前IP變量
addnew更新後IP變量
WANPublic網口WAN的名稱 (*根據路由器網口名稱變更)
dynamic_natnat表內查找comment(註釋)為"dynamic_nat"的rule, 更新其dst-address為現在使用的IP Address

NAT表建立jump ruleJump Target: Hairpin_NAT

2022-04-08_122452.png

需要添加Comment(註釋)為dynamic_nat,因為上一步新增的腳本是根據Comment來更新rule內的Dst.Address

最後添加端口轉發(Port Forwarding) rules,其中ChainHairpin_NAT

2022-04-08_122648.png

Terminal 設定

建立腳本(script),用於更新動態的Public IP

/system script
add dont-require-permissions=no name=dynamic_nat owner=admin policy=\
    ftp,reboot,read,write,policy,test,password,sniff,sensitive,romon source=":global addold\r\
    \n:global addnew\r\
    \n:set addnew [/interface get [/interface find name=\"WAN\"] running]\r\
    \n:if (\$addnew=true) do={\r\
    \n:set addold [/ip address get [/ip address find dynamic=yes interface=\"WAN\"] address]\r\
    \n:set addold [:pick \$addold 0 ([:len \$addold ] -3)]\r\
    \n/ip firewall nat set [/ip firewall nat find comment=\"dynamic_nat\"] dst-address=\$addold\r\
    \n}"

建立排程(Scheduler)

/system scheduler
add interval=10m name=dynamic_nat on-event=dynamic_nat policy= ftp,reboot,read,write,policy,test,password,sniff,sensitive,romon start-time=startup

NAT表建立jump ruleJump Target: Hairpin_NAT

/ip firewall nat
add action=jump chain=dstnat comment=dynamic_nat dst-address=20.13.3.87 jump-target="Hairpin NAT"

最後添加端口轉發(Port Forwarding) rules,其中ChainHairpin_NAT

/ip firewall nat
add action=dst-nat chain="Hairpin NAT" dst-port=80 protocol=tcp to-addresses=12.2.2.2 to-ports=80
add action=dst-nat chain="Hairpin NAT" dst-port=443 protocol=tcp to-addresses=12.2.2.2 to-ports=443
add action=masquerade chain=srcnat

返回目錄內容

結語:
三種解決方案可根據自身情況進行選擇及設定,最為簡單是使用路由器自帶的DDNS功能域名地址解決,也可以透過DNSStatic功能處理回流問題。
參考資料:

There're 3 comments