mysql router测试_MySQL Router 测试使用 转

MySQL Router 测试使用1. 特性

MySQL Router 并没有包括一些特别新的特性, 总体上看中规中矩, 不过 first-available 和插件两个特性挺有意思, 后续会进行讲解, 特性包括:

对连接请求进行路由;和 Fabric 配套使用, 方便管理;

插件特性, 需要的功能以插件形式提供;2. 配置

MySQL Router 在启动的时候会读取默认的配置文件, 用户可以通过-DROUTER_CONFIGDIR= 或编辑 cmake/settings.cmake 来自定义配置文件, 默认情况下从以下路径读取:

[root@cz-centos7 bin]# ./mysqlrouter --help

Copyright (c)2015, Oracle and/or its affiliates. All rights reserved.

Oracleis a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.

Start MySQL Router.

Configuration readfrom the following files inthe given order (enclosedin parentheses means not available forreading):

(./mysqlrouter.ini)

(/root/.mysqlrouter.ini)

Usage: mysqlrouter [-v|--version] [-h|--help]

[-c|--config=]

[-a|--extra-config=]

Options:-v, --version

Display version information and exit.-h, --help

Displaythishelp and exit.-c , --config

Only read configurationfromgiven file.-a , --extra-config

Readthis file after configuration files are read fromeitherdefault locations or from files specified by the --config

option.

值得一提的是-c 选项指定的配置会被最先加载, -a 指定的配置后续加载.2.1配置文件设置2.1.1通用选项

通用选项可以放到 [DEFAULT] 块中, 通常包括一些目录路径配置:

logging_folder: MySQL Router 运行时产生 log 的目录路径, log 文件默认为 mysqlrouter.log, 不设置路径默认输出到标准输出(STDOUT);

plugin_folder: MySQL Router 的插件路径, 该路径必须和 MySQL Router 的安装目录对应上, 如果是自定义的安装路径, 该选项必须要指定, 默认为/usr/local/lib/mysqlrouter;

runtime_folder: MySQL Router 运行时候的目录路径, 默认为/usr/local ;

config_folder: MySQL Router 配置文件的路径, 默认为/usr/loca/etc/mysqlrouter

举例如下:

[DEFAULT]

logging_folder= /var/log/mysqlrouter

plugin_folder= /usr/local/mysqlrouter/lib

runtime_folder= /usr/local/mysqlrouter2.1.2路由选项

以下选项可以放到路由策略 [routing:] 块中:

bind_address: 工具启动的时候绑定的网卡地址, 默认为127.0.0.1, 如果没有指定端口, bind_port 选项则必须指定;

bind_port: 工具启动监听的端口, 如果 bind_address 以 ip:port 形式指定, 则 bind_port 不需要再指定;

connect_timeout: 工具连接后端 MySQL Server 的超时时间, 默认为 1s, 有效的值为1 ~ 65535;

destinations: 以分号形式提供后端需要连接的 MySQL Server 列表;

mode: 该选项必须要指定, 不同模式对应不同的调度策略, 目前支持两种方式: read-write 和 read-only;

max_connections: 连接到 MySQL Router 的最大连接数, 类似 MySQL Server 中的 max_connections 选项;

在 mode 选项中, 我们可以选用 read-write 和 read-only 模式:

read-write: 通常用于路由到后端的 MySQL master, 在 read-write 模式中, 所有的流量都转发到 destinations 指定的列表的首个地址, 比如 “127.0.0.1:3301, 127.0.0.1:3302″, 则所有的流量都转发到 3301 端口, 如果 3301 端口失败, 则尝试连接 3302 端口, 如果列表中没有有效的MySQL Server, 路由请求会被中断丢弃; 这种方式被称作 “first-available”. 这种方式可以适用于一般的主从架构中, 比如指定列表 “master:3301, slave1:3301″, 在 master 出现故障的时候, MySQL Router 会自己连接 slave1, 不过中间的切换过程需要我们做很多的操作来满足这种工作模式.

