设为首页 收藏本站
查看: 978|回复: 0

[经验分享] SQL自动审核-自助上线平台

[复制链接]

尚未签到

发表于 2018-10-12 09:34:50 | 显示全部楼层 |阅读模式
  为了让DBA从日常繁琐的工作中解放出来,通过SQL自助平台,可以让开发自上线,开发提交SQL后就会自动返回优化建议,无需DBA的再次审核,从而提升上线效率,有利于建立数据库开发规范。
  借鉴了去哪网Inception的思路并且把美团网SQLAdvisor(索引优化建议)集成在一起,并结合了之前写的《DBA的40条军规》纳入了审核规则里,用PHP实现。目前在我公司内部使用。
  SQL自动审核主要完成两方面目的:
  1、避免性能太差的SQL进入生产系统,导致整体性能降低。
  2、检查开发设计的索引是否合理,是否需要添加索引。
  思路其实很简单:
  1、获取开发提交的SQL
  2、对要执行的SQL做分析,触碰事先定义好的规则来判断这个SQL是否可以自动审核通过,未通过审核的需要人工处理。
  下面是首页界面:
DSC0000.jpg

  使用说明:
  1、针对select/insert/update/create/alter加了规则,delete需要审批。

  2、语句之间要有空格,例where>  3、SQL语句后面要加分号; MySQL解析器规定分号才可以执行SQL。
  4、反引号`会造成上线失败,需要用文本编辑器替换掉。
  5、支持多条SQL解析,用一个分号;分割。例如:
  insert into t1 values(1,'a');
  insert into t1 values(2,'b');
  6、JSON格式里的双引号要用反斜杠进行转义,例如:{\"dis_text\":\"nba\"}。
  
  

  •   SELECT审核
  1、开发人员可以直接将SQL语句提交到平台进行风险评估
  2、平台对SQL语句进行分析,自动给出其不符合开发规范的改进意见
  3、适用场景:应用开发阶段
  检查项:
1、select * 是否有必要查询所有的字段?  
2、警告!没有where条件,注意where后面的字段要加上索引
  
3、没有limit会查询更多的数据
  
4、警告!子查询性能低下,请转为join表关联
  
5、提示:in里面的数值不要超过1000个
  
6、提示:采用join关联,注意关联字段要都加上索引,如on a.id=b.id
  
7、提示:MySQL对多表join关联性能低下,建议不要超过3个表以上的关联
  
8、警告!like '%%'双百分号无法用到索引,like 'mysql%'这样是可以利用到索引的
  
9、提示:默认情况下,MySQL对所有GROUP BY col1,col2...的字段进行排序。如果查询包括GROUP BY,
  
想要避免排序结果的消耗,则可以指定ORDER BY NULL禁止排序。
  
10、警告!MySQL里用到order by rand()在数据量比较多的时候是很慢的,因为会导致MySQL全表扫描,故也不会用到索引
  
11、提示:是否要加一个having过滤下?
  
12、警告!禁止不必要的order by排序,因为前面已经count统计了
  
13、警告!MySQL里不支持函数索引,例DATE_FORMAT('create_time','%Y-%m-%d')='2016-01-01'是无法用到索引的,需要改写为
  
create_time>='2016-01-01 00:00:00' and create_time集核对utf8_general_ci
  4、避免使用外键)
  https://pan.baidu.com/s/1KKw9aMWa-9Q_8efaiQndMQ
  -------------------------------------------
  2018-04-27更新
  1、增加人工确认审核功能
  上线流程为:开发提交SQL,系统自动审核(sql_review.php),审核通过后生成我的工单待管理员批复,管理员人工确认审核通过后,开发点击执行完成上线。
  表
  1、login_user.sql  用户登录验证表(权限功能)
  2、sql_order_wait.sql  工单待审核生成表
  3、dbinfo.sql(DB配置信息表)
  脚本解释
  1、index.html(用户登录入口)
  2、login.php(用户密码校验)
  3、main.php(首页框架栏)
  4、header.php(用户登录欢迎页面,和注销)
  5、left.php(导航栏)
  6、sql_interface.php(SQL传参入口)
  7、sql_review.php(SQL审核)
  8、my_order.php(查看我的工单,执行,撤销)
  9、wait_order.php(管理员人工批复:通过,否决)
  10、update.php(管理员审批确认)
  11、update_status.php(修改审批状态值)
  12、execute.php(开发执行SQL工单)
  13、execute_status.php(修改执行工单状态)
  14、cancel.php(开发自行撤销工单)
  15、cancel_status.php(修改撤销工单状态)
  16、stat/show.html(工单动态统计图表)
  17、db_config.php(DB配置信息的IP、端口、用户名、密码、库名)
  18、sqladvisor_config.php(访问SQLAdvisor服务器的IP、SSH端口、SSH用户名、SSH密码)
  ---------------------
  注:
  1、客户端版本使用mysql5.5或者mariadb10.X。
  5.6会出现Warning: Using a password on the command line interface can be insecure,导致上线失败。
  2、php文件里的涉及连接数据库的用户名和密码要修改,这块没有做成统一个DB配置文件调用。
  https://pan.baidu.com/s/194zXrat-GLJa0AZu2KxebQ
  ---------------------
  2018-05-04更新
  1、增加发邮件给管理员审核SQL工单功能
  上线流程为:开发提交SQL,系统自动审核(sql_review.php),审核通过后生成我的工单待管理员批复并且发邮件通知,管理员人工确认审核通过后,开发点击执行完成上线。
  脚本解释
  1、mail/mail.php(邮件配置信息--修改你自己的邮箱用户名和密码)
  2、mail/sendEmail(开源邮件perl脚本)
  3、sql_review.php(触发发送邮件-覆盖掉之前的旧文件)
  https://pan.baidu.com/s/1abduiOMV8UguxfHCfBw5sg



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-620616-1-1.html 上篇帖子: SQL Server管理员必备技能之性能优化 下篇帖子: 安全安装SQL Server
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表