内容简介:我的CDN部署在腾讯云,10月2日接收到短信提醒:CDN流量已用完。登陆控制台后发现,被盗刷了360G,宽带峰值也到达了难以想象的680Mbps。抱着怀疑的态度,我查看了区域商分布,果然,海外的请求占了总请求的98.24%。其中300多G的流量都来自海外,现在可以确定是歪果仁盗刷了我的CDN流量。
我的CDN部署在腾讯云,10月2日接收到短信提醒:CDN流量已用完。登陆控制台后发现,被盗刷了360G,宽带峰值也到达了难以想象的680Mbps。 这对于一个个人网站来说,几乎是不可能的流量。
抱着怀疑的态度,我查看了区域商分布,果然,海外的请求占了总请求的98.24%。其中300多G的流量都来自海外,现在可以确定是歪果仁盗刷了我的CDN流量。
没有办法,被迫联系工单,但因为我自己的一些防御没做好,所以这次的补偿不了了之。无奈,只能出钱补上了被盗刷的流量,以保证服务正常使用。并且在工单的交流中,增设了QPS等安全措施。
毫无疑问,限制QPS会影响用户的正常使用,造成延迟。但保险起见,我还是设置了QPS,只希望不要再被攻击。
1.2 再次遭遇
但好景不长,仅安稳度过了一天,又一波来自海外的DDoS让我不得不临时关闭CDN和COS服务。下图中第一个峰值是上一次DDoS,第二个峰值是这次的DDoS。
这次的攻击更高级,颇有一种“道高一尺,魔高一丈”的味道。因为之前应增设了QPS等限制,但这样完全限制不了IP代理池等攻击手段,黑客这次也选择了体积较大的单文件进行攻击。
我惯例去找了工单, 因为上次腾讯云的工程师专门call过来:只要增设了相关安全限制,下次确认是盗刷立即给予补偿 。然而这次工单依然是打太极,各种文档、规则扔给我,闭口不谈补偿问题,并且说是我的QPS设置太高了:)。
问题是:QPS设置成5,项目还用不用了?如果用户处于同一个局域网下(校内网、Wifi等场景),那在同一秒中只有一个用户可以正常使用?
最后,工程师还是call过来,经过了1小时的聊天,可以补偿,但是要等一段时间才能批下来这90G的流量包。然而我的流量已经超了,我还是要自己补以保证第二天正常使用。好吧,也算是一个解决方案。
1.3 无路可走
经历了2次DDoS,我设置了“宽带封顶配置“。根据平日的使用量,我估计“3Mbps”,并且在超值的时候,返回404,关停服务。
当日晚,就接收到了CDN到达宽带封顶的短信,自动关停了CDN服务:项目也无法正常使用了。
这次,彻底是绝望了,只能先关闭CDN服务,寻求别的解决方法。
2. 坎坷的补救措施
在补救的时候,首先排除了工单的意见:回源到原站或者COS(对象存储服务)。前者会直接造成服务器瘫痪,DDoS是结结实实打在服务器上;后者COS也是流量或者宽带后收费,本质上和CDN没区别。
所以,关闭当前的CDN加速域名,并且清空了COS中的文件。然后针对个人网站和项目应用做了不同的处理。
2.1 公司项目:更改CDN域名
观察被盗刷的资源,全部都是个人网站的静态资源。而公司项目只有合作的商户在使用,并且在 robots.txt
中禁止了爬虫,所以用利用另一个账号开启了一个新的COS并且开启了对应的CDN加速域名。
至于为什么个人网站和公司项目要放在一起,只是因为方便上传和管理,现在看来省事一步,后患无穷。
2.2 个人网站:Git平台
借助免费的Git平台,可以存放图片、代码等数据,并且可以在外部访问到。考虑到国内用户居多,所以我将友链界面的图片和文章中的图片存放到了 Coding.net 的公有仓库中。
例如下面这种图片的地址就是: https://qcloud.coding.net/u/godbmw/p/blog/git/raw/master/markdown-static/网站搭建与运营/第一次遭遇云服务器完全崩溃/1.png
当当我把代码放在Coding或者github上时,虽然可以请求到代码的内容, 但是 Response Header
中的 Content-Type
字段的值是: text/plain; ...
。对于CSS样式文件,浏览器无法自动解析 。因此,打包后的js、css等项目文件不能放在Git平台。
2.3 免费CDN: CloudFlare
这是全球最大的 免费的CDN ,并且 国内也可以访问 。ping值稳定在100ms左右,具体可以去查看相关测试文章。除此之外,cloudflare可以 抗下DDoS、CC等攻击 ,听说百度抗不下来海外的DDoS的时候,也是DNS解析到cloudflare进行处理。
cloudflare的操作很简单,首次注册按照它的指导到域名注册上修改DNS解析即可。如果是国外的域名注册商,几分钟就可以同步。国内的并没有尝试。如果成功了,CONSOLE页面就会显示“Active”。
感谢来自V友们的提示:请在CloudFlare的控制台的DNS面板中,点亮小云朵(开启HTTP Proxy),否则是无法使用他们的CDN的,IP还是暴露的。
除此之外,还有一下措施:
- 控制台提高安全等级:默认是Essentially Off,可以根据情况提升
- 设置防火墙规则:国内ip直接访问,国外ip需要通过Javascript验证
- 限制访问频次
到此,个人网站就可以正常访问了。
3. 一些思考
在这之前一直在使用腾讯云,希望云平台可以采纳预付费(现在是后付费)限制宽带的做法。
而腾讯云的官方文档也有提及DDos等攻击造成流量激增的免除措施,如下图所示:
不知道大家发现了没有,宽带必须到达10Gbps以上才可以免除。然而这次经历的才只有680Mbps,如果到10Gbps,那后果真是不敢想象,怕是要赔掉裤子。 和工单讨论的时候,工单就给了我这张图片,如果用户被盗刷达到了9Gbps呢?也是他们说的不符合要求,还是需要用户自己买单 。损失肯定难以衡量。希望日后平台可以改进相关规定。
刚做网站的时候关心名头(傻傻觉得越大公司越靠谱),现在才发现云平台的 安全稳定、补救措施、收费标准 才是关键。
最后,如果是个人项目,强烈推荐使用国外的“cloudflare”,免费、不限流量、抗攻击,就像国外的JetBrians(教育版免费),都是有情怀的公司,致敬!!!
以上所述就是小编给大家介绍的《被DDos后的及时补救与一些思考》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python高效开发实战——Django、Tornado、Flask、Twisted(第2版)
刘长龙 / 电子工业出版社 / 2019-1 / 99
也许你听说过全栈工程师,他们善于设计系统架构,精通数据库建模、通用网络协议、后端并发处理、前端界面设计,在学术研究或工程项目上能独当一面。通过对Python 3及相关Web框架的学习和实践,你就可以成为这样的全能型人才。 《Python高效开发实战——Django、Tornado、Flask、Twisted(第2版)》分为3篇:上篇是Python基础,带领初学者实践Python开发环境,掌握......一起来看看 《Python高效开发实战——Django、Tornado、Flask、Twisted(第2版)》 这本书的介绍吧!
RGB转16进制工具
RGB HEX 互转工具
正则表达式在线测试
正则表达式在线测试