목차
(转)Amoeba for MySQL 非常好用的mysql集群软件
데이터 베이스 MySQL 튜토리얼 (转)Amoeba for MySQL 非常好用的mysql集群软件_MySQL

(转)Amoeba for MySQL 非常好用的mysql集群软件_MySQL

Jun 01, 2016 pm 01:18 PM
mysql 애플리케이션 레이어 데이터 베이스 소프트웨어

Mysql集群

bitsCN.com

(转)Amoeba for MySQL 非常好用的mysql集群软件

http://yanwt.iteye.com/blog/1460780

Amoeba for MySQL 


Amoeba for MySQL致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQL的时候充当query 路由功能,专注 分布式数据库 proxy 开发。座落与Client、DB Server(s)之间。对客户端透明。具有负载均衡、高可用性、Query过滤、读写分离、可路由相关的query到目标数据库、可并发请求多台数据库合并结果。 在Amoeba上面你能够完成多数据源的高可用、负载均衡、数据切片的功能。目前在很多企业的生产线上面使用。 




Amoeba使用指南 

说明文档见:http://docs.hexnova.com/amoeba/ 




安装小结: 




目前可以有三种解决方式实现mysql读写分离 

1 程序修改mysql操作类 

优点:直接和数据库通信,简单快捷的读写分离和随机的方式实现的负载均衡,权限独立分配 

缺点:自己维护更新,增减服务器在代码处理 




2 amoeba 

参考官网:http://amoeba.meidusa.com/ 

优点:直接实现读写分离和负载均衡,不用修改代码,有很灵活的数据解决方案 

缺点:自己分配账户,和后端数据库权限管理独立,权限处理不够灵活 




3 mysql-proxy 

参考 mysql-proxy。 

优点:直接实现读写分离和负载均衡,不用修改代码,master和slave用一样的帐号 

缺点:字符集问题,lua语言编程,还只是alpha版本,时间消耗有点高 




如果你不能安装软件来解决读写分离,那可以尝试阿权的项目解决思路。 

如果你可以安装软件,那amoeba是不错的,mysql-proxy不太建议,目前只有alpha版本,效率还不太理想,amoeba目前在阿里巴巴是内部项目,正在生产环境使用的。 




amoeba的安装使用 

1 安装java环境,需要Java SE 1.5 或以上 

2 配置xml文件 

下载地址: http://www.sf.net/projects/amoeba 

解压就可以使用的,顺便说一下,打包的习惯似乎不是太好,最好解压后是自己的文件夹,如用tar -zxpf amoeba-mysql-binary-2.1.0-RC5.tar.gz -C /usr/local/amoeba-mysql 




运行很简单 bin/amoeba 即可,后台运行 bin/amoeba & 

如果没有配置JAVA_HOME,则会有如下提示: 

[root@aslibra amoeba-mysql]# bin/amoeba 

Error: JAVA_HOME environment variable is not set. 

如果你是比1.5低,比如1.4的,运行会有错误提示: 




[root@aslibra amoeba-mysql]# bin/amoeba 

Exception in thread "main" java.lang.UnsupportedClassVersionError: com/meidusa/amoeba/mysql/server/MysqlProxyServer (Unsupported major.minor version 49.0) 

        at java.lang.ClassLoader.defineClass0(Native Method) 

        at java.lang.ClassLoader.defineClass(ClassLoader.java:539) 

        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:123) 

..... 




下载jdk1.5以上的版本,压缩版解压后设置好环境变量即可 




可以编辑 /etc/profile以便启动时变量生效,末尾加上 




##############  java  ########### 




JAVA_HOME=/usr/java/jdk 

PATH=$PATH:JAVA_HOME/bin 

export JAVA_HOME PATH 




用bin/amoeba start即可启动amoeba 

如bin/amoeba start > /dev/null & 




配置amoeba: 




conf/amoeba.xml 配置mysql数据库,简单说明一下: 




1 server节点定义amoeba为接受client访问的数据库,可以当作是mysql看待的,用户名和密码是访问时使用的,这个似乎不能定义多个用户名密码,也就是只有一个权限控制,这个对于多应用似乎不大方便。 

2 dbServerList里面可以定义很多实际的mysql数据库,增加dbServer节点即可,这里的用户名密码是作为amoeba操作数据库使用的,要有足够权限。dbServer可以是虚拟的,比如要做负载均衡时可用定义多个数据库归属到此虚拟数据库。2.1RC版的dbServer已移到dbServers.xml文件中配置。 

