天下事有难易乎?为之,则难者亦易矣;不为,则易者亦难矣。

如何封禁IP和IP段?看完这篇我会了!!

itzoo 489次浏览 0个评论

点击“终码一生”,关注,置顶公众号

每日技术干货,第一时间送达!



1

写在前面


Nginx不仅仅只是一款反向代理和负载均衡服务器,它还能提供很多强大的功能,例如:限流、缓存、黑白名单和灰度发布等等。在之前的文章中,我们已经介绍了Nginx提供的这些功能。今天,我们来介绍Nginx另一个强大的功能:禁用IP和IP段。


 

2

禁用IP和IP段


Nginx的ngx_http_access_module 模块可以封配置内的ip或者ip段,语法如下:


deny IP; 
deny subnet;
allow IP;
allow subnet;
# block all ips
deny    all;
# allow all ips
allow    all;


如果规则之间有冲突,会以最前面匹配的规则为准。


配置禁用ip和ip段


下面说明假定nginx的目录在/usr/local/nginx/。


首先要建一个封ip的配置文件blockips.conf,然后vi blockips.conf编辑此文件,在文件中输入要封的ip。


deny 1.2.3.4; 
deny 91.212.45.0/24;
deny 91.212.65.0/24;


然后保存此文件,并且打开nginx.conf文件,在http配置节内添加下面一行配置:


include blockips.conf;


保存nginx.conf文件,然后测试现在的nginx配置文件是否是合法的:


/usr/local/nginx/sbin/nginx -t


如果配置没有问题,就会输出:


the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
configuration file /usr/local/nginx/conf/nginx.conf test is successful


如果配置有问题就需要检查下哪儿有语法问题,如果没有问题,需要执行下面命令,让nginx重新载入配置文件。


/usr/local/nginx/sbin/nginx -s reload


仅允许内网ip


如何禁止所有外网ip,仅允许内网ip呢?














大道至简,是宇宙万物发展之规律,是中华文化之精髓,是中华道家哲学,是大道理极其简单,简单到一两句话就能说明白。所谓“真传一句话,假传万卷书”。“万物之始,大道至简,衍化至繁”出自老子的《道德经》。大道至简,不仅被哲学流派道家、儒家等所重视,也是人生在世的生活境界。


大道至简,大道无形,大道无法,这是一种大道自然、返朴归真的高级功态。在这种清净无为、忘我无私、天人合一的状态中,不求长功,功力自然上长;不求治病,身心自然调整;不求功能,功能自然显现;你不求大小周天,百脉自然畅通,最深刻的真理是最简单最普通的真理。把最复杂的变成最简单的,才是最高明的。最伟大的人仅仅因为简单才显得崇高。


大道至简,人生亦简。开悟,深奥了就简单,简单了才深奥,从看山是山,到看山是山,境界不一样,从简单到复杂,再从复杂到简单,就是升华。生活的意义在于简单,人修炼到一定程度,会淡泊一些事,会简单,你可以理解别人,但别人不一定理解你,其实人不在理解,在认同。


精于心,简于形。拷问灵魂这是人的终极问题,简不仅是一种至美,也是一种能力、一种境界。看透了不说透,高境界;朦胧地看,心透 ;透非透、 知未知 ,故意不看透,才是透彻;知道世事看不透,就是透,透彻后的不透彻,明白后的不明白,难得糊涂是真境界。


“大道至简”是做人的智慧,做人做事要将一件复杂的事情化为简单,那是需要智慧的。将繁杂的事情回归到简单,要有智慧、能力,也要有决心。有智慧的人都喜欢大道至简,因此,功和利,不可趋之若鹜;名和财,不可为之所累。淡泊以明志,宁静以致远。我们要简简单单的做人,踏踏实实的做事,用智慧化难为简。


为名利尽抛宠辱,清纯似儿时天真的童贞,朴实如父辈耕耘的沃土,只有心情平静的人方能视见“斜阳照墟落,穷巷牛羊归”的悠闲,听闻“荷风送秋气,竹露滴清响”的天籁,感受那“空山不见人,但闻人语响”的空旷。陶渊明就是这样的人,所以他能够吟出“采菊东篱下,悠然见南山”的绝句;欧阳修也是这样的一个人,所以他在谪居时仍能悠然自得的写出《醉翁亭记》。


大道至简,人生亦简。简不是物质的贫乏,而是精神的自在;简不是生命的空虚,而是心灵的单纯。大道至简是最高的道理往往是最简明的,人要学会简单、简朴生活、简捷行事,放下自己的私心杂念,当超出自我欲望的牢笼,当真正忘记自己的思想,忘记自己的意识,进入忘我忘物的状态。


人生的繁出于惑,以“仁”抗拒诱惑,以“智”解除困惑。不惑,才是人生由繁入简的标志。弱水三千,我只取一瓢饮;人生百态,须当从一而终。乐以忘忧,简以存真,才是人生的“大道至简”。


有个大道至简、平常心是道的故事:一个行者问老道长:“您得道前,做什么?”老道长:“砍柴担水做饭。”行者问:“那得道后呢?”老道长:“砍柴担水做饭。”行者又问:“那何谓得道?”老道长:“得道前,砍柴时惦记着挑水,挑水时惦记着做饭;得道后,砍柴即砍柴,担水即担水,做饭即做饭。”老道长和行者的对话让我们开悟,许多至高至深的道理都是含蕴在一些极其简单的思想中。


