文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何使用MySQL自动化运维工具goinception

2024-04-02 19:55

关注

这篇文章主要讲解了“如何使用MySQL自动化运维工具goinception”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用MySQL自动化运维工具goinception”吧!

goinception介绍

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

goinception架构

如何使用MySQL自动化运维工具goinception

goinception安装

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

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

[root@centos7 ~]# git clone https://github.com/hanchuanchuan/goInception.git  [root@centos7 ~]# cd goInception  [root@centos7 ~]# make parser  [root@centos7 ~]# go build -o goInception tidb-server/main.go
[root@centos7 ~]# docker pull hanchuanchuan/goinception

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

[root@centos7 ~]# mkdir goinception  [root@centos7 ~]# tar zxf goInception-linux-amd64-v1.2.3.tar.gz -C ./goinception/  [root@centos7 ~]# cd goinception/  [root@centos7 goinception]# ll  total 38476  drwxr-xr-x 2 root root        33 Aug 30 03:48 config  -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

host = "0.0.0.0"  port = 4000  path = "/tmp/tidb"  [log]  # 日志参数  level = "info"  format = "text"  [log.file]  # 日志文件参数  filename = ""  max-size = 300  [inc]  # 审核选项  enable_nullable = true  enable_drop_table = false  check_table_comment = false  check_column_comment = false  # 等等...  [osc]  # pt-osc参数  osc_on = false  osc_min_table_size = 16 [ghost]  # gh-ost参数  ghost_allow_on_master = true

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

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

使用实例

  inception_magic_start;  use test;  create table t1(id int primary key);  inception_magic_commit;

其它介绍

1、结果信息

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

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

2、自带备份功能

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

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

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

3、审核规则

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

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

对比Inception

1、功能对比

如何使用MySQL自动化运维工具goinception

2、速度

如何使用MySQL自动化运维工具goinception

3、使用

如何使用MySQL自动化运维工具goinception

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

感谢各位的阅读,以上就是“如何使用MySQL自动化运维工具goinception”的内容了,经过本文的学习后,相信大家对如何使用MySQL自动化运维工具goinception这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