开发者社区> 技术小胖子> 正文

采用Atlas实现MySQL读写分离

简介:
+关注继续查看

##采用Atlas实现MySQL读写分离


一、基础介绍

==========================================================================================

1、背景描述

目前我们的高可用DB的代理层采用的是360开源的Atlas,从上线以来,已稳定运行2个多月。无论是从性能上,还是稳定性上,

相比其他开源组件(amoeba、cobar、MaxScale、MySQL-Proxy等),还是很出色的。


当初我们之所以选择Atlas,主要看中它有以下优点:

(1)、基于mysql-proxy-0.8.2进行修改,代码完全开源;

(2)、比较轻量级,部署配置也比较简单;

(3)、支持DB读写分离;

(4)、支持从DB读负载均衡,并自动剔除故障从DB;

(5)、支持平滑上下线DB;

(6)、具备较好的安全机制(IP过滤、账号认证);

(7)、版本更新、问题跟进、交流圈子都比较活跃。


在测试期间以及线上问题排查过程中,得到了360 Atlas作者朱超的热心解答,在此表示感谢。有关更多Atlas的介绍,我就不一一例举,可以参考以下链接:

https://github.com/Qihoo360/Atlas/blob/master/README_ZH.md


3、系统环境

CentOS 7.2 x86_64

网络环境:master  192.168.10.25

          slave   192.168.10.26

  mysql-atlas-proxy  192.168.10.28


##安装mysql-server主服务端(192.168.10.25)

service  firewalld  stop

chkconfig  firewalld  off

setenforce  0

getenforce

sed  -i  's/^SELINUX=enforcing/SELINUX=permissive/'  /etc/selinux/config

yum  install  -y  mariadb  mariadb-server

service  mariadb  restart

chkconfig  mariadb  on

sed -i '1aserver_id=25'  /etc/my.cnf

sed -i '2alog-bin=mysql-bin'  /etc/my.cnf

service  mariadb  restart

mysql -uroot  -e "grant  all on *.*  to  admin@'%'  identified  by '01';flush privileges;"

mysql -uroot  -e "grant  replication slave on *.*  to  rep@'%'  identified  by '01';flush privileges;"

mysql -uroot  -e "select user,host,password from  mysql.user;"

mysql  -uroot  -e  "reset master;show  master  status;"


##安装mysql-server主服务端(192.168.10.26)

service  firewalld  stop

chkconfig  firewalld  off

setenforce  0

getenforce

sed  -i  's/^SELINUX=enforcing/SELINUX=permissive/'  /etc/selinux/config

yum  install  -y  mariadb  mariadb-server

service  mariadb  restart

chkconfig  mariadb  on

sed -i '1aserver_id=26'  /etc/my.cnf

sed -i '2alog-bin=mysql-bin'  /etc/my.cnf

service  mariadb  restart

mysql -uroot  -e "grant  all on *.*  to  admin@'%'  identified  by '01';flush privileges;"

mysql -uroot  -e "grant  replication slave on *.*  to  rep@'%'  identified  by '01';flush privileges;"

mysql -uroot  -e "select user,host,password from  mysql.user;"

mysql  -uroot  -e  "change master to master_host='192.168.100.11',master_user='rep',master_password='01',master_port=3306,master_log_file='mysql-bin.000001',master_log_pos=245;"

sleep  30s

mysql  -uroot  -e  "start slave;show  slave  status\G"



##安装配置atlas读写分离(192.168.10.28)

service  iptables  stop

chkconfig  iptables  off

setenforce  0

getenforce

sed  -i  's/^SELINUX=enforcing/SELINUX=permissive/'  /etc/selinux/config

grep  '^SELINUX='  /etc/selinux/config


安装和配置atlas软件

rpm  -ivh  Atlas-2.2.1.el6.x86_64.rpm

echo "PATH=$PATH:/usr/local/mysql-proxy/bin/"  >> /etc/profile

source  /etc/profile

ll /usr/local/mysql-proxy/


##mysql-proxy文件功能说明:

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

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

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

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


