溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL:Fabric 安裝

發(fā)布時間:2020-08-07 16:57:23 來源:網(wǎng)絡(luò) 閱讀:677 作者:胡壯壯 欄目:MySQL數(shù)據(jù)庫

MySQL Fabric安裝

 

MySQL Fabric是Oracle提供的用于輔助進(jìn)行ha\sharding的工具,它的基本架構(gòu):

 MySQL:Fabric 安裝

 

 

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

應(yīng)用從fabric中得知各個數(shù)據(jù)庫、表、分區(qū)等的映射關(guān)系,然后訪問相應(yīng)的mysql 實(shí)例。

 

Fabric由三個組件組成:

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

2)fabric nodes,可以啟動1到多個node。每個node也是一個進(jìn)程。用于處理fabric的管理請求、應(yīng)用的mapping請求。

3)backstore,它也是一個mysql server,維護(hù)了HA Group、Sharding Group。

 

 

 

下載

 

在mysql 5.6之后的版本,可以使用fabric的對應(yīng)版本是1.5,在mysql官網(wǎng)上可以直接下載。由于fabric是由python語言編寫的,并且內(nèi)部通信用會用到 mysql-connector- python,所以也要下載對應(yīng)的python驅(qū)動。

         我下載的版本是:

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

 

  

安裝

1、安裝介質(zhì)

使用操作系統(tǒng)root用戶來安裝。

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

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

 安裝完畢后,會有一個mysqlfabric命令可以使用。所以可以通過該命令來判定是否安裝成功。

2、配置文件

在安裝好fabric之后,就會有一個默認(rèn)的配置文件:fabric.cfg。

默認(rèn)的配置文件的位置:

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

 

默認(rèn)的配置文件預(yù)覽:

MySQL:Fabric 安裝

[DEFAULT]
prefix = /usr/local
sysconfdir = /usr/local/etc
logdir = /var/log

[storage]
address = localhost:3306
user = fabric_store
password = secret
database = mysql_fabric
auth_plugin = mysql_native_password
connection_timeout = 6
connection_attempts = 6
connection_delay = 1

[servers]
user = fabric_server
password = secret
backup_user = fabric_backup
backup_password = secret
restore_user = fabric_restore
restore_password = secret
unreachable_timeout = 5

[protocol.xmlrpc]
address = localhost:32274
threads = 5
user = admin
password = secret
disable_authentication = no
realm = MySQL Fabric
ssl_ca =
ssl_cert =
ssl_key =

[protocol.mysql]
address = localhost:32275
user = admin
password = secret
disable_authentication = no
ssl_ca =
ssl_cert =
ssl_key =

[executor]
executors = 5

[logging]
level = INFO
url = file:///var/log/fabric.log

[sharding]
mysqldump_program = /usr/bin/mysqldump
mysqlclient_program = /usr/bin/mysql

[statistics]
prune_time = 3600

[failure_tracking]
notifications = 300
notification_clients = 50
notification_interval = 60
failover_interval = 0
detections = 3
detection_interval = 6
detection_timeout = 1
prune_time = 3600

[connector]
ttl = 1

MySQL:Fabric 安裝

 

在這個配置文件中,會涉及到很多種帳戶:
·backstore

在[storage]區(qū)域,用來配置backstore mysql server的信息。所以這里配置的就是backstore mysql server的操作帳戶。

該用戶必需的權(quán)限:

MySQL:Fabric 安裝

ALTER              - alter some database objectsCREATE             - create most database objectsCREATE VIEW        - create viewsDELETE             - delete rowsDROP               - drop most database objects
EVENT              - manage eventsREFERENCES         - foreign keysINDEX              - create indexesINSERT             - insert rowsSELECT             - select rowsUPDATE             - update rows

MySQL:Fabric 安裝

  

·server

在[servers]區(qū)域配置的,是所有的受管mysql server的帳戶。

該用戶必需的權(quán)限:

其中全局滿圍的權(quán)限:

