如果服务器面向的用户主要是国内用户,如何拒绝国外IP/屏蔽国外IP访问服务器?
保存下面的脚本为 allcn.sh
#!/bin/bash
mmode=$1
#wget https://ghfast.top/https://github.com/17mon/china_ip_list/blob/master/china_ip_list.txt
CNIP="/home/username/china_ip_list.txt"
gen_iplist() {
cat <<-EOF
$(cat ${CNIP:=/dev/null} 2>/dev/null)
EOF
}
flush_r() {
iptables -F ALLCNRULE 2>/dev/null
iptables -D INPUT -p tcp -j ALLCNRULE 2>/dev/null
iptables -X ALLCNRULE 2>/dev/null
ipset -X allcn 2>/dev/null
}
mstart() {
ipset create allcn hash:net 2>/dev/null
ipset -! -R <<-EOF
$(gen_iplist | sed -e "s/^/add allcn /")
EOF
iptables -N ALLCNRULE
iptables -I INPUT -p tcp -j ALLCNRULE
# 1. 放行已建立和关联的连接
iptables -A ALLCNRULE -m conntrack --ctstate ESTABLISHED,RELATED -j RETURN
# 2. 本地及内网地址放行
iptables -A ALLCNRULE -s 127.0.0.0/8 -j RETURN
iptables -A ALLCNRULE -s 169.254.0.0/16 -j RETURN
iptables -A ALLCNRULE -s 224.0.0.0/4 -j RETURN
iptables -A ALLCNRULE -s 255.255.255.255 -j RETURN
iptables -A ALLCNRULE -s 10.0.0.0/8 -j RETURN
iptables -A ALLCNRULE -s 172.16.0.0/12 -j RETURN
iptables -A ALLCNRULE -s 192.168.0.0/16 -j RETURN
# 3. 来自中国大陆 IP 放行
iptables -A ALLCNRULE -m set --match-set allcn src -j RETURN
# 4. 其余 DROP
iptables -A ALLCNRULE -p tcp -j DROP
}
# 主入口逻辑
if [ "$mmode" == "stop" ]; then
flush_r
exit 0
fi
flush_r
sleep 1
mstart
屏蔽国外IP。
./allcn.sh
解除屏蔽国外IP。
./allcn.sh stop
查看iptables,检查屏蔽或解除屏蔽的结果。
iptables -L