大道至简,人生易简。一千个人有一千种生存方式和生活道路,走过岁月、走过生活,心里有许多的感慨,一切放下,一切自在;当下放下,当下自在,生活中的很多问题并不需要放在心里,人生的很多负担并不需要挑在肩上。一念放下,才能感受到简单生活的乐趣,才能感受到心灵飞翔的快感。要想改变一些事情,首先得把自己给找回来。我们都有潜在的能量,只是很容易:被习惯所掩盖,被时间所迷离,被惰性所消磨。我们应该记住该记住的,忘记该忘记的,改变能改变的,接受不能改变的。我们要用最少的悔恨面对过去,用最少的浪费面对现在,用最多的梦面对未来。


天地之道,简易而已。人生苦短,诸事不想太复杂,简单生活。人生这部大戏一旦拉开序幕,不管你如何怯场,都得演到戏的结尾。成长过程中最大的挑战在于有些路段,只能自己寂静地走,快乐工作、简单生活才是幸福生活,人要懂得知足常乐,所有的哀伤、痛楚,所有不能放弃的事情,不过是生命里的一个过渡,你跳过了就可以变得更精彩。


最好的生活就是简单生活,一盏茶,一张桌,一处清幽,日子平淡,心无杂念。可是简单的生活却需要百般的努力,这样才会无忧无虑欣然享受生活。生活总的来说是完美的,不完美的是心态,不懂得欣赏的人,就会用挑剔把一切变得有残缺。简单做人,率性而为,把握分寸,随遇而安,坦然接受现实;简单做事,不惹事、不生事、不怕事,不悔、不怨、不惜自己所做的事。


人生就是一场漫长对抗,有些人笑在开始,有些人却赢在最终。试着微笑,试着回眸,放松自己,不强求、不萎靡、不浮躁。简单生活,随心、随性、随缘,做最好的自己,知足、微笑、淡然,即使再苦再累,只要坚持往前走,属于自己的风景终会出现。


生活容不容易,关键看你怎么活。处境在于心境,心境改变了,处境也会改变。你向生活要得越多,你就会变得越紧张、越复杂,生活也就越不容易。反之,你对生活要求的越少,就越容易满足,越容易快乐。江山明月,本无常主,得闲便是主人;大道至简,活在当下,知足便能常乐。


悟入无怀之静境,一轮之心月独明,尽显心静之境界;心静自然从容洒脱,持心若水笑面人生,更现心静之魅力。人生在世,平淡才是最真,静默才是最美,生命里最持久的不是繁华,而是平淡,不是热闹而是清欢。保持一颗童心,不开心的时候,心无遮拦地向朋友倾诉烦恼,开心的时候,肆无忌惮地开怀大笑,也许所有的忧愁会在倾诉中流走,所有的紧张会在大笑中释放。像孩子一样,简单生活,快乐生活,保持心灵原生态,一切都是美好的。


生命里总有一个故事,想讲述却难以开口,就这样在心底,渐渐谱成了曲。人就是这样,得不到的永远向往,失去了的,才会觉到珍贵。所谓的,得失、情缘、风景、驿站,都在时光的尘烟中,慢慢淡散。虽然,有些事情放下很难,但是,不属于自己的东西,终究会走远。


人的一生,注定要经历很多。红尘路上,有朗朗的笑声,有委屈的泪水,懵懂的坚持着,有成功的自信,有失败的警醒,每一段经历注定珍贵。生命的丰盈缘于心的慈悲,生活的美好缘于拥有一颗平常心,生活简单让人轻松快乐,想法简单让人平和宁静。因为简单,才深悟生命之轻,因为简单,才洞悉心灵之静。



如下配置文件


location / { 
  # block one workstation
  deny    192.168.1.1;
  # allow anyone in 192.168.1.0/24
  allow   192.168.1.0/24;
  # drop rest of the world
  deny    all;
}


上面配置中禁止了192.168.1.1,允许其他内网网段,然后deny all禁止其他所有ip。


格式化nginx的403页面


如何格式化nginx的403页面呢?


首先执行下面的命令:


cd /usr/local/nginx/html 
vi error403.html


然后输入403的文件内容,例如:


<html> 
<head><title>Error 403 - IP Address Blocked</title></head> 
<body> 
Your IP Address is blocked. If you this an error, please contact binghe with your IP at test@binghe.com
</body> 
</html>


如果启用了SSI,可以在403中显示被封的客户端ip,如下:


Your IP Address is <!--#echo var="REMOTE_ADDR" --> blocked.


保存error403文件,然后打开nginx的配置文件vi nginx.conf,在server配置节内添加下面内容。


# redirect server error pages to the static page 
 error_page 403 /error403.html;
 location = /error403.html {
         root html;
 }


然后保存配置文件,通过nginx -t命令测试配置文件是否正确,若正确通过nginx -s reload载入配置。


PS:防止找不到本篇文章,可以收藏点赞,方便翻阅查找哦。


往期推荐



叕更新了,再次被和谐?!不存在的…

Debug 实现原理!看完还不懂吗?

专治 MySQL 乱码, 再也不想看到�了 !!

面试官:跨库多表存在大量数据依赖问题有哪些解决方案?

告别“丝袜哥”,推荐这几个在线文档生成神器!

MySQL 定时备份数据库



ITZOO版权所有丨如未注明 , 均为原创丨转载请注明来自IT乐园 ->如何封禁IP和IP段?看完这篇我会了!!
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址