专栏首页MYSQL轻松学MySQL高可用工具—Orchestrator初识

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轻松学(learnmysql)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-10-17

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • ASP.NET Ajax AsyncFileUpload 控件用法

    AsyncFileUpload控件,就是用来对文件进行异步上传的,示例看这里:http://www.asp.net/ajax/ajaxcontroltoolki...

    thz
  • 利用JS生成自己的个性二维码

    二维码又称QR Code,QR全称Quick Response,是一个近几年来移动设备上超流行的一种编码方式,它比传统的Bar Code条形码能存更多的信息,也...

    框架师
  • 夯实Java基础系列3:一文搞懂String常见面试题,从基础到实战

    本系列文章将整理到我在GitHub上的《Java面试指南》仓库,更多精彩内容请到我的仓库里查看

    黄小斜
  • python购物车升级版

    注意: # swb 用户为管理员用户,可以执行管理员操作(swb 以及 tank的密码均为 123),右键starts.py文件运行即可

    suwanbin
  • js2

    到目前为止,我们已经学过了JavaScript的一些简单的语法。但是这些简单的语法,并没有和浏览器有任何交互。

    suwanbin
  • Asp.net Ajax AutoComplete 控件的用法

    AutoComplete控件是微软提供的ASP.NET AJAX Control Toolkit 中的一个控件,是用来实现类似百度搜索的自动完成效果。

    thz
  • 非常好用的 VS Code 插件推荐

    编码过程中,尤其在我们使用js进行函数式编程时,代码里会有很多的花括号,想要保证它们对称十分困难,所以就出现了上面小粉同学的尴尬局面,相信很多人都遇到过类似的情...

    桃翁
  • python整型-浮点型-字符串-列表及内置函数(上)

    转换字符串的大小写(只影响字母) lower  upper  capitalize  swapcase  title

    suwanbin
  • Vue.js

    这个星期把Vue学习了一下。Vue.js是对JavaScript进行了封装,语法风格和小程序很像,比如双大括号{{}}都是插值表达式。也许它们有...

    用户3112896
  • python包-logging-hashlib-openpyxl模块-深浅拷贝-04

    包: # 包是一系列模块文件的结合体,表现形式是文件夹,该文件夹内部通常会包含一个__init__.py文件,本质上还是一个模块

    suwanbin

扫码关注云+社区

领取腾讯云代金券