Skip to content

hcymysql/sqlops

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

image

安装视频:

https://edu.51cto.com/center/course/lesson/index?id=843411


2023-01-08更新:

新增pt-osc功能,研发可以在网页里执行大表Alter更改表结构操作。 https://blog.51cto.com/hcymysql/5996723

sqlops新增pt-osc功能,触发条件:

1)当行记录小于150万行,研发可以直接在网页里执行Alter table操作。

2)当行记录大于150万行并且小于3000行,平台将调用pt-online-schema-change开源工具在线执行Alter表结构变更。

注:期间不要关闭浏览器!执行进度会自动刷新。

3)当行记录大于3000行时,提示:Alter更改表结构会引起表锁,影响业务。由于该表过大,平台不支持自助上线。


image

2020-03-11更新:

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

image

这里须要调用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


3) 增加dbinfo_prvi审批权限表

在待审批工单栏目下,研发经理可以只审批自己的业务库,别的项目数据库库,看不到审批内容。

insert into dbinfo_prvi(dbuser,approver,dbname) values('hechunyang','贺春旸','test');


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

image

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

SQL自动审核主要完成两方面目的:

1、避免性能太差的SQL进入生产系统,导致整体性能降低。

2、检查开发设计的索引是否合理,是否需要添加索引。

思路其实很简单:

1、获取开发提交的SQL

2、对要执行的SQL做分析,触碰事先定义好的规则来判断这个SQL是否可以自动审核通过,未通过审核的需要人工处理。


环境安装

1、PHP环境安装

yum install httpd mariadb php php-mysqlnd php-devel php-pear libssh2 libssh2-devel gcc -y

2、安装PHP SSH2扩展

pecl install -f ssh2

3、修改/etc/php.ini

在最后一行添加

extension=ssh2.so

然后重启httpd

systemctl restart httpd.service

4、关闭selinux

vim /etc/selinux/config

SELINUX=disabled

5、美团网SQLAdvisor安装

请移步

https://github.com/Meituan-Dianping/SQLAdvisor/blob/master/doc/QUICK_START.md

6、binlog2sql安装

请移步

https://github.com/danfengcao/binlog2sql

部署

https://github.com/hcymysql/sqlops/archive/master.zip 解压缩到/var/www/html/目录下

1、导入表结构sqlops_schema/sqlops_schema.sql(DB配置信息表)和(SQL工单记录表)

2、修改conn.php(sqlops数据库的配置信息的IP、端口、用户名、密码、库名)

录入开发上线的生产数据库信息

insert into dbinfo(id,ip,dbname,user,pwd,port) values (1,'10.10.159.31','test','admin','hechunyang',3306);

3、修改sqladvisor_config.php(访问SQLAdvisor服务器的IP、SSH端口、SSH用户名、SSH密码)

4、修改rollback.php(访问binlog2sql服务器的IP、SSH端口、SSH用户名、SSH密码)

5、execute_status.php 执行上线

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

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


规则

create审核

检查项:

1、警告!表没有主键

2、警告!表主键字段名必须是id。

3、提示:id自增字段默认值为1,auto_increment=1

4、警告!表字段没有中文注释,COMMENT应该有默认值,如COMMENT '姓名'

5、警告!表没有中文注释,例:COMMENT='学生信息表'

6、警告!表缺少utf8字符集,否则会出现乱码

7、警告!表存储引擎应设置为InnoDB

8、警告!表缺少update_time字段,方便抽数据使用,且给加上索引。

9、警告!表update_time字段类型应设置timestamp。

10、警告!表update_time字段缺少索引。

11、警告!表缺少create_time字段,方便抽数据使用,且给加上索引。

12、警告!表中的索引数已经超过10个,索引是一把双刃剑,它可以提高查询效率但也会降低插入和更新的速度并占用磁盘空间

13、警告!表应该为timestamp类型加默认系统当前时间。例如:update_time timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间'

14、警告!表 utf8_bin应使用默认的字符集核对utf8_general_ci

15、警告!用DECIMAL代替FLOAT和DOUBLE存储精确浮点数。浮点数的缺点是会引起精度问题,对货币等对精度敏感的数据,应该用定点数decimal类型存储。

16、警告!避免使用外键,外键会导致父表和子表之间耦合,十分影响SQL性能,出现过多的锁等待,甚至会造成死锁。

17、警告!表字段类型应设置为datetime精确到秒。例:将datetime(3)改成datetime。警告!表字段类型应设置为timestamp精确到秒。例:将timestamp(3)改成timestamp。


alter审核

检查项:

1、警告!不支持create index语法,请更改为alter table add index语法。

2、警告!更改表结构要减少与数据库的交互次数,应改为,例alter table t1 add index IX_uid(uid),add index IX_name(name)

3、表记录小于150万行,可以由开发自助执行。否则表太大请联系DBA执行!

4、支持删除索引,但不支持删除字段

5、不支持更改字段名字


insert审核

检查项:

1、警告:insert 表1 select 表2,会造成锁表。


update/delete审核

检查项:

1、警告!没有where条件,update会全表更新,禁止执行!!!

2、更新的行数小于1000行,可以由开发自助执行。否则请联系DBA执行!!!

3、防止where 1=1 绕过审核规则

4、检查更新字段有无索引

5、警告!DML不同的操作要分开写,不要写在一个事务里。


About

SQL自动审核-自助上线平台

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published