网站出现bug,我深夜被叫醒处理,用一个触发器解决了问题
凌晨两点,我正在睡梦之中,此时电话忽然想起,在漆黑的深夜中显得格外刺耳。
这个时间点电话响了肯定没好事,因为我的手机在夜间模式下,除非被同一个电话号码打三次,否则是静音,因此电话那边的人肯定有急事找我。我心一下子紧绷,睡意全无。
来电的是一个陌生的号码
“喂”我接通电话
“是xxx吗”电话那头是一个妹子的声音,说话声音有点快, 显得很急切
“是我,你是哪位,有什么事吗” 我说
“我是公司客服部的同事,是这样的,有用户反映我们的网站的文章评论内容被注入了大量的非法广告,我们查到这块功能是你负责的,所以直接联系你,希望你能尽快处理下”妹子回答
评论系统刚刚升级过,难道出BUG了,我心里一突
“好的,我马上看一下,处理好了给你回复”
挂掉电话,起身穿上衣服,打开电脑,打开网站,随便点开一篇首页的热文,下拉到评论处,果然评论里有大量链接内容,里面都是一些不堪入目的内容。 点开另一篇文章,评论处也是如此。
这可是对公司口碑有影响的事故,我吓出一身冷汗,必须赶紧处理。
我远程连接到网站的数据库服务器,select 了评论表,并做了筛选,发现非法评论记录有几十万之多,而且还在不断增长。而问题的原因显然是提交评论的接口被攻击了,但是因为编码是考虑欠周,没有检测这种特殊情况,提交的非法数据被不断的写入至数据库。
要解决这个问题,必须要修改代码,判断提交的内容合法性和提交频率。这需要重新发布版本,况且我家里也没有代码,想改也改不了,而这个问题又必须要尽快处理,这可如何是好。
凌晨两点很凉快,我却急得浑身发热,背心直冒汗。
“没办法了,只能先把已存在的非法评论删除再说”
我用root账户登录数据库,设置了一个筛选出这些非法评论的where条件,这个条件很容易指定, 因为这些评论都长一个样子,然后执行delete语句,几秒钟后,这些非法评论都被删除。
可是原有的评论虽然被删除,新的评论还在不断的写入, 不一会,评论数量又达到几千。
“这样删除永远删不光啊,这可怎么办”我急得抓耳挠腮“这要是不能马上解决, 明天肯定要挨批了,可这个问题根本没有办法马上解决啊,现在连代码都没有。难道让我现在去公司吗”
忽然,我脑袋里灵光一闪,想到了一个解决方案。
我可以在评论表上加一个insert触发器,在触发器中对评论内容进行检测,如果插入的内容是非法评论,则回滚这次操作,这样表中就不会再被写入非法数据了。
按照这个思路说做就做,我建立完触发器,删掉表里的非法评论,过了一会,再次检测发现非法评论未再次出现。
“方案生效了”我舒了口气
然而这只是个临时解决方案,假如对方改了评论内容的格式,那这个触发器就会失效。与此同时,触发器会对数据库性能造成影响,完善的解决方案还是应该通过程序处理,不过应急处理下问题不大,等挨到天亮就去改程序。
“喂,问题我修复了,你们看下”我拨通了刚才打给我的客服妹子的电话
“好的,大半夜的处理问题,真是辛苦你了”妹子客套了一下
“没有,这本来就是我的锅,是我给你们带来麻烦了”我说 “对了,你们持续观测下,如果再有这种情况,立马打电话给我,我刚才只是临时处理下,真正修复问题还要去公司”
“好的,我们知道”客服妹子甜甜的回答
挂掉电环, 我睡意全无,静静的等天亮,去公司彻底解决这个漏洞。
网站出现bug,我深夜被叫醒处理,用一个触发器解决了问题的更多相关文章
- 深夜,用canvas画一个时钟
		深夜,用canvas画一个时钟 查看demo 这几天准备阿里巴巴的笔试,可以说已经是心力交瘁,自从阿里和蘑菇街的内推被刷掉之后,开始越来越怀疑起自己的能力来,虽然这点打击应该是微不足道的.毕竟校招在刚 ... 
