1. MARK作用
给特定的数据包打上标记,配合TC做【QOS流量限制】 或 【策略路由实现】。
2. MARK相关的模块
libxt_mark.so
libxt_connmark.so
libxt_MARK.so
libxt_CONNMARK.so
libxt_SECMARK.so
libxt_CONNSECMARK.so
小写是匹配模块,大写是标记模块。
带CONN的是标记链接,不带的是标记数据包。
带SEC的是处理IPSEC数据,不带的是处理一般数据。
-m 匹配
-m mark --mark value[/mask]
如果指定了掩码,就先把mark值和掩码取逻辑与,然后再和包的mark值比较。
-j 标记
-j MARK 标记数据包
--set-mark #标记数据包
-j CNNMARK 标记链接
--set-mark #标记链接
--save-mark #保存数据包中的MARK到链接中
--restore-mark #将链接中的MARK设置到同一链接的其它数据包中
示例
# 数据包标记为50
iptables -t mangle -A PREROUTING -j MARK --set-mark 50
# 匹配标记为50的数据包,并保存数据包中的标记设置到链接中
iptables -t mangle -A PREROUTING -m mark --mark 50 -j CONNMARK --save-mark
# 链接标记为50
iptables -t mangle -A PREROUTING -j CONNMARK --set-mark 50
# 匹配链接标记为50数据包,并将链接中的标记设置到数据包中
iptables -t mangle -A PREROUTING -m connmark --mark 50 -j CONNMARK --restore-mark
3. 应用
–restore-mark 与 --set-mark 和 --save-mark 进行配合,完成给链接打标记,进而为链接上的所有数据包打标记。
iptables -A POSTROUTING -t mangle -j CONNMARK --restore-mark
iptables -A POSTROUTING -t mangle -m mark ! --mark 0 -j ACCEPT
iptables -A POSTROUTING -t mangle -m mark --mark 0 -p tcp --dport 21 -j MARK --set-mark 1
iptables -A POSTROUTING -t mangle -m mark --mark 0 -p tcp --dport 80 -j MARK --set-mark 2
iptables -A POSTROUTING -t mangle -m mark --mark 0 -p tcp -j MARK --set-mark 3
iptables -A POSTROUTING -t mangle -j CONNMARK --save-mark
- 规则1,完成了将链接跟踪上的标记记录到该连接上的每一个数据包中。
- 规则2,匹配数据包标记不为0的数据包,直接ACCEPT。如果为0,则交由后面的规则进行匹配并打标记。
如果一条链接的第1个数据包经过规则1后,由于ct->mark为0,所以其数据包标记skb->nfmark也为0,就需要进行后面规则的匹配。 - 规则3~5,按照匹配选项对符合规则的数据包打上不同的标记。
- 规则6,将数据包上的标记记录到链接跟踪上。
当属于该链接的下一个数据包走到规则1后,就会被打上标记,命中第2条规则,直接ACCEPT。