sqlops流程.png


2020-03-11更新:

1)sql_check.php --> SQL语法校验功能

SQL语言校验.png

这里须要调用MariaDB的mysql客户端,因为MySQL5.6高版本会抛出警告,命令行里带密码不安全,会影响SQL语言检测结果。

mysql: [Warning] Using a password on the command line interface can be insecure.


execute_status.php 执行上线

这里须要调用MariaDB的mysql客户端,因为MySQL5.6高版本会抛出警告,命令行里带密码不安全,会影响SQL语言检测结果。

mysql: [Warning] Using a password on the command line interface can be insecure.


2)用户权限增加研发经理角色

login_user表privilege字段(0:普通研发;1:研发经理;100:DBA)

区别:研发经理只能审批SQL,不能执行SQL;DBA可以审批SQL且可以执行SQL


为了让DBA从日常繁琐的工作中解放出来,通过SQL自助平台,可以让开发自上线,开发提交SQL后就会自动返回优化建议,无需DBA的再次审核,从而提升上线效率,有利于建立数据库开发规范。


借鉴了去哪网Inception的思路并且把美团网SQLAdvisor(索引优化建议)集成在一起,并结合了之前写的《DBA的40条军规》纳入了审核规则里,用PHP实现。目前在我公司内部使用。


SQL自动审核主要完成两方面目的:
1、避免性能太差的SQL进入生产系统,导致整体性能降低。
2、检查开发设计的索引是否合理,是否需要添加索引。


思路其实很简单:
1、获取开发提交的SQL
2、对要执行的SQL做分析,触碰事先定义好的规则来判断这个SQL是否可以自动审核通过,未通过审核的需要人工处理。