利用amoeba(变形虫)实现mysql数据库读写分离[亲测有效]

利用amoeba(变形虫)实现mysql数据库读写分离[亲测有效]关于mysql的读写分离架构有很多,百度的话几乎都是用mysql_proxy实现的。由于proxy是基于lua脚本语言实现的,所以网上不少网友表示proxy效率不高,也不稳定,不建议在生产环境使用;…

利用amoeba(变形虫)实现mysql数据库读写分离

前期准备工作:
1.两个数据库,一主一从,主从同步;
master: 172.22.10.237:3306 ;主库负责写入操作;
slave: 10.4.66.58:3306 ; 从库负责读取操作;
amoeba: 172.22.10.237:8066 ; 我把amoeba安装到了主库所在的服务器,当然,你也可以安装到第三台服务器上;
所有服务器操作系统均为centos7;
2.在amoeba所在的服务器上配置安装jdk;
我安装的是jdk1.8;
路径是: JAVA_HOME=/usr/local/java/jdk1.8.0_131

以上务必自己点搭建、配置好,主从正常工作,添加jdk环境变量: /etc/profile ;

安装amoeba的方式有很多,这里就不在安装上面费口舌了,我下载了amoeba-mysql-3.0.5-RC-distribution的安装包,直接解压即可使用;
解压目录: /usr/local/amoeba/
利用amoeba(变形虫)实现mysql数据库读写分离
很明显 conf里是配置文件,bin里是启动程序;
刚才说到 amoeba的功能可不止读写分离,但如果只用读写分离功能的话只需要配置这几个个文件即可: conf/dbServers.xml conf/amoeba.xml 和 bin/launcher ;
conf/dbServers.xml :

 `<property name="port">3306</property>  
           #设置Amoeba要连接的mysql数据库的端口,默认是3306
    <property name="schema">testdb</property>  
          #设置缺省的数据库,当连接amoeba时,操作表必须显式的指定数据库名,即采用dbname.tablename的方式,不支持 use dbname指定缺省库,因为操作会调度到各个后端dbserver
    <property name="user">test1</property>  
             #设置amoeba连接后端数据库服务器的账号和密码,因此需要在所有后端数据库上创建该用户,并授权amoeba服务器可连接
    <property name="password">111111</property>

    <property name="maxActive">500</property>  #最大连接数,默认500
    <property name="maxIdle">500</property>    #最大空闲连接数
    <property name="minIdle">1</property>    #最新空闲连接数

    <dbServer name="writedb" parent="abstractServer">  #设置一个后端可写的数据库,这里定义为writedb,这个名字可以任意命名,后面还会用到
        <property name="ipAddress">172.22.10.237</property> #设置后端可写dbserver的ip

    <dbServer name="slave01" parent="abstractServer">  #设置后端可读数据库
        <property name="ipAddress">10.4.66.58</property>

     <dbServer name="myslave" virtual="true">  #设置定义一个虚拟的dbserver,实际上相当于一个dbserver组,这里将可读的数据库ip统一放到一个组中,将这个组的名字命名为myslave
            <property name="loadbalance">1</property>  #选择调度算法,1表示复制均衡,2表示权重,3表示HA, 这里选择1
            <property name="poolNames">slave01</property>  #myslave组成员`

代码100分

conf/amoeba.xml :

代码100分<property name="port">8066</property>    
        #设置amoeba监听的端口,默认是8066
        <property name="ipAddress">127.0.0.1</property> 
                #配置监听的接口,如果不设置,默认监听所以的IP
                # 提供客户端连接amoeba时需要使用这里设定的账号 (这里的账号密码和amoeba连接后端数据库服务器的密码无关)
            <property name="user">root</property> 
            <property name="password">123456</property>

        <property name="defaultPool">myslave</property>  
                #设置amoeba默认的池,这里设置为writedb
        <property name="writePool">master</property>  
                #这两个选项默认是注销掉的,需要取消注释,这里用来指定前面定义好的俩个读写池
        <property name="readPool">slave01</property>

bin/launcher :

        #启动脚本,需要配置jdk环境变量;
        #在注释后的第一行添加:
        JAVA_HOME=/usr/local/java/jdk1.8.0_131

