故事背景

前阵子,有位朋友在微信上问我数据被删了能不能恢复,我问了下原因,居然是因为一个配置项惹的祸。

故事细节

在 Spring Boot 中使用 jpa 来操作数据库,jpa 就不做详细的介绍了,相信大家都有所了解或者也用过。

在 jpa 中有一个配置项,可以让程序在启动的时候自动初始化表结构或者更新表结构的功能。听上去很不错,非常实用。

其实这是一个非常危险的功能,个人觉得不应该提供这种功能,只要留了口子就有可能会出问题。

这个配置就是:spring.jpa.hibernate.ddl-auto

  • create(危险系数 2 颗星

应用启动的时候,如果数据库中没有对应的表,就会自动根据实体类的结构创建一个表结构。如果表已经存在了就会将表中的数据清空。

  • create-drop(危险系数 3 颗星

应用启动的时候,如果数据库中没有对应的表,就会自动根据实体类的结构创建一个表结构。如果表已经存在了就会将表中的数据清空。

程序停止的时候会将数据库中所有表删除掉。

  • update(危险系数 1 颗星

应用启动的时候,如果数据库中没有对应的表,就会自动根据实体类的结构创建一个表结构。如果表已经存在了就会判断有没有新增字段或者修改长度之类的,如果有则会更新表结构,不会影响数据。

  • validate(危险系数 0 颗星

validate 不会更新和删除表或者数据,只会做验证逻辑。

  • none (危险系数 0 颗星

禁用 ddl 操作。

如何防范

这种问题归根到底还是技术负责人没重视线上安全问题,主要有下面几点:

  • 数据没备份

线上数据一定要有备份,而且备份得放在不同的机器上,降低风险值。

  • 数据库账号权限细分,不给删除权限,业务做逻辑删除

如果公司有 DBA 那么可能会好点,对数据库相关的安全会管控的比较严。如果没有 DBA,基本上都是开发自己管理,技术负责人应该去做这件事情。

一般的开发人员可以给只读账号就行了,偶尔线上查查数据之类的。

另外需要有一个读写的账号,用于程序中。

像删除,DDL 操作这种权限就留给管理员账号就行了,不然很容易出事。

  • 应用中的框架有 DDL 操作的功能,一律禁止使用

这次的问题,除了开发人员的大意,最主要就是框架中自带了 DDL 的功能。像这种功能就应该禁止使用。

所有的表结构应该在上线之前确认好,最好手动执行,像 DDL 这种操作本身就会锁表,应该在业务低峰期去做。交给程序自动做不靠谱。

我记得我们之前在代码中也有去自动创建表的逻辑,在 code review 的时候被指了出来,然后就去掉了。虽然说是为了使用更方便,但是增加了线上数据库的风险。像一些开源框架中也有类似的逻辑,当表不存在时会自动给你创建好表。

关于作者:尹吉欢,简单的技术爱好者,《Spring Cloud 微服务-全栈技术与案例解析》, 《Spring Cloud 微服务 入门 实战与进阶》作者, 公众号 猿天地 发起人。

最新文章

  1. eclipse中快捷键
  2. 2014-2015 ACM-ICPC, NEERC, Moscow Subregional Contest C. CIA Datacenter
  3. Jquery中的队列函数quene()、dequene()、clearQuene()
  4. 缓存技术之——Yii2性能优化之:缓存依赖
  5. 分享9款用HTML5/CSS3制作的动物人物动画
  6. php利用smtp类轻松的发送电子邮件
  7. 软件测试学习日志———— round 2 Junit+intellj idea 安装及简单的测试使用
  8. Android - 和其他APP交互 - 获得activity的返回值
  9. linux nvme的sendfile流程
  10. Shell脚本生成网页版相册浏览器
  11. 6.Django session
  12. Mysql千万级大表优化
  13. Sequential Container
  14. c# Point不能输入小数
  15. Codeforces 643C Levels and Regions 斜率优化dp
  16. django 基于form表单上传文件和基于ajax上传文件
  17. 得到body相对定位的插件
  18. mysql函数find_in_set()
  19. git fork后提交pull request到原作者,别人的pull request我们要怎样merge融合
  20. js:{}与new Object()的区别是什么

热门文章

  1. mac OS 安装 nvm
  2. 桌面上的Flutter:Electron又多了个对手
  3. 现代软件工程讲义 如何提出靠谱的项目建议 NABCD
  4. python(while 循环语句)
  5. muduo网络库源码学习————原子性操作Atomic.h
  6. Spring Boot 集成 Flyway 实现数据库版本控制
  7. SSM家庭财务管理系统
  8. Day_11【集合】扩展案例4_删除长度大于5的字符串,删除元素包含0-9数字的字符串
  9. JDK/Java 14 发布
  10. Vue2.0 + ElementUI 手写权限管理系统后台模板(一)——简述