SQL自动审核-自助上线平台 V2.0
2020-03-11更新:
1)sql_check.php --> SQL语法校验功能
这里须要调用MariaDB的mysql客户端,因为MySQL5.6高版本会抛出警告,命令行里带密码不安全,会影响SQL语言检测结果。
mysql: Using a password on the command line interface can be insecure.
execute_status.php 执行上线
这里须要调用MariaDB的mysql客户端,因为MySQL5.6高版本会抛出警告,命令行里带密码不安全,会影响SQL语言检测结果。
mysql: 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是否可以自动审核通过,未通过审核的需要人工处理。
页:
[1]