记一次真实的网站被黑经历

前言

距离上次被DDOS攻击已经有10天左右的时间,距离上上次已经记不起具体那一天了,每一次都这么不了了只。然而近期一次相对持久的攻击,我以为有必要静下心来,分享一下被黑的那段经历。php

在叙述经历以前,先简单的介绍一下服务器配置状况:nginx

  • ECS 1核2G内存1MB带宽,Linux系统
  • RDS 2核240MB内存,最大链接数60
  • Redis 256MB共享实例,搬家以后没用到
  • CDN 按量付费,缓存小文件

以上配置,对于一个日访问量几千的网站来讲应该绰绰有余了,并发撑死十几个左右,如下是简单的网站部署状况:redis

经历

前段时间据说过互联网大佬阮一峰博客被DDOS的经历,可谓是持久啊,最终被迫转移服务器,听说还被勒索。然不知道为啥是哪一个仙人板板竟然盯上了个人小站?难道我比阮大神长得帅?算法

好吧,故事开始,2018年6月14日,凌晨两点三十收到了阿里云系统告警通知,告知网站没法访问,然而那会我还在睡梦中。数据库

跟往常同样,差很少六点左右醒来,习惯性的翻看手机,刚好此时又发来了短信告警。要在平时的话是能够再睡两个小时的,然而此时一个激灵,瞬间困意全无,怎么说我也是有几千访问量的博主了。后端

因而,赶忙爬起来打开电脑,尝试访问下博客和论坛,果不其然浏览器在一直打转转。浏览器

问题排查

尝试远程登陆服务器:缓存

  • 查看Nginx 和 PHP-FPM,ps -ef|grep xxxx安全

  • 查看系统剩余内存 free -m服务器

  • 查看CPU使用状况 top

  • 查看Nginx错误日志 tail -f error.log

  • 查看日志容量 ll -h

  • 查看并发链接数 netstat -nat|grep ESTABLISHED|wc -l

一顿骚操做以后,并无什么异常,内存和CPU平稳,Nginx和PHP 进程没问题。而后分别重启了一下 PHP 和 Nginx,开始网站还能够访问,进入社区首页就被卡死。

查看错误日志,后台使劲的刷日志,随便查看了几个IP,有印度的,美国的,菲律宾的等等,固然大多数仍是国内的IP。一夜的时间竟然刷了上百兆日志(上次被D我清理过一次),反正我以为是很多了,对比网站平时的访问量来讲。

以前有过几回攻击,但都是三三俩俩的过来,使用Nginx禁掉IP就是了。然而这次,显然不是禁掉IP能够解决问题的了,这么多IP收集是个问题(固然能够经过正则匹配获取),还有可能形成误伤。

上班途中

然而上班才是正事,心思着一时半会解决不了问题,瞄了一眼错误日志,还在使劲的刷着,而后顺手发了个朋友圈而后去洗漱:

路上一路嘟念,心想是否是到了9点,他们准时下夜班而后就能够正常访问了,自我开解一下。

上班中

到了公司,第一件事固然是远程登陆下服务器,看了一下,错误日志还在使劲刷。正常来讲这个是时间点是不会有用户来访问的。

重启了服务屡次,访问一下首页就被卡死,而后瞬间瘫痪,整个网站(社区+博客)都不能访问了。既然这样,仍是老实上班,坐等攻击中止吧。

期间群里的小伙伴们问网站怎么了,打不开了椰?将近中午的时候,查看了一下错误日志,还有那么几个IP再尝试请求不一样的地址,一瞅就不是什么好东西,果断deny了一下。话说,如今请求没那么多了,重启了一些Nginx 和 PHP 进程,访问首页仍是卡死?真是怪了个蛋。

心想是否是RDS数据库的问题,查看了监控报警面板,CPU和内存利用率和当前总链接数都正常,没有什么异常,凌晨两点-六点左右的确有波动,可是不至于被D死。既然都登陆了,要不顺便把 ECS 和 RDS 都重启了吧。

果真,重启一下竟然神奇的好了,吃午餐的时候还用手机访问了一下,正常,能够安心吃饭了。

问题解决