read-only: 路由请求到后端的 MySQL slave, 从这点看 read-only 模式下, destitions 指定的 MySQL Server 列表应该都是 slave, 不同于 read-write 都指定的是 master. 在 read-only 模式中, 使用轮询( round-robin )方式转发请求到后端的 Server. 如果一个 Server 不可用,则尝试下一个 Server, 这意味着不会丢失一个请求, 如果服务都不可用, 则丢弃请求.这种模式下如果应用读写分离, read-only 会是比较好的选择.

从上面两点看, MySQL Router 的服务模式和我们熟知的 cobar, atlas, kingshard 等大为不同, master, slave 都需要单独配置, 这点在扩展性方面比较差, 估计很多人不会喜欢该模式, 不过话说回来, 如果能够和 Fabric 很好的配合使用的话, 可能会吸引一部分用户使用.2.1.3日志

日志选择可以放到 [logger] 块中, 可以用来指定日志级别, 默认为 INFO, 输出则依赖 logging_folder 的选项:

[logger]

level=DEBUG2.2配置举例

我们以读扩展的配置举例说明(read-write 模式估计不受欢迎 ~~, 可以配置多个 routing:, MySQL Router 可以启动多个routing ):

[DEFAULT]

logging_folder= /usr/local/mysqlrouter/log

plugin_folder= /usr/local/mysqlrouter/lib/mysqlrouter

runtime_folder= /usr/local/mysqlrouter

[logger]

level=DEBUG

[routing:readtest]

bind_address= 0.0.0.0:7001mode= read-only

destinations= 10.0.21.7:3301,10.0.21.17:3301#不能有空格3连接测试

启动

./bin/mysqlrouter -c /usr/local/mysqlrouter/etc/mysqlrouter.ini

先来看看最简单的测试:

[root@cz-centos7 ~]# time for x in `seq 1 5`; do /opt/Percona-Server-5.5.33-rel31.1-566.Linux.x86_64/bin/mysql -h 10.0.21.90 -P 7001 -uroot percona -Bse "show global variables like 'hostname'; show tables"; done配置举例

[DEFAULT]

logging_folder= /usr/local/mysqlrouter/log

plugin_folder= /usr/local/mysqlrouter/lib/mysqlrouter

runtime_folder= /usr/local/mysqlrouter

[logger]

level=DEBUG

[routing:readtest]

bind_address= 0.0.0.0:7001mode= read-write

destinations= 10.0.21.17:3301#多个地址用逗号分隔, 中间不能有空格

我们这里只设置一个 master, 然后再对比下直连 MySQL 和连接 MySQL Router 的测试结果.

直连 master:

[root@cz-centos7 ~]# /opt/mysql/bin/mysqlslap -h 10.0.21.17 -P 3301 -uroot -a --auto-generate-sql-execute-number=10000 --auto-generate-sql-load-type=read --auto-generate-sql-secondary-indexes=3 --auto-generate-sql-unique-query-number=1 --auto-generate-sql-write-number=1000 -c 10Benchmark

Average number of seconds to run all queries:180.839seconds

Minimum number of seconds to run all queries:180.839seconds

Maximum number of seconds to run all queries:180.839seconds

Number of clients running queries:10Average number of queries per client:10000连接 MySQL Router:

[root@cz-centos7 ~]# /opt/mysql/bin/mysqlslap -h 10.0.21.90 -P 7001 -uroot -a --auto-generate-sql-execute-number=10000 --auto-generate-sql-load-type=read --auto-generate-sql-secondary-indexes=3 --auto-generate-sql-unique-query-number=1 --auto-generate-sql-write-number=1000 -c 10Benchmark

Average number of seconds to run all queries:433.598seconds

Minimum number of seconds to run all queries:433.598seconds

Maximum number of seconds to run all queries:433.598seconds

Number of clients running queries:10Average number of queries per client:10000从时间总是上看, 直连方式中10个线程执行 1w 次请求需要大约 181s 左右, 平均每个线程每秒执行5.5次, 连接 MySQL Router 则每个线程平均每秒执行2.3次, 多了一层转发性能消耗还是比较明显的. 这里只是简单的测试, destinations 中如果提供多个服务作为 read 扩展, 相信性能还是会有所提升的.

总体上看, 应用程序本身支持读写分离的话, 分别指定两个 routing section(read-write 和 read-only) 会是很不错的选择, 当然比起 atlas, cobar 等, 应用程序的结构会稍显复杂, 扩展性不强.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值