3 queryRouter节点定义读写的分配情况,也就是读写该发往那个dbServer。 




vi amoeba.xml 修改主配置文件 

4.1)把默认端口8066改成3306 

3066 

4.2)把默认连接用户名和密码改成自己的 

sky 

123456 

4.3)把默认的客户端线程数,请求数及服务端回应数改成200,300,300 

200 




                        

                       300 

                        

                       300 

4.4)把默认注释掉的读写分离选项,把注释去掉并readpool修改成server2 

 

                       server1 

                       server2 

提示:readPool或writePool可以是dbServers中的multiPool名称,用multiPool来设置负载均衡。 




(本文出自php_sir的新浪博客,用户名php_sir,首页链接:http://blog.sina.com.cn/phpsir,未经本人(php_sir)同意禁止转载) 




5. vi dbServers.xml 增加SEVER2模块,里面的连接用户名密码及地址都表示两台MYSQL的物理机器,192.168.1.11和192.168.1.13 另SERVER1是写,SERVER是读 




 

 




 

     

   




     




      ${defaultManager} 




      64 




      128 




       




      3306 




       




      test 




       




      root 




       




      123456 




   
 




     




      500 




      500 




      10 




      600000 




      600000 




      true 




      true 




   
 




 
 




   




     




       




      192.168.2.11 




   
 




 
 

   




     




       




      192.168.2.13 




   
 




 
 




 




     




       




      1 




       




      server1 




   
 




 
 




 




6:修改log4j.xml 取消日志文件生成,如做pdf时(太大了,磁盘很容易满) 

 

改成 

 

注意:我在2.1-rc5版本下第6条的设置JAVA运行时报警,无法通过。 





7:性能优化,打开bin/amoeba 




DEFAULT_OPTS="-server -Xms256m -Xmx256m -Xss128k" 

改成 

DEFAULT_OPTS="-server -Xms2048m -Xmx2048m -Xmn1000m -Xss2048k" 




8:启动amoeba 

nohup /usr/local/amoeba/bin/amoeba start 2>&1 >/dev/null &

bitsCN.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP에서 MySQL 쿼리 성능을 최적화하는 방법은 무엇입니까? PHP에서 MySQL 쿼리 성능을 최적화하는 방법은 무엇입니까? Jun 03, 2024 pm 08:11 PM

PHP에서 MySQL 쿼리 성능을 최적화하는 방법은 무엇입니까?

PHP에서 MySQL 백업 및 복원을 사용하는 방법은 무엇입니까? PHP에서 MySQL 백업 및 복원을 사용하는 방법은 무엇입니까? Jun 03, 2024 pm 12:19 PM

PHP에서 MySQL 백업 및 복원을 사용하는 방법은 무엇입니까?

PHP를 사용하여 MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까? PHP를 사용하여 MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까? Jun 02, 2024 pm 02:26 PM

PHP를 사용하여 MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까?

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 Dec 09, 2024 am 11:42 AM

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법

PHP에서 MySQL 저장 프로시저를 사용하는 방법은 무엇입니까? PHP에서 MySQL 저장 프로시저를 사용하는 방법은 무엇입니까? Jun 02, 2024 pm 02:13 PM

PHP에서 MySQL 저장 프로시저를 사용하는 방법은 무엇입니까?

모든 소프트웨어는 WPS로 열리며 exe 기본 열기 방법이 복원됩니다. 모든 소프트웨어는 WPS로 열리며 exe 기본 열기 방법이 복원됩니다. Jun 19, 2024 am 01:48 AM

모든 소프트웨어는 WPS로 열리며 exe 기본 열기 방법이 복원됩니다.

PHP를 사용하여 MySQL 테이블을 만드는 방법은 무엇입니까? PHP를 사용하여 MySQL 테이블을 만드는 방법은 무엇입니까? Jun 04, 2024 pm 01:57 PM

PHP를 사용하여 MySQL 테이블을 만드는 방법은 무엇입니까?

PHP에서 MySQLi를 사용하여 데이터베이스 연결을 설정하는 방법에 대한 자세한 튜토리얼 PHP에서 MySQLi를 사용하여 데이터베이스 연결을 설정하는 방법에 대한 자세한 튜토리얼 Jun 04, 2024 pm 01:42 PM

PHP에서 MySQLi를 사용하여 데이터베이스 연결을 설정하는 방법에 대한 자세한 튜토리얼

See all articles