其实,最终问题怎么解决的,我并不清楚,说几个比较疑惑的点:

  • ECS 服务器 CPU 和内存也在正常阈值
  • Nginx 和 PHP-FPM 进程都分别重启过
  • RDS 数据库链接数尽管有所波动,可是并无占满未释放
  • 看错误日志请求都是来自上百个不一样的IP,而且大多都是访问的社区URL
  • 还有这些肉鸡为何都是晚上?晚上便宜?仍是说在西半球组织攻击
  • 这次是有针对性的,仍是随机的?希望是随机的
  • 中间中止过一次社区,博客是能够一直正常访问的,怀疑是首页数据库查询的问题,基于链接数应该不是这个问题,难道是Discuz的Bug?可是后来重启数据库后的确能够正常访问了。

其实阿里云有基础的DDOS防御,清洗触发值:

  • 每秒请求流量:300M
  • 每秒报文数量:70000

对于通常小站来讲,是万万不可能达到300M的流量阈值的,博客的CDN峰值才3M而已。

因此说,这些小波流的攻击只能自身去默默承受,而机器配置不高,买不起带宽只能任攻击自由的撒欢,还不如直接关站,扔给他一个Nginx + 静态页面让它D去吧。

攻防策略

若是有人真D你的站点,你还真没有办法,固然我所说的群体是针对中小站长而言,你连DDOS基础防御的清洗阈值都达不到。

若是你只是一个默默无闻的小站,根本不须要想那么多。尽管如今DDOS成本很低,但谁不是无利不起早,除非你得罪了什么人。

固然对于通常的攻击咱们也不能坐以待毙,这里总结了几个小技巧,分享给你们,反向代理使用的是openresty。

Nginx优化

Nginx号称最大并发5W,实际上对于中小站点来讲几十或者上百个并发就不错了,最基本的参数就能够知足需求。可是为了安全期间,咱们最好隐藏其版本号。

# 隐藏版本,防止已知漏洞被利用
server_tokens off; #在http 模块当中配置

PHP优化

在php渲染的网页header信息中,会包含php的版本号信息,好比: X-Powered-by: php/5.6.30,这有些不安全,有些黑客可能采用扫描的方式,批量寻找低版本的php服务器,利用php漏洞(好比hash冲突)来攻击服务器。

# 隐藏版本,防止已知漏洞被利用
php_admin_flag[expose_php] = off

IP黑名单

对付那种最low的攻击,加入黑名单的确是一个不错的选择,否则别人AB就能把你压死:

# 在Nginx的http模块添加如下配置便可
deny 61.136.197.xxx;
# 禁封IP段
deny 61.136.197.0/24;

IP日访问次数

限制单个IP的日访问次数,正常来讲一个用户的访问深度不多超过10个,跳出率通常在50%-70%之间。其实咱们要作的把单个IP的日访问量控制在100甚至50之内便可。

限制并发数

光限制访问次数仍是不够的,攻击者可能瞬间涌入成百上千的请求,若是这些请求到后端服务,会打垮数据库服务的,因此咱们还要基于咱们自身网站访问状况设置并发数。

  • 限制单个IP的并发数
  • 限制总并发数

这里建议你们使用漏桶算法限流,来整形流量请求。

配置CDN

基于带宽以及正经常使用户访问速度的考量,建议配置CDN,如下是博客的流量使用状况,峰值3MB,对于我这1MB带宽的服务器确定是抗不住啊,何况还有社区的访问。

配置缓存

数据库资源是宝贵的,因此尽可能不要让请求直达后端。其实搬家以前,博客和社区都是配置过redis缓存的。因为以前购买的Redis服务是专有网络,新帐号没法链接,而后就做罢了。

看来此次,须要在空闲服务器上配置一把了,反正闲着也是闲着,能起一丢丢做用也是好的。

总结

前面也说了,对于攻击,小站真的无解,能作好基础的防御就能够了。可是对于那些肉鸡们或者即将成为肉鸡的人来讲:

  • 软件漏洞必定要及时打补丁,时刻关注互联网相关动态。

  • 黑客利用被入侵的路由器获取网络流量,从而控制大量肉鸡。

  • 大多数肉鸡是没有安全意识的,而且被长期利用,经发现,很多是云服务商主机、托管服务器主机,被黑客利用漏洞控制。

  • DDoS黑客攻击正在向产业化、平台服务化转变,若是有人想害你,一个按钮、几百块钱,就能够实现一整月的攻击,而后一首《凉凉》送给本身。

参考

各类限流脚本:从构建分布式秒杀系统聊聊限流特技

相关文章
相关标签/搜索