MySQL Fabric 分片性能测试
苦逼的人生,开始了新一轮调研。这次是上面要看 MySQL Fabric 分片性能,好吧,开搞。
1 啥是 MySQL Fabric
其实就是一个Python进程和应用端的Connector的组合。来一张官方图:
看到了吧,Fabric就是会启动一个python daemon进程作为xml rpc服务器,应用端的Connector会自动连接这个服务器获取信息判断该连接哪个MySQL服务器。Fabric服务器还会监控各个HA组,出现问题时自动切换主从。尼玛这性能能好才有鬼呢!
2 前置条件
- 需要 MySQL 版本 > 5.6.
- 需要单独一台 MySQL 作为Fabric服务器的 backing store.
- 各个受控的 MySQL 服务器要求打开: gtid_mode (GTID), bin_log (binary logging), 和 log_slave_updates ,并且 server_id 不能有冲突.
- 需要 Python > 2.6.
- 如果是写Java程序的话, Connector/J 版本 > 5.1.27.
3 安装 Fabric
官方文档说从1.6开始Fabric从MySQL Utilities里独立出来了,但是坑爹的是看了半天论坛又发现并没有1.6的包。最新就是1.5.6,请老实下载MySQL Utilities 1.5.6并安装吧,少年!
这里先提供一份我的 fabric.cnf 配置文件,具体就是配置 Fabric 的数据库信息,受控服务器的3种账号,客户端连接 Fabric 服务器使用 XmlRpc 或 MySQL 协议的信息。我这里把disable_authentication 打开了,取消连接 Fabric 时需要的验证,因为需要验证的情况我没试成功,总是 Permission Denie.
#fabric.cnf
[DEFAULT]
prefix =
sysconfdir = /home/will
logdir = /var/log
[storage]
address = 10.202.8.33:23308
user = root
password = root123
database = mysql_fabric
auth_plugin = mysql_native_password
connection_timeout = 6
connection_attempts = 6
connection_delay = 1
[servers]
user = root
password = root123
backup_user = root
backup_password = root123
restore_user = root
restore_password = root123
unreachable_timeout = 5
[protocol.xmlrpc]
address = 10.202.8.33:32274
threads = 5
user = admin
password = root123
disable_authentication = yes
realm =
ssl_ca =
ssl_cert =
ssl_key =
[protocol.mysql]
address = 10.202.8.33:32275
user = admin
password = root123
disable_authentication = yes
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
4 安装数据库
做分片需要至少2台分片用服务器,1台全局服务器存不分片数据(这台的数据会同步的前2台分片服务器上),1台做back store,总共4台MySQL。记得打开: gtid_mode (GTID), bin_log (binary logging), 和 log_slave_updates。我这里打算用mysqld_multi启动多台实例,哈哈48 核,192G内存的机器。
#my.cnf
[mysqld1]
port = 23306
socket =/home/will/mysql/mysql.sock
datadir =/home/will/mysql/data
pid-file =/home/will/mysql/mysql.pid
user =mysql
log-bin =master-bin
log-bin-index =master-bin.index
binlog_format = ROW
binlog-row-image= minimal
binlog-do-db =rcc_will
server-id =1
symbolic-links =0
character_set_server=utf8
skip-external-locking
innodb_flush_log_at_trx_commit = 2
default-storage-engine =innodb
slave-skip-errors=all
max_binlog_size=200M
enforce-gtid-consistency = ON
gtid-mode = ON
log_slave_updates
master_info_repository = TABLE
relay_log_info_repository = TABLE
[mysqld2]
port = 23307
socket = /home/will/mysql2/mysql.sock
datadir =/home/will/mysql2/data
pid-file =/home/will/mysql2/mysql.pid
user =mysql
server-id =2
log-bin =master-bin
log-bin-index =master-bin.index
binlog_format = ROW
binlog-row-image= minimal
binlog-do-db =rcc_will
symbolic-links =0
character_set_server=utf8
skip-external-locking
innodb_flush_log_at_trx_commit = 2
default-storage-engine =innodb
slave-skip-errors=all
max_binlog_size=200M
enforce-gtid-consistency = ON
gtid-mode = ON
log_slave_updates
master_info_repository = TABLE
relay_log_info_repository = TABLE
[mysqld_back]
port = 23308
socket = /home/will/mysql3/mysql.sock
datadir =/home/will/mysql3/data
pid-file =/home/will/mysql3/mysql.pid
user =mysql
server-id =3
symbolic-links =0
character_set_server=utf8
skip-external-locking
innodb_flush_log_at_trx_commit = 2
default-storage-engine =innodb
slave-skip-errors=all
max_binlog_size=200M
enforce-gtid-consistency = ON
gtid-mode = ON
log_slave_updates
master_info_repository = TABLE
relay_log_info_repository = TABLE
[mysqld_global]
port = 23309
socket = /home/will/mysql4/mysql.sock
datadir =/home/will/mysql4/data
pid-file =/home/will/mysql4/mysql.pid
user =mysql
server-id =4
log-bin =master-bin
log-bin-index =master-bin.index
binlog_format = ROW
binlog-row-image= minimal
binlog-do-db =rcc_will
symbolic-links =0
character_set_server=utf8
skip-external-locking
innodb_flush_log_at_trx_commit = 2
default-storage-engine =innodb
slave-skip-errors=all
max_binlog_size=200M
enforce-gtid-consistency = ON
gtid-mode = ON
log_slave_updates
master_info_repository = TABLE
relay_log_info_repository = TABLE
5 初始化Fabric
先初始化 Backing Store 即 Fabric 服务器的 MySQL:
mysqlfabric --config=./fabric.cnf manage setup
再启动 Fabric 服务器:
mysqlfabric manage start
6 分组搞分片
Fabric的HA是按组来搞得,每个组的服务器组成主从并且可以自动切换。我这里每组就一台好了,主要是测分片嘛。
先来3个组:
mysqlfabric --config=./fabric.cnf group create my_group1
mysqlfabric --config=./fabric.cnf group create my_group2
mysqlfabric --config=./fabric.cnf group create my_group_global
再把服务器加入:
mysqlfabric --config=./fabric.cnf group add my_group1 10.202.8.33:23306
mysqlfabric --config=./fabric.cnf group add my_group2 10.202.8.33:23307
mysqlfabric --config=./fabric.cnf group add my_group_global 10.202.8.33:23309
搞起HA:
mysqlfabric --config=./fabric.cnf group promote my_group1
mysqlfabric --config=./fabric.cnf group promote my_group2
mysqlfabric --config=./fabric.cnf group promote my_group_global
激活自动切换,这步可选:
mysqlfabric --config=./fabric.cnf group activate my_group1
mysqlfabric --config=./fabric.cnf group activate my_group2
mysqlfabric --config=./fabric.cnf group activate my_group_global
定义分片的mapping(全局组,分片策略HASH):
mysqlfabric --config=./fabric.cnf sharding create_definition HASH my_group_global
给定义好的mapping(id 1)添加分片的table和列:
mysqlfabric --config=./fabric.cnf sharding add_table 1 db_will.db_users name
添加分片组:
mysqlfabric --config=./fabric.cnf sharding add_shard 1 "my_group1, my_group2" --state=ENABLED
7 创建数据库
这里需要在mysqld_global那台机器上手动create database db_will,然后就自动同步到其他服务器了。
8 Java客户端
// 数据源
FabricMySQLDataSource ds = new FabricMySQLDataSource();
ds.setServerName("10.202.8.33");
ds.setPort(32274);
ds.setDatabaseName("db_will");
ds.setFabricShardTable("db_users");
ds.setUser("root");
ds.setPassword("root123"); //创建表
JDBC4FabricMySQLConnection conn = (JDBC4FabricMySQLConnection) ds.getConnection();
Statement stat = conn.createStatement();
stat.execute(“CREATE TABLE `db_users` ( … ”); //插入数据
JDBC4FabricMySQLConnection conn = (JDBC4FabricMySQLConnection) ds.getConnection();
PreparedStatement stat = conn.prepareStatement("insert into db_users (`name`) values (?)");
for (long i = 0; i < 20 * 1024 * 1024; i++) {
conn.setShardKey(String.valueOf(i));
stat.setString(1, String.valueOf(i));
stat.executeUpdate();
} //查询数据
conn.setShardKey(imsi);
ResultSet rs = stat.executeQuery("SELECT * FROM `db_users` WHERE name=" + name);
可以看到主要是通过conn.setShardKey来实现选择分片组的。
9 性能
插入20M的数据,尼玛花了5个小时,每秒也就1000条吧。
然后增删改查基本都在20毫秒的级别。
最后同时查询也就能达到130个连接,再多就挂了,python服务器撑不住啊。
MySQL Fabric 分片性能测试的更多相关文章
- 甲骨文推出MySQL Fabric,简化MySQL的高可用性与可扩展性
北京,2014年5月28日——为了满足当下对Web及云应用需求,甲骨文宣布推出MySQL Fabric.MySQL Fabric是一款可简化管理MySQL数据库群的整合式系统.该产品通过故障检测和故障 ...
- Mysql Fabric实现学习笔记
Mysql Fabric用来管理mysql服务,提供扩展性和容易使用的系统,管理mysql分片和高可用部署(当前实现了两个特性:高可用和使用数据分片的横向扩展,能单独使用或结合使用这两个特性.). 架 ...
- MySQL Fabric和MyBatis的整合过程中遇到的问题
这是我昨天在整合MySQL Fabric和MyBatis时遇到的问题,花了大半天才解决的问题,解决的过程中在网上查找了很久,都没有找到解决的方案.现在记下来,希望能够帮助有同样问题的朋友.如果各位朋友 ...
- mysql几种性能测试的工具使用
mysql几种性能测试的工具使用 近期由于要比较mysql及其分支mariadb, percona的性能,了解了几个这方面的工具,包括:mysqlslap sysbench tpcc-mysql,做一 ...
- MySQL加密的性能测试
这是对MySQL进行加密性能测试的两篇文章系列之二.在第一篇中,我专门使用MySQL的内置的对SSL的支持来 做压力测试,产生了一些令人惊讶的结果. AD:WOT2015 互联网运维与开发者大会 热销 ...
- MySQL Fabric部署
架构描写叙述: 一台主机上安装4个MySQL 服务,当中一个MySQL服务用于存储MySQL Fabric后台数据:另外3个MySQL服务用于主从架构測试.一个主+两个从. 第一部分:二进制方式安装M ...
- HBase 高性能获取数据(多线程批量式解决办法) + MySQL和HBase性能测试比较
摘要: 在前篇博客里已经讲述了通过一个自定义 HBase Filter来获取数据的办法,在末尾指出此办法的性能是不能满足应用要求的,很显然对于如此成熟的HBase来说,高性能获取数据应该不是问题. ...
- 【MySQL】Sysbench性能测试
两台MySQL配置不一样,要测试下性能差别 [m1] long_query_time = 0.1 log_slave_updates innodb_flush_log_at_trx_commit [m ...
- mysql分区/分片
一.分区概念 mysql 5.1 以后支持分区, 有点类似MongoDB中的分片概念. 就是按照一定的规则, 将一个数据库表分解成很多细小的表, 这些细小的表可以是物理的分区, 就是在不同的位置. 但 ...
随机推荐
- 在linux下挂载、卸载U盘
首先你得保证你的U盘的格式是fat格式. 先进入/mnt/目录新建一个usb目录 cd /mnt/ mkidr usb 先fdisk -l,然后插上U盘,fdisk -l 查看是否有新的硬盘添加上来了 ...
- Eplan中电缆源和目标的确定规则
使用过Eplan的都知道,生成电缆总览时会有源和目标,电缆是怎么定义源和目标的呢,下面给大家讲解.确定源和目标按照下列规则确定电缆的源和目标: 首先考虑结构标识符中标识性的层结构说明.如果两端都是端子 ...
- [转]优秀Python学习资源收集汇总
Python是一种面向对象.直译式计算机程序设计语言.它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用縮进来定义语句块.与Scheme.Ruby.Perl ...
- apache服务器配置Net的实践
前置: 在xp系统中,打补丁之类或啥子操作引起或多或少的问题,最终导致iis不能使用: 不想装系统...忍着... 最近突发事件导致,需要摸一下apache服务器处理,好吧,那就搜索下吧..... 目 ...
- oracle 查询月份差
select to_char(add_months(trunc(sysdate),-1),'yyyymm') from dual;
- 蓝凌表单的表体调用Javascript
应用场景:像请假类表单会在从表输入开始时间.结束时间等字段 需求1:客户希望根据开始.结束时间自动计算小时数 解决方法: 1.主表单增加一行,设三个字段[开始时间合计].[结束时间合计].[开始结束时 ...
- Angular.js表单以及与Bootatrap的使用
首先从angular.js的目录开始,如下图,知道了我们要学什么,然后再开始有目的的学习与对比. 1.从表达式开始: ng-app指令初始化一个 AngularJS 应用程序. ng-init指令初始 ...
- MyBatis XML 映射配置文件
配置文件的基本结构 configuration —— 根元素 properties —— 定义配置外在化 settings —— 一些全局性的配置 typeAliases —— 为一些类定义别名 ty ...
- bootstrap插件学习-bootstrap.button.js
先看bootstrap.button.js的结构 var Button = function ( element, options ){} //构造器 Button.prototype = {} // ...
- Transact-SQL 示例 - 使用脚本备份数据库的示例
在常规的数据库开发与维护的过程中,常常需要对数据库进行数据备份,最入门的办法就是使用SSMS图形化界面提供的数据库备份向导一步一步操作进行备份,这种方式虽然简单快捷但是日子久了就会觉得重复且繁琐.下面 ...