Atlas 读写分离
Posted applogize
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Atlas 读写分离相关的知识,希望对你有一定的参考价值。
1.Atals介绍
1.简介
Atlas是由 Qihoo 360公司Web平台部基础架构团队开发维护的一个基于mysql协议的数据中间层项目。它在MySQL官方推出的MySQL-Proxy 0.8.2版本的基础上,修改了大量bug,添加了很多功能特性。它在MySQL官方推出的MySQL-Proxy 0.8.2版本的基础上,修改了大量bug,添加了很多功能特性。
2.主要功能
1.读写分离
2.从库负载均衡
3.IP过滤
4.自动分表
5.DBA可平滑上下线DB
6.自动摘除宕机的DB
3.Atlas相对于官方MySQL-Proxy的优势
1.将主流程中所有Lua代码用C重写,Lua仅用于管理接口
2.重写网络模型、线程模型
3.实现了真正意义上的连接池
4.优化了锁机制,性能提高数十倍
2.安装Atlas
1.上传或下载包
[root@db03 ~]# rz Atlas-2.2.1.el6.x86_64.tmp
2.安装
[root@db03 ~]# yum localinstall -y Atlas-2.2.1.el6.x86_64.rpm
3.确认文件
[root@db03 ~]# ll /usr/local/mysql-proxy/
total 0
drwxr-xr-x 2 root root 75 Jul 29 10:15 bin
drwxr-xr-x 2 root root 22 Jul 29 10:15 conf
drwxr-xr-x 3 root root 331 Jul 29 10:15 lib
drwxr-xr-x 2 root root 6 Dec 17 2014 log
4.配置
[root@db03 ~]# cat /usr/local/mysql-proxy/conf/test.cnf
[mysql-proxy]
# 管理接口的用户名
admin-username = user
# 管理接口的密码
admin-password = pwd
# Atlas后端连接的MySQL主库的IP和端口,可设置多项,用逗号分隔
proxy-backend-addresses = 172.16.1.50:3306
# Atlas后端连接的MySQL从库的IP和端口,@后面的数字代表权重,用来作负载均衡,若省略则默认为1,可设置多项,用逗号分隔
proxy-read-only-backend-addresses = 172.16.1.51:3306,172.16.1.53:3306
# 用户名与其对应的加密过的MySQL密码,密码使用PREFIX/bin目录下的加密程序encrypt加密,下行的user1和user2为示例,将其替换为你的MySQL的用户名和加密密码!
pwds = rep:3yb5jEku5h4=,mha:O2jBXONX098=
# 设置Atlas的运行方式,设为true时为守护进程方式,设为false时为前台方式,一般开发调试时设为false,线上运行时设为true,true后面不能有空格。
daemon = true
# 设置Atlas的运行方式,设为true时Atlas会启动两个进程,一个为monitor,一个为worker,monitor在worker意外退出后会自动将其重启,设为false时只有worker,没有monitor,一般开发调试时设为false,线上运行时设为true,true后面不能有空格。
keepalive = true
# 工作线程数,对Atlas的性能有很大影响,可根据情况适当设置
event-threads = 8
# 日志级别,分为message、warning、critical、error、debug五个级别
log-level = error
# 日志存放的路径
log-path = /usr/local/mysql-proxy/log
# SQL日志的开关,可设置为OFF、ON、REALTIME,OFF代表不记录SQL日志,ON代表记录SQL日志,REALTIME代表记录SQL日志且实时写入磁盘,默认为OFF
sql-log = OFF
# 慢日志输出设置。当设置了该参数时,则日志只输出执行时间超过sql-log-slow(单位:ms)的日志记录。不设置该参数则输出全部日志。
#sql-log-slow = 10
# 实例名称,用于同一台机器上多个Atlas实例间的区分
instance = test
# Atlas监听的工作接口IP和端口
proxy-address = 0.0.0.0:1234
# Atlas监听的管理接口IP和端口
admin-address = 0.0.0.0:2345
# 分表设置,此例中person为库名,mt为表名,id为分表字段,3为子表数量,可设置多项,以逗号分隔,若不分表则不需要设置该项
#tables = person.mt.id.3
# 默认字符集,设置该项后客户端不再需要执行SET NAMES语句
#charset = utf8
# 允许连接Atlas的客户端的IP,可以是精确IP,也可以是IP段,以逗号分隔,若不设置该项则允许所有IP连接,否则只允许列表中的IP连接
client-ips = 127.0.0.1
5.启动
[root@db03 ~]# /usr/local/mysql-proxy/bin/mysql-proxyd test start
OK: MySQL-Proxy of test is started
# 检验启动
[root@db03 conf]# netstat -lntp
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:2345(服务端) 0.0.0.0:* LISTEN 31101/mysql-proxy
tcp 0 0 0.0.0.0:1234(客户端) 0.0.0.0:* LISTEN 31101/mysql-proxy
3.Atlas使用
1.连接数据库
[root@db03 ~]# mysql -uuser -ppwd -P 2345 -h127.0.0.1
2.执行命令
mysql> show databases;
ERROR 1105 (07000): use ‘SELECT * FROM help‘ to see the supported commands
mysql> SELECT * FROM help;
+----------------------------+---------------------------------------------------------+
| command | description |
+----------------------------+---------------------------------------------------------+
| SELECT * FROM help | 查看帮助 |
| SELECT * FROM backends | 查看后端数据库主机列表 |
| SET OFFLINE $backend_id | DBA可平滑下线DB |
| SET ONLINE $backend_id | DBA可平滑上线DB |
| ADD MASTER $backend | 添加主库 |
| ADD SLAVE $backend | 添加从库 |
| REMOVE BACKEND $backend_id | 移除后端数据库 |
| SELECT * FROM clients | 客户端列表 |
| ADD CLIENT $client | 临时添加客户端 |
| REMOVE CLIENT $client | 临时移除客户端 |
| SELECT * FROM pwds | 客户端用户名和密码 |
| ADD PWD $pwd | 添加客户端用户名和密码 |
| ADD ENPWD $pwd | 添加客户端用户名和加密后的密码 |
| REMOVE PWD $pwd | 移除客户端用户 |
| SAVE CONFIG | 保存配置到配置文件 |
| SELECT VERSION | 查看Atlas版本 |
+----------------------------+---------------------------------------------------------+
16 rows in set (0.00 sec)
以上是关于Atlas 读写分离的主要内容,如果未能解决你的问题,请参考以下文章