介绍ipsetiptables的扩展,它允许你创建匹配整个IP地址集合的规则。可以快速的让我们屏蔽某个IP段。这里分享个屏蔽指定国家访问的方法,有时候还可以有效的帮网站阻挡下攻击。这对于我们阻止某个国家访问网站和CC攻击还是很有用的,不过鉴于很多人需要白名单设置方法,也可以用ipset来完成,这里就说下,目前测试是没问题的。下面介绍三种方法

使用ipset快速屏蔽指定国家的IP访问

首先需要得到国家IP段,下载地址。这里以我们国家为例。

1、安装ipset

#Debian/Ubuntu系统
apt-get -y install ipset

#CentOS系统
yum -y install ipset

2、创建规则

#创建一个名为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

3、开始屏蔽

iptables -I INPUT -p tcp -m set --match-set cnip src -j DROP

4、解除屏蔽

#-D为删除规则
iptables -D INPUT -p tcp -m set --match-set cnip src -j DROP

### 利用脚本一键屏蔽指定国家所有的IP访问 本脚本适用于CentOS、Debian、Ubuntu等常用系统。 使用root运行以下命令: wget https://github.com/YLiteraturePro/LiteraturePro/blob/master/block-ips.sh chmod +x block-ips.sh ./block-ips.sh 封禁ip时会要求你输入国家代码,[代码查看][2]。记住所填参数均为小写字母。比如JAPAN (JP),我们就输入jp这个参数。 演示: #### 1、封禁IP ![][3] #### 2、查看封禁列表 ![][4] #### 3、解封IP ![][5]
### 使用ipset设置防火墙端口白名单,只让指定国家访问 首先需要得到国家IP段,[下载地址][6]。这里以我们国家为例。 #### 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命令保存下,保存命令可能在很多系统中都不通用,这里就不说了,需要各位自行搜索解决了,有耐心的也可以每次重启的时候都重新设置一下防火墙。
[1]: http://www.ipdeny.com/ipblocks/ [2]: https://www.ipdeny.com/ipblocks/ [3]: https://jscdn.cachefly.net/web/wxiou/20200630174706.png [4]: https://jscdn.cachefly.net/web/wxiou/20200630174755.png [5]: https://jscdn.cachefly.net/web/wxiou/20200630174835.png [6]: http://www.ipdeny.com/ipblocks/
最后修改:2020 年 07 月 24 日
如果觉得我的文章对你有用,请随意赞赏