站务联系

服务器屏蔽所有境外(国外)IP段

发布时间:2021-03-09   来源:网络整理    
字号:

1、安装ipset

Debian/Ubuntu系统

apt-get -y install ipset

CentOS系统

yum -y install ipset

CentOS 7还须要关掉firewall防火墙

systemctl stop firewalld.service
systemctl disable firewalld.service

2、清空之前的规则

防止设置不生效,建议清空下之前的防火墙规则

iptables -P INPUT ACCEPT
iptables -F

3、创建新规则

创建一个名为cnip的规则

ipset -N cnip hash:net

下载国家IP段,这里以美国为例

wget -P . http://www.ipdeny.com/ipblocks/data/countries/cn.zone

将IP段添加至cnip规则中

for i in $(cat /root/cn.zone ); do ipset -A cnip $i; done

4、设置IP段白名单

放行IP段

iptables -A INPUT -p tcp -m set --match-set cnip src -j ACCEPT

关掉所有端口

iptables -P INPUT DROP

这时候就只有指定国家的IP能访问服务器了。

如果你在国外,网站不容许被国外人访问,建议别关所有端口,这样你的SSH会上不去,我们可以只关掉80/443端口。

关闭指定端口,比如80/443

iptables -A INPUT -p tcp --dport 80 -j DROP
iptables -A INPUT -p tcp --dport 443 -j DROP

这时候其他国家的IP是难以访问你服务器的80/443端口,等于难以访问你的网站,其它端口还是可以访问的。

5、删除规则

将参数里的-A改成-D就是删掉规则了,如

iptables -D INPUT -p tcp -m set --match-set cnip src -j ACCEPT
iptables -D INPUT -p tcp --dport 443 -j DROP

说明:

设置防火墙后,可能有些服务器重启系统后会清空防火墙规则国外服务器,导致设置的失效国外服务器,所以我们设置规则后,需要使用iptables命令保存下,保存命令或许在这些系统中都不通用,这里就不说了,需要诸位自行搜索解决了,有耐心的也可以每天重启的时侯都再次设置一下防火墙。

图说天下

×
二维码生成