MySQL:Fabric 安装
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.rpm
mysql-connector-ptyhon-2.0.4-1.el6.noarch.rpm
安装
1、安装介质
使用操作系统root用户来安装。
先安装mysql-connector-ptyhon,再安装mysql-utilities:
rpm –i mysql-connector-ptyhon-2.0.-.el6.noarch.rpm
rpm –i mysql-utiltities-1.5.-.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/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
在这个配置文件中,会涉及到很多种帐户:
·backstore
在[storage]区域,用来配置backstore mysql server的信息。所以这里配置的就是backstore mysql server的操作帐户。
该用户必需的权限:
ALTER - alter some database objects
CREATE - create most database objects
CREATE VIEW - create views
DELETE - delete rows
DROP - drop most database objects
EVENT - manage events
REFERENCES - foreign keys
INDEX - create indexes
INSERT - insert rows
SELECT - select rows
UPDATE - update rows
·server
在[servers]区域配置的,是所有的受管mysql server的帐户。
该用户必需的权限:
其中全局满围的权限:
DELETE - prune_shard
PROCESS - list sessions to kill
RELOAD - RESET SLAVE
REPLICATION CLIENT - SHOW SLAVE STATUS
REPLICATION SLAVE - SHOW SLAVE HOSTS
其中Fabric 数据库的权限:
ALTER - alter some database objects
CREATE - create most database objects
DELETE - delete rows
DROP - drop most database objects
INSERT - insert rows
SELECT - select rows
UPDATE - update rows
·backup
在[servers]区域配置的,它是所有的受管mysql server上用于backup的帐户。例如执行mysqldump。
该用户的权限:
EVENT - show event information
EXECUTE - show routine information inside views
REFERENCES - foreign keys
SELECT - read data
SHOW VIEW - SHOW CREATE VIEW
TRIGGER - show trigger information
·restore
在[servers]区域配置的,它是所有的受管mysql server上用于restore的帐户。Restore 用户可以使用mysql client执行restore操作。
该用户的权限:
ALTER - ALTER DATABASE
ALTER ROUTINE - ALTER {PROCEDURE|FUNCTION}
CREATE - CREATE TABLE
CREATE ROUTINE - CREATE {PROCEDURE|FUNCTION}
CREATE TABLESPACE - CREATE TABLESPACE
CREATE VIEW - CREATE VIEW
DROP - DROP TABLE (used before CREATE TABLE)
EVENT - DROP/CREATE EVENT
INSERT - write data
LOCK TABLES - LOCK TABLES (--single-transaction)
REFERENCES - Create tables with foreign keys
SELECT - LOCK TABLES (--single-transaction)
SUPER - SET @@SESSION.SQL_LOG_BIN = 0
TRIGGER - CREATE TRIGGER
·admin
在[protocol.mysql]、[protocol.xmlrpc]中配置的admin用户,是Fabric 的客户端(包括mysqlfabric、使用jdbc驱动的应用等) 与fabric node交互使用的用户、密码。
在使用mysqlfabric时,可以使用默认的配置文件,也可以使用自定义的配置文件。不管使用哪个配置文件,相关的配置项都是要配的。
3、创建backstore 帐户
创建一个mysql 实例作为fabric 的backstore。然后创建一个fabric backstore帐户。
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';
创建的这个用户名、密码要跟配置文件fabric.cfg中[storeage]区域中的user、password相同。
此时fabric数据库还没有创建,但是也不要自己去创建。
4、初始化fabric数据库、表
使用mysqlfabric初始化:
mysqlfabric manage setup
如果要使用自定义的fabric.cfg配置文件:
mysqlfabric --config=/your/fabric/cfg/path manage setup
5、mysqlfabric命令
1)启动fabric节点
mysqlfabric --config=/your/fabric/cfg/path manage start
2)停止fabric节点
mysqlfabric --config=/your/fabric/cfg/path manage stop
至于其它命令,可以参考官方文档。
MySQL:Fabric 安装的更多相关文章
- MySQL Fabric 分片性能测试
苦逼的人生,开始了新一轮调研.这次是上面要看 MySQL Fabric 分片性能,好吧,开搞. 1 啥是 MySQL Fabric 其实就是一个Python进程和应用端的Connector的组合.来一 ...
- MySQL Fabric部署
架构描写叙述: 一台主机上安装4个MySQL 服务,当中一个MySQL服务用于存储MySQL Fabric后台数据:另外3个MySQL服务用于主从架构測试.一个主+两个从. 第一部分:二进制方式安装M ...
- Mysql Fabric实现学习笔记
Mysql Fabric用来管理mysql服务,提供扩展性和容易使用的系统,管理mysql分片和高可用部署(当前实现了两个特性:高可用和使用数据分片的横向扩展,能单独使用或结合使用这两个特性.). 架 ...
- MySql免安装版安装配置,附MySQL服务无法启动解决方案
文首提要: 我下载的MySQL版本是:mysql-5.7.17-winx64.zip Archive版:系统:Windows7 64位. 一.解压文件 下载好My ...
- Mysql(windows)安装
h3 { color: rgb(255, 255, 255); background-color: rgb(30,144,255); padding: 3px; margin: 10px 0px } ...
- MYSQL离线安装
由于MySQL的广泛应用,MySQL的安装也就成了大家经常会碰到的问题.并且由于不是所有机器都可连接外网,所以MySQL的离线安装显得比较重要.而本文旨在介绍CentOS6.6下离线安装MySQL. ...
- 虚拟机+apache+php+mysql 环境安装配置
虚拟机的安装:直接下一步即可,注意修改路径. 安装完成后新建虚拟机,直接下一步.如果选择镜像文件后出现错误,可以试着去修改电脑bios中的虚拟化设置,改为enable,如下图: apache安装: 1 ...
- Windows 下 zip 版的 MySQL 的安装
创建 配置文件 当 MySQL server 启动时,它会在按照下表列出位置的顺序寻找并读取配置文件: File Name Purpose %PROGRAMDATA%\MySQL\MySQL Ser ...
- mysql 编译安装
mysql 编译安装方式: ```cd /home/oldboy/tools``` 创建 目录 if not have then mkd ...
随机推荐
- Angular杂谈系列1-如何在Angular2中使用jQuery及其插件
jQuery,让我们对dom的操作更加便捷.由于其易用性和可扩展性,jQuer也迅速风靡全球,各种插件也是目不暇接. 我相信很多人并不能直接远离jQuery去做前端,因为它太好用了,我们以前做的东西大 ...
- 总结:Mac前端开发环境的搭建(配置)
新年新气象,在2016年的第一天,我入手了人生中第一台自己的电脑(大一时好友赠送的电脑在一次无意中烧坏了主板,此后便不断借用别人的或者网站的).macbook air,身上已无分文...接下来半年的房 ...
- 【XSS】延长 XSS 生命期
XSS 的本质仍是一段脚本.和其他文档元素一样,页面关了一切都销毁.除非能将脚本蔓延到页面以外的地方,那样才能获得更长的生命力. 庆幸的是,从 DOM 诞生的那一天起,就已为我们准备了这个特殊的功能, ...
- TODO:即将开发的第一个小程序
TODO:即将开发的第一个小程序 微信小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验.个人理解小程序是寄宿在微信平台上的一个前端框架,具有跨平台功能, ...
- 6. ModelDriven拦截器、Preparable 拦截器
1. 问题 Struts2 的 Action 我们将它定义为一个控制器,但是由于在 Action 中也可以来编写一些业务逻辑,也有人会在 Action 输入业务逻辑层. 但是在企业开发中,我们一般会将 ...
- JavaScript自定义媒体播放器
使用<audio>和<video>元素的play()和pause()方法,可以手工控制媒体文件的播放.组合使用属性.事件和这两个方法,很容易创建一个自定义的媒体播放器,如下面的 ...
- JDBC增加删除修改
一.配置程序--让我们程序能找到数据库的驱动jar包 1.把.jar文件复制到项目中去,整合的时候方便. 2.在eclipse项目右击"构建路径"--"配置构建路径&qu ...
- PHP设计模式(二)工厂方法模式(Factory Method For PHP)
简单工厂简述: 简单工厂模式实现了生产产品类的代码跟客户端代码分离,在工厂类中你可以添加需要生成长跑的逻辑代码(new 产品类),但是问题来了,优秀的代码是符合"开闭原则"如果你要 ...
- android Notification介绍
如果要添加一个Notification,可以按照以下几个步骤 1:获取NotificationManager: NotificationManager m_NotificationManager=(N ...
- LINQ to SQL语句(7)之Exists/In/Any/All/Contains
适用场景:用于判断集合中元素,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足某一条件:不延迟.(若条件为空,则集合只要不为空就返回True,否则为False).有2种形式,分别为简单形式 ...