launcher 是启动脚本,如果不配置JAVA_HOME的话,即便你在/etc/profile中配置了环境变量也可能会报错:没有配置jdk环境变量;
还有一个配置文件: jvm.properties

代码100分        #占用内存配置文件
        # -Xss参数有最小值要求,必须大于228才能启动JVM
        #修改:
            JVM_OPTIONS="-server -Xms1024m -Xmx1024m -Xss256k -XX:PermSize=16m -XX:MaxPermSize=96m"

有经验的运维都知道,凡是和jdk沾上边的,基本都会和内存的调优有关系,amoeba也不例外;


现在可以启动了:
利用amoeba(变形虫)实现mysql数据库读写分离

启动后就可以看到本机的8066端口:
利用amoeba(变形虫)实现mysql数据库读写分离
这时,你只需要通过本机ip的8066端口和你配置文件中设置的账号密码来连接数据库就行了,写入的数据都会到master里,读取的数据都会从slave中读取;
测试:
关闭master数据库,依然可以读取:执行 select 查看命令;郑州输卵管性不孕医院:http://yyk.39.net/hospital/fc964_doctors.html
或者
关闭slave数据库,依然可以写入: 执行 update、inster命令;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/8336.html

(0)
上一篇 2023-03-03
下一篇 2023-03-03

相关推荐

  • 基于oracle的sql优化如何_oracle数据库物理结构

    基于oracle的sql优化如何_oracle数据库物理结构 Oracle结构; 主要包括两部分:1.Oracle实例 2.数据库文件 Orac le 实例: 1.是访问 Oracle database 的途径 2.只能打开一个数据库 3.由 SGA …

    2023-03-19
    150
  • Python文本编辑器

    Python文本编辑器在编程工作中,文本编辑器是必不可少的工具。Python文本编辑器是一种使用Python语言编写的专门用于编辑文本的软件工具。Python编程语言本身就是一种非常流行的编程语言,由于其简单易学、易读易写、兼容性强等特点,被广泛应用于Web开发、科学计算、人工智能等各个领域中。

    2024-04-24
    67
  • Python的创始人 Guido van Rossum

    Python的创始人 Guido van Rossuma href=”https://beian.miit.gov.cn/”苏ICP备2023018380号-1/a Copyright www.python100.com .Some Rights Reserved.

    2024-05-05
    71
  • 又见删库…[通俗易懂]

    又见删库…[通俗易懂]这两天,香港上市公司微盟(HK2013)因”删库”事件停运,已经过了36小时还在努力抢修数据的工作中。作为一位老DBA,我们一起来回顾和尝试反思下这个事件。 0. 事件回顾 2020.2.23日 1…

    2023-01-31
    133
  • MySQL之数据定义语言(DDL)

    MySQL之数据定义语言(DDL)写在前面 本文中 [ 内容 ] 代表啊可选项,即可写可不写。 SQL语言的基本功能介绍 SQL是一种结构化查询语言,主要有如下几个功能: 数据定义语言(DDL):全称Data Definition L

    2023-04-16
    159
  • MongoDB权限控制(6)[亲测有效]

    MongoDB权限控制(6)[亲测有效]权限概述 在mongodb里面的用户是属于数据库的,每个数据库有自己的管理员,管理员登录后,只能操作所属的数据库。 注意:一般在admin数据库中创建的用户授予超级管理员权限,登录后可以操作任何的数据

    2023-03-27
    165
  • 数据库连接池的原理?连接池使用什么数据结构实现?实现连接池?

    数据库连接池的原理?连接池使用什么数据结构实现?实现连接池?早期我们怎么进行数据库操作呢? 1、原理:一般来说,Java应用程序访问数据库的过程是: 加载数据库驱动程序; 通过jdbc建立数据库连接; 访问数据库,执行SQL语句; 断开数据库连接。 2、代码

    2023-02-11
    146
  • sql数据库无法连接到服务器_sqlserver无法启动服务

    sql数据库无法连接到服务器_sqlserver无法启动服务我们将 身份验证 选择为 SQL Server 身份验证。输入刚刚创建的用户名和密码: 但是现在还是不能直接使用,因为权限问题。你会看到下面的错误提示框: 解决问题的方法

    2023-06-17
    148

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注