微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MySQL高可用工具—Orchestrator初识

orchestrator是一款开源的MysqL复制拓扑管理工具,采用go语言编写,支持MysqL主从复制拓扑关系的调整、支持MysqL主库故障自动切换、手动主从切换等功能

orchestrator后台依赖于MysqL或者sqlite存储元数据,能够提供Web界面展示MysqL集群的拓扑关系及实例状态,通过Web界面可更改MysqL实例的部分配置信息,同时也提供命令行和api接口,以便更加灵活的自动运维管理。

相比于MHA,orchestrator更加偏重于复制拓扑关系的管理,能够实现MysqL任一复制拓扑关系的调整,并在此基础上,实现MysqL高可用,另外orchestrator自身可以部署多个节点,通过raft分布式一致性协议,保证自身的高可用。

环境说明

后台管理节点

被监测MysqL集群

IP

11.11.10.10

11.21.193.85:335811.42.212.23:335811.42.210.106:3358

操作系统

CentOS 7.2

CentOS 7.2

orchestrator

orchestrator-3.1.2-1.x86_64.rpmorchestrator-cli-3.1.2-1.x86_64.rpmorchestrator-client-3.1.2-1.x86_64.rpm

MysqL

MysqL5.7

MysqL5.6以上,开启GTID复制

后台管理节点 CentOS Linux release 7.2以上,不然可能会出现缺少依赖包。

安装MySQL数据库,在启动orchestrator程序的时候,会自动数据库里创建orchestrator数据库,保存orchestrator的一些数据信息。

下载安装包

https://github.com/github/orchestrator/releaseswget https://github.com/github/orchestrator/releases/download/v3.1.2/orchestrator-3.1.2-1.x86_64.rpm         -服务包wget https://github.com/github/orchestrator/releases/download/v3.1.2/orchestrator-cli-3.1.2-1.x86_64.rpm     -二进制命令wget https://github.com/github/orchestrator/releases/download/v3.1.2/orchestrator-client-3.1.2-1.x86_64.rpm  -命令行工具

复制

安装

[root@localhost ~]# rpm -ivh orchestrator-*Preparing...                          ################################# [100%]Updating / installing...   1:orchestrator-cli-1:3.1.2-1       ################################# [100%]Preparing...                          ################################# [100%]Updating / installing...   1:orchestrator-1:3.1.2-1           ################################# [100%]

复制

安装后会在/usr/local下生成orchestrator目录,包含以下文件和目录:

orchestrator-sample-sqlite.conf.json

采用sqlite库模板

orchestrator-sample.conf.json

认的配置模板

orchestrator

应用程序

resources

orchestrator相关的文件:client、web、伪GTID等相关文件

创建后台管理节点的库和用户

CREATE DATABASE IF NOT EXISTS orchestrator;GRANT ALL PRIVILEGES ON `orchestrator`.* TO 'orc_server_user'@'%' IDENTIFIED BY 'server_passwd';

复制

被监测的MysqL授权

GRANT SUPER, PROCESS, REPLICATION SLAVE, RELOAD ON *.* TO 'orc_client_user'@'%' IDENTIFIED BY 'client_passwd';

复制

修改配置文件

cp orchestrator-sample.conf.json orchestrator.conf.json

  "Debug": false,                               #设置Debug方式  "EnableSyslog": false,                        #是否把日志输出到系统日志里  "ListenAddress": ":3000",                     #web端口  "MysqLTopologyUser": "orc_client_user",       #被监测的MysqL实例用户  "MysqLTopologyPassword": "client_passwd",     #被监测的MysqL实例密码  "MysqLorchestratorHost": "11.11.10.10",       #后台管理主机  "MysqLorchestratorPort": 3306,                #后台管理库端口  "MysqLorchestratorDatabase": "orchestrator",  #后台管理库名  "MysqLorchestratorUser": "orc_server_user",   #后台管理库用户  "MysqLorchestratorPassword": "server_passwd", #后台管理库密码  "MysqLHostnameResolveMethod": "@@report_host",#解析主机名方式  "DetectClusteraliasQuery": "SELECT concat(@@report_host,':',@@port)", #集群别名

复制

官方参考配置:https://github.com/github/orchestrator/blob/master/docs/configuration-sample.md

配置参数解释:MySQL高可用工具—Orchestrator配置说明

启动

/usr/local/orchestrator/orchestrator -config=/usr/local/orchestrator/orchestrator.conf.json http &

复制

查看端口

[root@localhost orchestrator]# netstat  -nltp|grep 3000tcp6       0      0 :::3000                 :::*                    LISTEN      574969/orchestrator

复制

命令行注册集群

orchestrator -config=/usr/local/orchestrator/orchestrator.conf.json -c discover -i 192.168.1.2:3306

复制

命令行查看集群

orchestrator -c clusters

复制

通过web访问

http://11.11.10.10:3000

页面discover

查看集群架构

拖动更改架构

 

来源:MySQL高可用工具—Orchestrator初识 - 腾讯云开发者社区-腾讯云

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