zoukankan      html  css  js  c++  java
  • 一个sql脚本引发的灾难后的思索

    今天下午同事在PRD数据库服务器上更新了一个脚本,没有想到的是,本来很平常的一个操作,却导致了灾难性的后果,由于我们系统前不久改变了同SAP交互的方式,以前通过另外的中间接口访问SAP,最近进行了迁移,换了个接口程序。可是我同事的脚本更新后不久,用户就发现订单中有些产品被莫名的更改了,订单上开始选择的是芝麻油500箱,结果后来生成订单后发现变成了橄榄油500箱,虽然后来我们发现后马上进行了进一步的验证,而且没有发现大量的错误数据,只有一家用户,下了一个订单出现了问题。风险范围比较小,大家总算松了口气,马上进行了修复,并进一步进行了再三的Check,但是也暴露出了一个问题。事关这种全局性的修改,我们没有严格的进行测试,并且审查,所以出现了这种紧急情况。所幸的是最终造成的损失并不大。

    但是通过这次的事件,也暴露了我们开发中的一些薄弱环节,比如测试不过,对于这种事关系统全局的更改,没有进行严格的代码审查,在PRD环境执行时,也没有仿真环境测试,开发人员完成后,进行了一次确认后,特别是这种数据库脚本的执行,就简单的做了些测试就直接执行了。有时候简单的看看是看不出问题的,而且测试时如果没有考虑全面的话也测试部出来,因为这次并没有导致所有的数据出错,仅仅只是特殊的情况下有问题。所以流程的管理在某些 方面还是有漏洞。关于系统全局,关键性的修改,在开发人员完成开发后,自己先做完单元测试,相关同事一定要仔细的做验证,并Review代码,然后由同事再次测试,测试通过OK后交给测试组进行全面的测试。对于这种事关全局的更改,即使是一个小小的脚本,也要有测试用例,而且要全面的测试,同事在PRD环境执行前,一定要在一个和PRD环境最接近的仿真环境再次进行测试,并确认OK后方可在PRD环境执行。古人云:失之毫厘,差之千里。绝对的真理啊。下次一定要谨记了。

  • 相关阅读:
    从程序员到项目经理
    wumii 爆款总结经验
    快速的搭建JFinal的ORM框架示例
    Hibernate all-delete-orphan[转]
    HHvm Apache 2.4 Nginx建站环境搭建方法安装运行WordPress博客
    雷军是如何从程序员蜕变成职业经理人的
    Postgresql数据库数据简单的导入导出
    如何一年看50本好书?
    清除DNS解析缓存
    mysql 下 计算 两点 经纬度 之间的距离
  • 原文地址:https://www.cnblogs.com/kevinGao/p/2671007.html
Copyright © 2011-2022 走看看