使用Amoeba 实现MySQL DB 读写分离
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了使用Amoeba 实现MySQL DB 读写分离,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含6092字,纯文字阅读大概需要9分钟。
内容图文
mkdir /usr/local/amoeba tar xf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba # 使用二进制程序文件安装amoeba cd /usr/local/amoeba bin/amoeba start # 前台运行 nohup /usr/local/amoeba/bin/amoeba start & # 后台运行 mysql -h127.0.0.1 -uroot -p -P8066 # amoeba默认监听端口为8066
3.3 配置ameoba
cd /usr/local/amoeba/conf vi ameoba.xml # 前端定义配置文件 # 修改ameoba前端监听端口 <service name="Amoeba for Mysql" class="com.meidusa.amoeba.net.ServerableConnectionManager"> <property name="port">3306</property> # 默认端口是8066,修改为3306,便于实现前端程序连接数据库的透明性 # 修改连接amoeba接口的认证信息 <property name="authenticator"> <bean class="com.meidusa.amoeba.mysql.server.MysqlClientAuthenticator"> <property name="user">root</property> <property name="password">mypass</property> # 添加登录密码 # 查询路由设置 <queryRouter class="com.meidusa.amoeba.mysql.parser.MysqlQueryRouter"> <property name="ruleLoader"> <bean class="com.meidusa.amoeba.route.TableRuleFileLoader"> <property name="ruleFile">${amoeba.home}/conf/rule.xml</property> <property name="functionFile">${amoeba.home}/conf/ruleFunctionMap.xml</property> </bean> </property> <property name="sqlFunctionFile">${amoeba.home}/conf/functionMap.xml</property> <property name="LRUMapSize">1500</property> <property name="defaultPool">master</property> # 设定默认节点 <property name="writePool">master</property> # 设定可写节点,节点定义见dbServers.xml文件 <property name="readPool">readservers</property> # 设定只读池,可配置多个slave节点 <property name="needParse">true</property> </queryRouter> vi dbServers.xml # 后端节点配置文件 # 定义抽象服务器,为每个后端MySQL服务器提供默认连接配置 <dbServer name="abstractServer" abstractive="true"> <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory"> <property name="manager">${defaultManager}</property> <property name="sendBufferSize">64</property> <property name="receiveBufferSize">128</property> <property name="port">3406</property> <property name="schema">test</property> <property name="user">root</property> <property name="password">magedu</property> </factoryConfig> # 定义后端MySQL的IP地址,一个master,一个slave <dbServer name="master" parent="abstractServer"> <factoryConfig> <property name="ipAddress">192.168.0.45</property> </factoryConfig> </dbServer> <dbServer name="slave" parent="abstractServer"> <factoryConfig> <property name="ipAddress">192.168.0.46</property> </factoryConfig> </dbServer> # 定义虚拟服务器组,即只读池readservers <dbServer name="readservers" virtual="true"> <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool"> <property name="loadbalance">1</property> <property name="poolNames">master,slave</property> </poolConfig> </dbServer>
3.4 使用验证
在主库上授权:
MariaDB [(none)]> grant all on *.* to‘root‘@‘172.16.%.%‘ identified by ‘magedu‘; Query OK, 0 rows affected (0.00 sec) MariaDB [(none)]> grant all on *.* to‘root‘@‘%mysql.com‘ identified by ‘magedu‘; # 这里的密码应该与dbServer.xml中的数据库密码一致 Query OK, 0 rows affected (0.00 sec) MariaDB [(none)]> flush privileges; Query OK, 0 rows affected (0.00 sec)
# 登录验证 [root@mysql conf]# mysql -h127.0.0.1 -uroot -p -P3306 Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MySQL connection id is 2097086015 Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distribution Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others. Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement. MySQL [(none)]> show master status; +------------------+----------+--------------+------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | +------------------+----------+--------------+------------------+ | mysql-bin.000030 | 326 | | | +------------------+----------+--------------+------------------+ 1 row in set (0.00 sec) MySQL [(none)]> # 读写验证 [root@mysql conf]# mysql -h127.0.0.1 -uroot -p -P3306 Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MySQL connection id is 2097086015 Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distribution Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others. Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement. MySQL [(none)]> create database amoeba_test; Query OK, 1 row affected (0.04 sec) MySQL [(none)]> [root@mysql bin]# mysql -h127.0.0.1 -uroot -p -P3406 Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 33 Server version: 10.0.10-MariaDB-log Source distribution Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others. Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement. MariaDB [(none)]> show databases; +--------------------+ | Database | +--------------------+ | amoeba_test | | information_schema | | mysql | | performance_schema | | test | +--------------------+ 9 rows in set (0.01 sec) MariaDB [(none)]> # 从amoeba接口登录创建数据库amoeba_test后,再从主库的接口中去查询数据库已创建,说明写入确实是落在了主库节点上; # 若要验证ameoba对于读操作的调度,则需要暂时停止从库的复制操作,然后在主库上更新数据,这样从ameoba读取数据将出现不一致的情况;
3.5 后期扩展
利用MMM双主复制架构+Amoeba代理,可以实现对MySQL的高可用性和高性能;
关于MMM的内容参加博文"MySQL Scale Out"
4 问题记录
现象:使用mysql -uroot -p -P8066命令始终无法连接进入ameoba的配置接口,一直都是进入mysql数据库的配置接口
原因:在测试环境下,ameoba和mysql的主库都部署在同一台主机上,当启动ameoba服务后,即使指定-P8066连接,mysql客户端还是默认采用可被识别的socket文件(/tmp/mysql.sock)连接,同样指定-hlocalhost也是一样的;
当使用mysql命令连接mysqld时:
-
连接主机为localhost或不指定时,mysql会采用Unix Socket的连接方式;
-
连接主机为127.0.0.1时,mysql会采用TCP的方式连接;
解决方法:指定-h127.0.0.1连接即可,即mysql -h127.0.0.1 -uroot -p -P8066
http://www.cnblogs.com/xiaocen/p/3736095.html
使用Amoeba 实现MySQL DB 读写分离
标签:
本文系统来源:http://www.cnblogs.com/kms1989/p/5484529.html
内容总结
以上是互联网集市为您收集整理的使用Amoeba 实现MySQL DB 读写分离全部内容,希望文章能够帮你解决使用Amoeba 实现MySQL DB 读写分离所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。