设为首页 收藏本站
查看: 1024|回复: 0

[经验分享] MySQL:Fabric 安装

[复制链接]

尚未签到

发表于 2018-10-9 10:39:06 | 显示全部楼层 |阅读模式
  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.4-1.el6.noarch.rpm  
rpm –i mysql-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/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 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

  ·server
  在[servers]区域配置的,是所有的受管mysql server的帐户。
  该用户必需的权限:
  其中全局满围的权限:
DELETE             - prune_shard  
PROCESS            - list sessions to killRELOAD             - RESET SLAVEREPLICATION CLIENT - SHOW SLAVE STATUSREPLICATION SLAVE  - SHOW SLAVE HOSTS
  其中Fabric 数据库的权限:

ALTER              - alter some database objectsCREATE             - create most database objectsDELETE             - delete rowsDROP               - drop most database objectsINSERT             - insert rowsSELECT             - select rowsUPDATE             - update rows
  ·backup
  在[servers]区域配置的,它是所有的受管mysql server上用于backup的帐户。例如执行mysqldump。
  该用户的权限:

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

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

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

  ·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  至于其它命令,可以参考官方文档。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-619487-1-1.html 上篇帖子: mysql rpm包安装后修改数据目录 下篇帖子: MySQL:常见使用问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表