一键屏蔽指定国家所有的IP访问your Linux VPS

FISHERMAN’S BLOG.人生在世,看得穿,又看得远者prevail everywhere.: 一键屏蔽指定国家所有的IP访问your Linux VPS

本脚本适用于CentOSDebianUbuntu等常用系统。

使用root运行以下命令:

封禁ip时会要求你输入国家代码,代码查看:点击进入。记住所填参数均为小写字母。比如JAPAN (JP),我们就输入jp这个参数.

总结

一键屏蔽可以有效帮我们暂时防止一些CC攻击等,或者你不想让哪国的人进入博客也可以用,注意屏蔽cn的时候需谨慎,不然你SSH就上不去了。

———-

使用ipset设置防火墙端口白名单,只让指定国家访问.

一键屏蔽指定国家IP的教程,查看:’一键屏蔽指定国家所有的IP访问your Linux VPS’,这对于我们阻止某个国家访问网站和CC攻击还是很有用的,不过鉴于很多人需要白名单设置方法,研究了下,发现也可以用ipset来完成,这里就说下,目前测试是没问题的。

方法

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、创建规则

#创建一个名为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、设置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端口,等于无法访问你的网站,其它端口还是可以访问的。

4、删除规则

#将参数里的-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命令保存下,保存命令可能在很多系统中都不通用,这里就不说了,需要各位自行搜索解决了,有耐心的也可以每次重启的时候都重新设置一下防火墙。