Rat's

Linux VPS使用ipset快速屏蔽指定国家的IP访问
说明:ipset是iptables的扩展,它允许你创建匹配整个IP地址集合的规则。可以快速的让我们屏蔽某个IP段。...
扫描右侧二维码阅读全文
10
2018/04

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

说明:ipsetiptables的扩展,它允许你创建匹配整个IP地址集合的规则。可以快速的让我们屏蔽某个IP段。这里分享个屏蔽指定国家访问的方法,有时候还可以有效的帮网站阻挡下攻击。

方法

首先需要得到国家IP段,下载地址:http://www.ipdeny.com/ipblocks/。这里以我们国家为例。

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

方法参考:Blocking attack Ips/ddos Ips from China

Vultr新用户注册送100美元/16个机房按小时计费,支持支付宝,【点击查看】。
最后修改:2018 年 05 月 17 日 10 : 42 AM

发表评论

4 条评论

  1. xxx

    谢谢你的教程,请问怎么加入开机/重启自动加载?我关机或者重启iptables 会导致不生效了,另外能自定义黑名单ip就返回404或者403之类的页面么,谢谢

    1. Rat's
      @xxx

      这个页面是web服务器配置的,比如nginx啥的,开机自启可以放到rc.local文件中,可以搜索下相关用法

  2. vv

    这个开了后,连SSH都进不去,能设置成CNIP可访问VPS的SSH服务吗?

    1. Rat's
      @vv

      用cn的话,肯定连自己也屏蔽了,你可以用Daili上,推荐Xshell客户端。或者用另一个服务器转发22端口。