- css---移动端网站专属BUG【苹果手机】
		最近在前端写页面的时候,遇到了三个苹果手机的专属BUG,记录下... BUG1:苹果手机 form 表单的input有阴影 解决方法: input { /* 1 */ overflow: visibl ... 
- 大流量网站性能优化:一步一步打造一个适合自己的BigRender插件
		BigRender 当一个网站越来越庞大,加载速度越来越慢的时候,开发者们不得不对其进行优化,谁愿意访问一个需要等待 10 秒,20 秒才能出现的网页呢? 常见的也是相对简单易行的一个优化方案是 图片 ... 
- 火狐无法访问本机IIS部署的网站,弹出:此地址使用了一个通常用于网络浏览以外目的的端口.出于安全原因,Firefox 取消了该请求 的解决办法
		关于火狐浏览器访问本机IIS部署的网站弹出“此地址使用了一个通常用于网络浏览以外目的的端口.出于安全原因,Firefox 取消了该请求”这个错误(错误截图如下): 解决方法如下: 1.打开火狐浏览器, ... 
- Python+Selenuim测试网站,只能打开Firefox浏览器却不能打开网页的解决方法
		最开始我使用的Selenium版本为2.48,Firefox版本为37,自动化打开网站的时候,可以正常打开. 后来由于Firefox的自检测更新,版本更新为47,导致版本不兼容,自动化打开网站浏览器时 ... 
- 【知识整理】惊现RecyclerView内部Bug???别急,我们慢慢解决它~
		一.写在前面 这也是久违的一整个月没有写Blog,也是由于近期给妹纸找工作,各种坑蒙拐骗,然而都没卵用.额,广大朋友们,成都需要软件测试.线上运维.产品助理的伙伴,赶紧私聊我了.这妹纸,学习能力挺好, ... 
- IIS网站本机可以访问但局域网其他机器无法访问 解决方法
		在IIS部署网站的时候,发现只有本机可以访问,通过localhost和IP地址都可以,但是当局域网其他机器访问我的网站的时候,无响应. 我的是WIN10的系统 解决方法: 网站所对应的端口必须对外 ... 
- IE6浏览器有哪些常见的bug,缺陷或者与标准不一致的地方,如何解决
		IE6不支持min-height,解决办法使用css hack: .target { min-height: 100px; height: auto !important; height: 100px ... 
- 微信h5支付“网站域名ICP备案主体与商户号主体不一致”的解决方法,H5微信支付 授权函下载
		如下图所示: 微信h5支付“网站域名ICP备案主体与商户号主体不一致”: 需提交H5微信支付 授权函 下载地址:https://download.csdn.net/download/a72400815 ... 
随机推荐
- docker基本操作教程
			镜像操作 获取镜像 从Docker Hub搜索镜像: docker search ubuntu 下载镜像: docker pull ubuntu:18.04 若下载镜像速度较慢,更改镜像源: Ubun ... 
- 基于Rancher搭建Kubernetes
			基于Rancher搭建Kubernetes可以大大的简化安装的步骤,直接安装Kubernetes操作复杂并且容易出错. 转自 https://blog.csdn.net/u011142688/arti ... 
- SSM配置后可以访问静态html文件但无法访问其他后台接口的解决方案
			web.xml中的一段 <servlet> <servlet-name>SpringMVC</servlet-name> <servlet-class> ... 
- ElasticSearch(六):索引模板
			ElasticSearch(六):索引模板 学习课程链接<Elasticsearch核心技术与实战> Index Template Index Template - 帮助你设定Mappin ... 
- Project Euler 57: Square root convergents
			五十七.平方根收敛(Square root convergents) 二的平方根可以表示为以下这个无穷连分数: \[ \sqrt 2 =1+ \frac 1 {2+ \frac 1 {2 +\frac ... 
- Box 黑科技 —— 支持手机端反编译 !Box 黑科技 —— 支持手机端反编译 !
			项目地址: Box 文末扫码获取最新安装包 . 前言 有将近一个月没有更新文章了,一方面在啃 AOSP ,消化起来确实比较慢.在阅读的过程中,有时候上来就会陷入源码细节,其实这是没有必要的.刚开始更多 ... 
- Dubbo的应用
			导语:Dubbo是阿里巴巴的一个分布式服务的开源框架,致力于提供高性能和透明化的RPC远程服务调用方案,是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000+个服务提供3,000,000,000 ... 
- [LC] 108题 将有序数组转换为二叉搜索树 (建树)
			①题目 将一个按照升序排列的有序数组,转换为一棵高度平衡二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1. 示例: 给定有序数组: [-10,- ... 
- 破解微擎安装,免费搭建微擎,免费破解微擎,微擎破解版本,最新版本V2.1.2,一键安装!!
			 微擎是一款基于WEB2.0(PHP+Mysql)技术架构,免费开源的公众平台管理系统,一款致力于将小程序和公众号商业化.智慧化.场景化的自助引擎.微擎提供公众号.微信小程序.支付宝小程序.百度熊掌 ... 
- Apache中AllowOverride的详细配置使用
			我们通常利用Apache的rewrite模块对URL进行重写,rewrite规则会写在 .htaccess 文件里.但要使 apache 能够正常的读取.htaccess 文件的内容,就必须对.hta ... 
