MySQL Fabric安装

MySQL Fabric是Oracle提供的用于辅助进行ha\sharding的工具,它的基本架构:

从上面看出,借助于Fabric, 可以搭建 HA 集群、Sharing 、HA+Sharding。

应用从fabric中得知各个数据库、表、分区等的映射关系,然后访问相应的mysql 实例。

Fabric由三个组件组成:

1)fabric 的管理工具(也就是 mysqlfabric)。

2)fabric nodes,可以启动1到多个node。每个node也是一个进程。用于处理fabric的管理请求、应用的mapping请求。

3)backstore,它也是一个mysql server,维护了HA Group、Sharding Group。

下载

在mysql 5.6之后的版本,可以使用fabric的对应版本是1.5,在mysql官网上可以直接下载。由于fabric是由python语言编写的,并且内部通信用会用到 mysql-connector- python,所以也要下载对应的python驱动。

我下载的版本是:

mysql-utiltities-1.5.6-1.el6.noarch.rpmmysql-connector-ptyhon-2.0.4-1.el6.noarch.rpm

安装

1、安装介质

使用操作系统root用户来安装。

先安装mysql-connector-ptyhon,再安装mysql-utilities:

rpm–imysql-connector-ptyhon-2.0.4-1.el6.noarch.rpmrpm–imysql-utiltities-1.5.6-1.el6.noarch.rpm

安装完毕后,会有一个mysqlfabric命令可以使用。所以可以通过该命令来判定是否安装成功。

2、配置文件

在安装好fabric之后,就会有一个默认的配置文件:fabric.cfg。

默认的配置文件的位置:

Platform

Package

Location

Microsoft Windows

mysql-utilities-1.5.6-win32.msi

UTILITIES_INSTALLDIR/etc/mysql/fabric.cfg

Ubuntu Linux 14.04

mysql-utilities_1.5.6-1ubuntu14.04_all.deb

/etc/mysql/fabric.cfg

Debian Linux 6.0

mysql-utilities_1.5.6-1debian6.0_all.deb

/etc/mysql/fabric.cfg

Red Hat Enterprise Linux 6 / Oracle Linux 6

mysql-utilities-1.5.6-1.el6.noarch.rpm

/etc/mysql/fabric.cfg

OS X

mysql-utilities-1.5.6-osx10.9.dmg

/etc/mysql/fabric.cfg

默认的配置文件预览:

[DEFAULT]prefix=/usr/localsysconfdir=/usr/local/etclogdir=/var/log[storage]address=localhost:3306user=fabric_storepassword=secretdatabase=mysql_fabricauth_plugin=mysql_native_passwordconnection_timeout=6connection_attempts=6connection_delay=1[servers]user=fabric_serverpassword=secretbackup_user=fabric_backupbackup_password=secretrestore_user=fabric_restorerestore_password=secretunreachable_timeout=5[protocol.xmlrpc]address=localhost:32274threads=5user=adminpassword=secretdisable_authentication=norealm=MySQLFabricssl_ca=ssl_cert=ssl_key=[protocol.mysql]address=localhost:32275user=adminpassword=secretdisable_authentication=nossl_ca=ssl_cert=ssl_key=[executor]executors=5[logging]level=INFOurl=file:///var/log/fabric.log[sharding]mysqldump_program=/usr/bin/mysqldumpmysqlclient_program=/usr/bin/mysql[statistics]prune_time=3600[failure_tracking]notifications=300notification_clients=50notification_interval=60failover_interval=0detections=3detection_interval=6detection_timeout=1prune_time=3600[connector]ttl=1

在这个配置文件中,会涉及到很多种帐户:
·backstore

在[storage]区域,用来配置backstore mysql server的信息。所以这里配置的就是backstore mysql server的操作帐户。

该用户必需的权限:

ALTER-altersomedatabaseobjectsCREATE-createmostdatabaseobjectsCREATEVIEW-createviewsDELETE-deleterowsDROP-dropmostdatabaseobjectsEVENT-manageeventsREFERENCES-foreignkeysINDEX-createindexesINSERT-insertrowsSELECT-selectrowsUPDATE-updaterows

·server

在[servers]区域配置的,是所有的受管mysql server的帐户。

该用户必需的权限:

其中全局满围的权限:

DELETE-prune_shardPROCESS-listsessionstokillRELOAD-RESETSLAVEREPLICATIONCLIENT-SHOWSLAVESTATUSREPLICATIONSLAVE-SHOWSLAVEHOSTS

其中Fabric 数据库的权限:

ALTER-altersomedatabaseobjectsCREATE-createmostdatabaseobjectsDELETE-deleterowsDROP-dropmostdatabaseobjectsINSERT-insertrowsSELECT-selectrowsUPDATE-updaterows

·backup

在[servers]区域配置的,它是所有的受管mysql server上用于backup的帐户。例如执行mysqldump。

该用户的权限:

EVENT-showeventinformationEXECUTE-showroutineinformationinsideviewsREFERENCES-foreignkeysSELECT-readdataSHOWVIEW-SHOWCREATEVIEWTRIGGER-showtriggerinformation

·restore

在[servers]区域配置的,它是所有的受管mysql server上用于restore的帐户。Restore 用户可以使用mysql client执行restore操作。

该用户的权限:

ALTER-ALTERDATABASEALTERROUTINE-ALTER{PROCEDURE|FUNCTION}CREATE-CREATETABLECREATEROUTINE-CREATE{PROCEDURE|FUNCTION}CREATETABLESPACE-CREATETABLESPACECREATEVIEW-CREATEVIEWDROP-DROPTABLE(usedbeforeCREATETABLE)EVENT-DROP/CREATEEVENTINSERT-writedataLOCKTABLES-LOCKTABLES(--single-transaction)REFERENCES-CreatetableswithforeignkeysSELECT-LOCKTABLES(--single-transaction)SUPER-SET@@SESSION.SQL_LOG_BIN=0TRIGGER-CREATETRIGGER

·admin

在[protocol.mysql]、[protocol.xmlrpc]中配置的admin用户,是Fabric 的客户端(包括mysqlfabric、使用jdbc驱动的应用等) 与fabric node交互使用的用户、密码。

在使用mysqlfabric时,可以使用默认的配置文件,也可以使用自定义的配置文件。不管使用哪个配置文件,相关的配置项都是要配的。

3、创建backstore帐户

创建一个mysql 实例作为fabric 的backstore。然后创建一个fabric backstore帐户。

CREATEUSER'fabric_store'@'localhost'IDENTIFIEDBY'secret';GRANTALTER,CREATE,CREATEVIEW,DELETE,DROP,EVENT,INDEX,INSERT,REFERENCES,SELECT,UPDATEONmysql_fabric.*TO'fabric_store'@'localhost';

创建的这个用户名、密码要跟配置文件fabric.cfg中[storeage]区域中的user、password相同。

此时fabric数据库还没有创建,但是也不要自己去创建。

4、初始化fabric数据库、表

使用mysqlfabric初始化:

mysqlfabricmanagesetup

如果要使用自定义的fabric.cfg配置文件:

mysqlfabric--config=/your/fabric/cfg/pathmanagesetup

5、mysqlfabric命令

1)启动fabric节点

mysqlfabric--config=/your/fabric/cfg/pathmanagestart

2)停止fabric节点

mysqlfabric--config=/your/fabric/cfg/pathmanagestop

至于其它命令,可以参考官方文档。