• Atlas 读写分离


    1、前置条件

    需要配置好mysql 主从

    主库:192.168.28.137:16205

    从库:192.168.28.135:16205

    Atlas:192.168.28.139

    2、Atlas 部署

    下载Atlas会有两个版本,其中有个分表的版本,但是这个需要其他的依赖,我这边不需要分表这种需求,所以安装普通的版本

         Atlas (普通) : Atlas-2.2.1.el6.x86_64.rpm

         Atlas (分表) : Atlas-sharding_1.0.1-el6.x86_64.rpm

       

    首先进入Linux的Home目录下,下载非分表的安装包

    [root@localhost ~]# cd /home/
    [root@localhost home]# wget https://github.com/Qihoo360/Atlas/releases/download/2.2.1/Atlas-2.2.1.el6.x86_64.rpm

    下载好了之后,进行安装

    [root@localhost home]# rpm -ivh Atlas-2.2.1.el6.x86_64.rpm 
    Preparing...                ########################################### [100%]
       1:Atlas                  ########################################### [100%]

    安装好了,它会默认在”/usr/local/mysql-proxy”下给你生成4个文件夹,以及需要配置的文件,如下:

    [root@localhost home]# ll /usr/local/mysql-proxy/
    total 16
    drwxr-xr-x. 2 root root 4096 Dec 28 10:47 bin
    drwxr-xr-x. 2 root root 4096 Dec 28 10:47 conf
    drwxr-xr-x. 3 root root 4096 Dec 28 10:47 lib
    drwxr-xr-x. 2 root root 4096 Dec 17  2014 log

    bin目录下放的都是可执行文件

    1. “encrypt”是用来生成MySQL密码加密的,在配置的时候会用到

    2. “mysql-proxy”是MySQL自己的读写分离代理

    3. “mysql-proxyd”是360弄出来的,后面有个“d”,服务的启动、重启、停止。都是用他来执行的

    conf目录下放的是配置文件

    1. “test.cnf”只有一个文件,用来配置代理的,可以使用vim来编辑

    lib目录下放的是一些包,以及Atlas的依赖

    log目录下放的是日志,如报错等错误信息的记录

    进入bin目录,使用encrypt来对数据库的密码进行加密,我的MySQL数据的用户名是root,密码是a123456,我需要对密码进行加密

    [root@localhost bin]# ./encrypt a123456
    lxLJE/Pl4kI=

    配置Atlas,使用vim进行编辑

    [root@localhost conf]# cd /usr/local/mysql-proxy/conf/
    [root@localhost conf]# vim test.cnf

    进入后,可以在Atlas进行配置,360写的中文注释都很详细,根据注释来配置信息,其中比较重要,需要说明的配置如下:

    这是用来登录到Atlas的管理员的账号与密码,与之对应的是“#Atlas监听的管理接口IP和端口”,也就是说需要设置管理员登录的端口,才能进入管理员界面,默认端口是2345,也可以指定IP登录,指定IP后,其他的IP无法访问管理员的命令界面。方便测试,我这里没有指定IP和端口登录。

    #管理接口的用户名
    admin-username = user
    
    #管理接口的密码
    admin-password = pwd

    这是用来配置主数据的地址与从数据库的地址,这里配置的主数据库是137,从数据库是135

    #Atlas后端连接的MySQL主库的IP和端口,可设置多项,用逗号分隔
    proxy-backend-addresses = 192.168.28.137:16205
    
    #Atlas后端连接的MySQL从库的IP和端口,@后面的数字代表权重,用来作负载均衡,若省略则默认为1,可设置多项,用逗号分隔
    proxy-read-only-backend-addresses = 192.168.28.135:16205@1

    这个是用来配置MySQL的账户与密码的,我的MySQL的用户是buck,密码是hello,刚刚使用Atlas提供的工具生成了对应的加密密码

    #用户名与其对应的加密过的MySQL密码,密码使用PREFIX/bin目录下的加密程序encrypt加密,下行的user1和user2为示例,将其替换为你的MySQL的用户名和加密密码!
    pwds = root:lxLJE/Pl4kI=

    这是设置工作接口与管理接口的,如果ip设置的”0.0.0.0”就是说任意IP都可以访问这个接口,当然也可以指定IP和端口,方便测试我这边没有指定,工作接口的用户名密码与MySQL的账户对应的,管理员的用户密码与上面配置的管理员的用户密码对应。

    #Atlas监听的工作接口IP和端口
    proxy-address = 0.0.0.0:1234
    
    #Atlas监听的管理接口IP和端口
    admin-address = 0.0.0.0:2345

     

      进入/usr/local/mysql-proxy/bin目录,启动Atlas

      ./mysql-proxyd test start

      

       查看日志信息

     这样就启动成功了,通过软件去连就好啦,这边设置是谁都可以连接。

    本机IP:1234端口号

    192.168.28.139:1234

    通过工具直接链接即可

    lxLJE/Pl4kI=
  • 相关阅读:
    16种动画效果
    ios GCD 详解1
    [LeetCode] 3 Sum, Solution
    [LeetCode] Combinations, Solution
    [LeetCode] Binary Tree Inorder Traversal Solution
    [LeetCode] 3Sum Closest, Solution
    [LeetCode] Combination Sum, Solution
    [LeetCode] Binary Tree Maximum Path Sum Solution
    [LeetCode] Add Two Numbers, Solution
    [LeetCode] Climbing Stairs, Solution
  • 原文地址:https://www.cnblogs.com/Nanaya/p/11942444.html
Copyright © 2020-2023  润新知