超赞!墙裂推荐一个MySQL自动化运维工具!

数据库 MySQL 自动化
goInception是一个集审核、执行、备份及生成回滚语句于一身的MySQL运维工具, 通过对执行SQL的语法解析,返回基于自定义规则的审核结果,并提供执行和备份及生成回滚语句的功能。

在这之前,民工哥也给大家介绍过一款开源的SQL管理工具:自动补全、回滚!介绍一款可视化 sql 诊断利器。

今天,民工哥再给大家推荐一款SQL审核利器:goinception。

goinception介绍

goInception是一个集审核、执行、备份及生成回滚语句于一身的MySQL运维工具, 通过对执行SQL的语法解析,返回基于自定义规则的审核结果,并提供执行和备份及生成回滚语句的功能。

github地址:https://github.com/hanchuanchuan/goInception

文档:https://hanchuanchuan.github.io/goInception/

goinception架构

goinception安装

官方提供了几种的安装方式,如下。

  •  1、源码安装

源码安装需要有go V1.2版本以上的环境,使用go mod作依赖管理。 

  1. [root@centos7 ~]# git clone https://github.com/hanchuanchuan/goInception.git  
  2. [root@centos7 ~]# cd goInception  
  3. [root@centos7 ~]# make parser  
  4. [root@centos7 ~]# go build -o goInception tidb-server/main.go 
  • 2、docker方式 
  1. [root@centos7 ~]# docker pull hanchuanchuan/goinception 
  •  3、二进制安装(推荐)

直接上官方提供的地址:https://github.com/hanchuanchuan/goInception/releases/download/去下载对应的版本文件,下载完成后直接解压运行即可。 

  1. [root@centos7 ~]# mkdir goinception  
  2. [root@centos7 ~]# tar zxf goInception-linux-amd64-v1.2.3.tar.gz -C ./goinception/  
  3. [root@centos7 ~]# cd goinception/  
  4. [root@centos7 goinception]# ll  
  5. total 38476  
  6. drwxr-xr-x 2 root root        33 Aug 30 03:48 config  
  7. -rwxr-xr-x 1  501 games 39399424 May 22 07:45 goInception 

解压完成后,在config目录下会看到一个默认的配置文件:config.toml.default,大家可以根据实际情况修改。

goInception采用TiDB源码重构,所以部分参数可参考TiDB相关文档

config.toml文件由几部分组成,分别为最外层配置如host,port等,以及各分组如[inc],[log]等。示例(该示例仅为展示config.toml文件结构,详细参数请参考):https://github.com/hanchuanchuan/goInception/blob/master/config/config.toml.default 

  1. host = "0.0.0.0"  
  2. port = 4000  
  3. path = "/tmp/tidb"  
  4. [log]  
  5. # 日志参数  
  6. level = "info"  
  7. format = "text"  
  8. [log.file]  
  9. # 日志文件参数  
  10. filename = ""  
  11. max-size = 300  
  12. [inc]  
  13. # 审核选项  
  14. enable_nullable = true  
  15. enable_drop_table = false  
  16. check_table_comment = false  
  17. check_column_comment = false  
  18. # 等等...  
  19. [osc]  
  20. # pt-osc参数  
  21. osc_on = false  
  22. osc_min_table_size = 16 
  23. [ghost]  
  24. # gh-ost参数  
  25. ghost_allow_on_master = true 

配置修改完成后,就可以正常启动了。 

  1. [root@centos7 goinception]# ./goInception -config=config/config.toml  
  2. [root@centos7 ~]# netstat -lntp|grep 4000  
  3. tcp6   0   0 :::4000    :::*    LISTEN    1250/./goInception  

使用实例 

  1. /*--user=root;--password=root;--host=127.0.0.1;--check=1;--port=3306;*/  
  2. inception_magic_start;  
  3. use test;  
  4. create table t1(id int primary key);  
  5. inception_magic_commit; 

其它介绍

1、结果信息

给用户返回的信息有两种,

  •  一种是提交给goInception的基础信息存在错误,比如源信息不全,或者源信息有错误等,这种情况下,直接报异常,包括错误码及错误信息,与MySQL服务器的异常是一样的,在外面正常处理即可。
  •  二是如果没有上面的问题,都会以结果集的方式将检查结果告诉客户端。和mysql原生结果集一致。返回的结果集中,每一个行数据,就是一条提交的SQL语句,goInception内部将所有提交的语句块一条条的拆开,以结果集的方式返回,针对每一条语句,有什么问题或者状态,在结果集中是一目了然。

注意:如果在语句中出现语法错误,则不能继续了,因为goInception已经不能将剩下的语句分开了,那么此时前面已经正常检查的多行为多个结果集的行返回,后面出错的语句为一行返回,当然这个的错误信息是语法错误。

2、自带备份功能

自带备份功能,首先服务启动时配置config.toml(放在 [inc] 段)

参数 默认 可选范围 说明
       
backup_host "" string 备份数据库IP地址
backup_port 0 int 备份数据库端口
backup_user "" string 备份数据库用户名
backup_password "" string 备份数据库密码

并且在执行sql时,添加 --backup=true 或 --backup=1 选项。

3、审核规则

相关的审核规则,审核选项等详细信息,可以参考:

  1. https://hanchuanchuan.github.io/goInception/rules.html 

对比Inception

1、功能对比

2、速度

3、使用

这类工具在一定程度上解放了DBA的双手,而且还能在很大程度上避免出错的情况,从而保证SQL的执行正确率,同时还提供SQL回滚功能,在出错时进行回滚,保证数据安全与完整性。 

 

责任编辑:庞桂玉 来源: 民工哥技术之路
相关推荐

2020-11-06 08:43:21

AIOps运维DevOps

2017-03-22 16:31:30

Linux运维自动化ansible

2014-09-22 11:24:18

运维

2018-06-22 09:49:02

自动化运维体系

2018-12-10 08:10:39

2019-10-28 15:14:53

Python脚本语言Java

2015-10-09 13:14:10

clip自动化运维工具

2012-10-22 14:54:48

2015-02-02 10:26:18

自动化运维管理平台

2017-03-22 18:30:44

Linux运维自动化ansible

2014-08-04 10:10:35

IT运维自动化运维

2020-07-21 15:53:18

戴尔

2018-06-23 07:31:05

2017-10-13 13:14:35

互联网

2015-09-10 10:31:53

去哪儿网Inception自动化运维

2022-07-29 14:39:17

Ansible运维工具

2015-10-08 10:55:23

云服务自动化运维 ANSIBLE

2012-11-20 17:22:57

2018-07-26 13:50:37

IT架构运维

2013-04-16 14:55:21

自动化运维Puppet实战
点赞
收藏

51CTO技术栈公众号