DELETE             - prune_shard
PROCESS            - list sessions to killRELOAD             - RESET SLAVEREPLICATION CLIENT - SHOW SLAVE STATUSREPLICATION SLAVE  - SHOW SLAVE HOSTS

 

其中Fabric 數(shù)據(jù)庫的權(quán)限:

MySQL:Fabric 安裝

ALTER              - alter some database objectsCREATE             - create most database objectsDELETE             - delete rowsDROP               - drop most database objectsINSERT             - insert rowsSELECT             - select rowsUPDATE             - update rows

MySQL:Fabric 安裝

 

·backup

在[servers]區(qū)域配置的,它是所有的受管mysql server上用于backup的帳戶。例如執(zhí)行mysqldump。

該用戶的權(quán)限:

MySQL:Fabric 安裝

EVENT              - show event informationEXECUTE            - show routine information inside viewsREFERENCES         - foreign keysSELECT             - read data
SHOW VIEW          - SHOW CREATE VIEWTRIGGER            - show trigger information

MySQL:Fabric 安裝

 

·restore

在[servers]區(qū)域配置的,它是所有的受管mysql server上用于restore的帳戶。Restore 用戶可以使用mysql client執(zhí)行restore操作。

該用戶的權(quán)限:

MySQL:Fabric 安裝

ALTER              - ALTER DATABASEALTER ROUTINE      - ALTER {PROCEDURE|FUNCTION}CREATE             - CREATE TABLECREATE ROUTINE     - CREATE {PROCEDURE|FUNCTION}CREATE TABLESPACE  - CREATE TABLESPACECREATE VIEW        - CREATE VIEWDROP               - DROP TABLE (used before CREATE TABLE)
EVENT              - DROP/CREATE EVENTINSERT             - write data
LOCK TABLES        - LOCK TABLES (--single-transaction)REFERENCES         - Create tables with foreign keysSELECT             - LOCK TABLES (--single-transaction)SUPER              - SET @@SESSION.SQL_LOG_BIN = 0TRIGGER            - CREATE TRIGGER

MySQL:Fabric 安裝

 

·admin 

在[protocol.mysql]、[protocol.xmlrpc]中配置的admin用戶,是Fabric 的客戶端(包括mysqlfabric、使用jdbc驅(qū)動的應(yīng)用等) 與fabric node交互使用的用戶、密碼。

 在使用mysqlfabric時,可以使用默認(rèn)的配置文件,也可以使用自定義的配置文件。不管使用哪個配置文件,相關(guān)的配置項(xiàng)都是要配的。

 

 

3、創(chuàng)建backstore 帳戶

創(chuàng)建一個mysql 實(shí)例作為fabric 的backstore。然后創(chuàng)建一個fabric backstore帳戶。

MySQL:Fabric 安裝

CREATE USER 'fabric_store'@'localhost'
   IDENTIFIED BY 'secret';GRANT ALTER, CREATE, CREATE VIEW, DELETE, DROP, EVENT,   INDEX, INSERT, REFERENCES, SELECT, UPDATE ON mysql_fabric.*
   TO 'fabric_store'@'localhost';

MySQL:Fabric 安裝

創(chuàng)建的這個用戶名、密碼要跟配置文件fabric.cfg中[storeage]區(qū)域中的user、password相同。 

此時fabric數(shù)據(jù)庫還沒有創(chuàng)建,但是也不要自己去創(chuàng)建。

 

4、初始化fabric數(shù)據(jù)庫、表

使用mysqlfabric初始化:

mysqlfabric manage setup

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

 

mysqlfabric --config=/your/fabric/cfg/path manage setup

 

5、mysqlfabric命令

1)啟動fabric節(jié)點(diǎn)

mysqlfabric --config=/your/fabric/cfg/path manage start

2)停止fabric節(jié)點(diǎn) 

mysqlfabric --config=/your/fabric/cfg/path manage stop

至于其它命令,可以參考官方文檔。 


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI