基于inception的自动化SQL操作平台
python:3.4及以上
django:1.8.17
mysql : 5.6及以上
linux : 64位linux操作系统均可
- 自动审核:
发起SQL上线,工单提交,由inception自动审核,审核通过后需要由审核人进行人工审核 - 人工审核:
工单DBA人工审核、审核通过自动执行SQL.
为什么要有人工审核?
这是遵循运维领域线上操作的流程意识,一个工程师要进行线上数据库SQL更新,最好由另外一个工程师来把关.
很多时候DBA并不知道SQL的业务含义,所以人工审核最好由其他研发工程师或研发经理来审核. 这是archer的设计理念. - 回滚数据展示
- 在线查询
查询权限控制,基于inception解析查询语句,查询权限支持限制到表级
查询权限申请、审核和管理,支持审核流程配置
查询结果集限制、查询结果导出、表结构展示、多结果集展示 - 动态脱敏
基于inception解析查询语句,配合脱敏字段配置、脱敏规则(正则表达式)实现动态脱敏 - 主库集群配置
- 用户权限配置
工程师角色(engineer)与审核角色(review_man):工程师可以发起SQL上线,在通过了inception自动审核之后,需要由人工审核点击确认才能执行SQL.
还有一个特殊的超级管理员即可以上线、审核,又可以登录admin界面进行管理. - 历史工单管理,查看、修改、删除
- 可通过django admin进行匹配SQL关键字的工单搜索
- 发起SQL上线,可配置的邮件提醒审核人进行审核
- 在发起SQL上线前,自助SQL审核,给出建议
- 审核通过正在执行中的工单,如果是由pt-OSC执行的SQL会显示执行进度,并且可以点击中止pt-OSC进程
- 合理的数据库设计和规范很有必要,尤其是MySQL数据库,内核没有oracle、db2、SQL Server等数据库这么强大,需要合理设计,扬长避短。互联网业界有成熟的MySQL设计规范,特此撰写如下。请读者在公司上线使用archer系统之前由专业DBA给所有后端开发人员培训一下此规范,做到知其然且知其所以然。
下载链接: https://github.com/jly8866/archer/raw/master/docs/mysql_db_design_guide.docx
- archer/archer/settings.py
- 自定义配置文件,参考配置(inc.cnf)
[inception]
general_log=1
general_log_file=inception.log
port=6669
socket=/tmp/inc.socket
character-set-client-handshake=0
character-set-server=utf8
inception_remote_system_password=root #inception备份库配置信息
inception_remote_system_user=wzf1
inception_remote_backup_port=3306
inception_remote_backup_host=127.0.0.1
inception_support_charset=utf8mb4
inception_enable_nullable=0
inception_check_primary_key=1
inception_check_column_comment=1
inception_check_table_comment=1
inception_osc_min_table_size=1
inception_osc_bin_dir=/data/temp
inception_osc_chunk_time=0.1
inception_enable_blob_type=1
inception_check_column_default_value=1
- 指定配置文件和映射端口启动
docker run --name inception -v /etc/inc.cnf:/etc/inc.cnf -p 6669:6669 -d registry.cn-hangzhou.aliyuncs.com/lihuanhuan/inception
- 访问
mysql -hxxxx -P6669
- 下载settings.py文件,替换相关配置项,其中docker已经包含SQLADVISOR,请将SQLADVISOR配置项修改为
SQLADVISOR ='/opt/SQLAdvisor/sqladvisor/sqladvisor'
- 指定配置文件和映射端口启动
docker run --name archer -v
/etc/archer/settings.py:/opt/archer/archer/settings.py -p 9123:9123 -d registry.cn-hangzhou.aliyuncs.com/lihuanhuan/archer
- 进入容器,初始化数据库,后续升级可走增量变动脚本
docker exec -ti archer /bin/bash
cd /opt/archer
source /opt/venv4archer/bin/activate
# 初始化数据库
python3 manage.py makemigrations sql
python3 manage.py migrate
# 创建管理员账号
python3 manage.py createsuperuser
- 访问
http://xxxx:9123/
centos7一键安装脚本:克隆代码到本地后执行bash src/script/centos7_install.sh
,可配置好除inception和SQLAdvisor之外的环境
- 环境准备:
(1)克隆代码到本地: [email protected]:hhyo/archer.git 或下载zip包
(2)安装mysql集群,请注意保证mysql数据库默认字符集为utf8或utf8mb4
(3)安装inception,项目地址 - 安装python3:(强烈建议使用virtualenv或venv等单独隔离环境!)
- 安装所需相关模块:
pip3 install -r requirements.txt -i https://mirrors.ustc.edu.cn/pypi/web/simple/
-i变量是为了加速
centos安装ladp报错需要执行yum install openldap-devel - 给python3安装MySQLdb模块:
记得确保settings.py里有如下两行:
import pymysql
pymysql.install_as_MySQLdb()
由于python3使用的pymysql模块里并未兼容inception返回的server信息,因此需要编辑/path/to/python3/lib/python3.4/site-packages/pymysql/connections.py:
在if int(self.server_version.split('.', 1)[0]) >= 5: 这一行之前加上以下这一句并保存,记得别用tab键用4个空格缩进:
self.server_version = '5.6.24-72.2-log'
最后看起来像这样:
/path/to/python3/lib/python3.4/site-packages/pymysql/ - 创建archer本身的数据库表:
(1)修改archer/archer/settings.py所有的地址信息,包括DATABASES和INCEPTION_XXX部分
(2)通过model创建archer本身的数据库表, 记得先去archer数据库里CREATE DATABASE
python3 manage.py makemigrations sql
python3 manage.py migrate
执行完记得去archer数据库里看表是否被创建了出来 - mysql授权:
记得登录到archer/archer/settings.py里配置的各个mysql里给用户授权
(1)archer数据库授权
(2)远程备份库授权,为了查询回滚语句,需要额外配置查询权限 - 创建admin系统root用户(该用户可以登录django admin来管理model):
cd archer && python3 manage.py createsuperuser - 启动,有两种方式:
(1)用django内置runserver启动服务,需要修改debug.sh里的ip和port
cd archer && bash debug.sh
(2)用gunicorn+nginx启动服务
- 启动
cd archer && bash startup.sh
nginx的配置请指定settings.py配置项STATIC_ROOT - nginx配置示例
server{ listen 9123; #监听的端口 server_name archer; client_header_timeout 1200; #超时时间与gunicorn超时时间设置一致 client_body_timeout 1200; proxy_read_timeout 1200; location / { proxy_pass http://127.0.0.1:8888; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } location /static { alias /archer/static; #此处指向STATIC_ROOT目录的绝对路径,用于ngnix收集静态资源 } error_page 404 /404.html; location = /40x.html { } error_page 500 502 503 504 /50x.html; location = /50x.html { } }
- 启动
cd archer && bash startup.sh
- 创建archer系统登录用户:
使用浏览器(推荐chrome或火狐)访问debug.sh里的地址:http://X.X.X.X:port/admin/sql/users/ ,如果未登录需要用到步骤7创建的admin系统用户来登录。
点击右侧Add users,用户名密码自定义,至少创建一个工程师和一个审核人(步骤7创建的用户也可以登录)后续新的工程师和审核人用户请用LDAP导入sql_users表或django admin增加 - 配置主库地址:
使用浏览器访问http://X.X.X.X:port/admin/sql/master_config/ ,点击右侧Add 主库地址
这一步是为了告诉archer你要用inception去哪些mysql主库里执行SQL,所用到的用户名密码、端口等。 - 配置从库地址:
使用浏览器访问http://X.X.X.X:port/admin/sql/slave_config/ ,点击右侧Add 从库地址
这一步是为了进行sql在线查询,所用到的用户名密码、端口等,建议账号仅开放SELECT权限。 - 配置查询权限审核人:
使用浏览器访问http://X.X.X.X:port/admin/sql/workflowauditsetting/ ,点击右侧Add 工作流配置
这一步是为了添加查询权限审核人,单人审核格式为:user1,多级审核格式为:user1,user2,请正确配置。 - 正式访问:
以上步骤完毕,就可以使用步骤9创建的用户登录archer系统啦, 首页地址 http://X.X.X.X:port/
- settings中ENABLE_LDAP改为True,可以启用ldap账号登陆
- pip3 install django_auth_ldap
- 如果使用了ldaps,并且是自签名证书,需要打开settings中AUTH_LDAP_GLOBAL_OPTIONS的注释
- centos需要执行yum install openldap-devel
- settings中以AUTH_LDAP开头的配置,需要根据自己的ldap对应修改
- 安装SQLAdvisor,项目地址
- 修改配置文件SQLADVISOR为程序路径,路径需要完整,如'/opt/SQLAdvisor/sqladvisor/sqladvisor'
- 修改配置文件ENABLE_ALIYUN_FUNC=True
- 访问http://X.X.X.X:port/admin/sql/aliyunaccesskey/, 添加aliyun账号的accesskey信息,重新启动服务
- 访问http://X.X.X.X:port/admin/sql/aliyunrdsconfig/,添加实例信息
- 即可实现rds进程管理、慢日志管理
- 安装percona-toolkit(版本>3.0),以centos为例
yum -y install http://www.percona.com/downloads/percona-release/redhat/0.1-3/percona-release-0.1-3.noarch.rpm yum -y install percona-toolkit.x86_64 - 使用src/script/mysql_slow_query_review.sql创建慢日志收集表到archer数据库
- 将src/script/analysis_slow_query.sh部署到各个监控机器,注意修改配置信息
- 如果有阿里云RDS实例,可以在后台数据管理添加关联关系
1.patch目录下,名称为:django_1.8.17_admin_secure_archer.patch 2.使用命令:patch python/site-packages/django/contrib/auth/views.py django_1.8.17_admin_secure_archer.patch
- 工单展示页:
- 自助审核SQL:
- 提交SQL工单:
- SQL自动审核、人工审核、执行结果详情页:
- 用户登录页:
- 工单统计图表:
- pt-osc进度条,以及中止pt-osc进程按钮:
- SQL在线查询、自动补全:
- 动态脱敏:
- SQL在线查询日志:
- SQL在线查询权限申请:
- 阿里云RDS慢查日志统计:
- 阿里云RDS慢查日志明细、一键优化:
- 阿里云RDS进程管理、表空间查询:
- SQLAdvisor:
- 后台数据管理:
- 权限审核配置:
- 脱敏规则、字段配置:
QQ群:524233225
- 报错:
原因:python3的pymysql模块会向inception发送SHOW WARNINGS语句,导致inception返回一个"Must start as begin statement"错误被archer捕捉到报在日志里.
解决:如果实在忍受不了,请修改/path/to/python3/lib/python3.4/site-packages/pymysql/cursors.py:338行,将self._show_warnings()这一句注释掉,换成pass,如下:
但是此方法有副作用,会导致所有调用该pymysql模块的程序不能show warnings,因此强烈推荐使用virtualenv或venv环境!