conf目录下放的是配置文件

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

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

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

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


cd /usr/local/mysql-proxy/bin/

./encrypt 01   生成加密密码,并复制此密码

cd /usr/local/mysql-proxy/conf/

cp -v  test.cnf  test.cnf.bak    //备份test.cnf配置文件

vi  test.conf   修改后的读写分享的完整配置文件内容

[mysql-proxy]

admin-username = user

admin-password = pwd

proxy-backend-addresses = 192.168.100.11:3306

pwds = admin:VFnEp9P4Vu4=, rep:VFnEp9P4Vu4=

daemon = true

keepalive = true

event-threads = 8

log-level = message

log-path = /usr/local/mysql-proxy/log

proxy-address = 0.0.0.0:3306

admin-address = 0.0.0.0:2345


test.cnf读写分离配置文件功能说明:

1:[mysql-proxy]   //读写分离代理配置

6:admin-username = user    //管理接口的用户名

9:admin-password = pwd     //管理接口的密码

12:proxy-backend-addresses = 192.168.100.11:3306    //主数据库的IP地址和端口号(可读可写)

18:pwds = admin:VFnEp9P4Vu4=, rep:VFnEp9P4Vu4=      //后端MYSQL的用户名和encrypt命令生成的加密密码

21:daemon = true      //设置为守护进程模式(后台运行)

24:keepalive = true   //允许keepalive

27:event-threads = 8   //工作线程数为8

30:log-level = message   //日志等级为message消息

33:log-path = /usr/local/mysql-proxy/log    //日志文件路径

45:proxy-address = 0.0.0.0:3306      //Atlas监听的管理接口IP和端口

48:admin-address = 0.0.0.0:2345      //Atlas监听的管理接口IP和端口


重启atlas服务:/usr/local/mysql-proxy/bin/mysql-proxyd  test  start

查状态:./etc/init.d/mysqld  status


设置mysql-proxyd开机启动:

echo "/usr/local/mysql-proxy/bin/mysql-proxyd  test  start" >> /etc/profile

source  /etc/profile


登录测试:mysql  -uadmin  -p01  -h 192.168.10.28 -P3306


登录到atlas管理端:mysql  -uuser  -ppwd  -h 192.168.10.28 -P2345







      本文转自rshare 51CTO博客,原文链接:http://blog.51cto.com/1364952/1952214,如需转载请自行联系原作者




版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
23940 0
腾讯云服务器 设置ngxin + fastdfs +tomcat 开机自启动
在tomcat中新建一个可以启动的 .sh 脚本文件 /usr/local/tomcat7/bin/ export JAVA_HOME=/usr/local/java/jdk7 export PATH=$JAVA_HOME/bin/:$PATH export CLASSPATH=.
12915 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,云吞铺子总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系统盘、创建快照、配置安全组等操作如何登录ECS云服务器控制台? 1、先登录到阿里云ECS服务器控制台 2、点击顶部的“控制台” 3、通过左侧栏,切换到“云服务器ECS”即可,如下图所示 通过ECS控制台的远程连接来登录到云服务器 阿里云ECS云服务器自带远程连接功能,使用该功能可以登录到云服务器,简单且方便,如下图:点击“远程连接”,第一次连接会自动生成6位数字密码,输入密码即可登录到云服务器上。
32578 0
使用OpenApi弹性释放和设置云服务器ECS释放
云服务器ECS的一个重要特性就是按需创建资源。您可以在业务高峰期按需弹性的自定义规则进行资源创建,在完成业务计算的时候释放资源。本篇将提供几个Tips帮助您更加容易和自动化的完成云服务器的释放和弹性设置。
18557 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,大概有三种登录方式:
8349 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
14095 0
使用SSH远程登录阿里云ECS服务器
远程连接服务器以及配置环境
11611 0
阿里云服务器ECS登录用户名是什么?系统不同默认账号也不同
阿里云服务器Windows系统默认用户名administrator,Linux镜像服务器用户名root
12903 0
21117
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载