微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Atlas MySQL MySQL 中间层

程序名称:Atlas MySQL

授权协议: GPLv2

操作系统: Linux

开发语言: C/C++

Atlas MySQL 介绍

Atlas是由 Qihoo 360, Web平台部基础架构团队开发维护的一个基于MysqL协议的数据中间层项目。它在MysqL官方推出的MysqL-
Proxy
0.8.2版本的基础上,修改了大量bug,添加了很多功能特性。目前该项目在360公司内部得到了广泛应用,很多MysqL业务已经接入了Atlas平台,每天承载的读写请求数达几十亿条。

主要功能
读写分离
从库负载均衡
IP过滤
sql语句黑白名单
* 自动分表

Q & A
-------------------
Q: 是否支持多字符集?
A: 这是我们对原版MysqL-Proxy的第一项改进,符合国情是必须的

Q: 自动读写分离挺好,但有时候我写完马上就想读,万一主从同步延迟怎么办?
A: sql语句前增加 /master/ 就可以将读请求强制发往主库

Q: 主库宕机,读操作受影响么?
A: 在atlas中是不会的! 能问这样的问题, 说明你用过官方的MysqL-proxy, 很遗憾官方版本并未解决这个问题

Q: 检测后端DB状态会阻塞正常请求么?
A: 不会, atlas中检测线程是异步进行检测的,即使有db宕机,也不会阻塞主流程。在atlas中没有什么异常会让主流程阻塞! 同上,官方版本也会让你失望

Q: 想下线一台DB, 又不想停掉MysqL server, 怎么办?
A: 可以通过管理接口手动上下线后端db, atlas会优先考虑管理员的意愿

Q: 想给集群中增加一台DB, 不想影响线上正常访问可以吗?
A: 通过管理接口可以轻松实现

Q: 相比官方MysqL-proxy, atlas还有哪些改进?
A: 这实在是个难以回答的问题,性能,稳定性,可靠性,易维护性,我们做过几十项的改进,下面会尽量列一些较大的改动

VS 官方MysqL-Proxy
-------------------
1. 将主流程中所有Lua代码改为纯C实现,Lua仅用在管理接口
2. 重写网络模型、线程模型
3. 实现了真正意义的连接池
4. 优化了锁机制,性能提高数十倍
......

附名字来源:
Atlas,希腊神话中双肩撑天的巨人,普罗米修斯的兄弟,最高大强壮的神之一,因反抗宙斯失败而被罚顶天。我们期望这个系统能够脚踏后端DB,为前端应用撑起一片天。

二、配置文件示例
-------------------
[MysqL-proxy] #不需要改
plugins = admin, proxy #Atlas加载的模块名称,不需要改

admin-username = user #管理接口的用户名
admin-password = pwd #管理接口的密码
admin-lua-script = /usr/local/MysqL-proxy/lib/MysqL-proxy/lua/admin.lua

实现管理接口的Lua脚本所在路径

proxy-backend-addresses = 127.0.0.1:3306 #Atlas后端连接的MysqL主库的IP和端口,可设置多项,用逗号分隔
proxy-read-only-backend-addresses = 127.0.0.1:3305@2

Atlas后端连接的MysqL从库的IP和端口,2代表权重,用来作负载均衡,若省略则认为1,可设置多项,用逗号分隔

daemon = false

设置Atlas的运行方式,设为true时为守护进程方式,设为false时为前台方式,一般开发调试时设为false,线上运行时设为true

keepalive = false

设置Atlas的运行方式,设为true时Atlas会启动两个进程,一个为monitor,一个为worker,monitor在worker意外退出后会自动将其重启,设为false时只有worker,没有monitor,一般开发调试时设为false,线上运行时设为true

event-threads = 4 #工作线程数,推荐设置与系统的cpu核数相等
log-level = message #日志级别,分为message、warning、critical、error、debug五个级别
log-path = /usr/local/MysqL-proxy/log #日志存放的路径
instance = test #实例名称,用于同一台机器上多个Atlas实例间的区分

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

min-idle-connections = 128 #连接池的最小空闲连接数,可根据业务请求量大小适当调大或调小
tables = person.mt.id.3 #分表设置,此例中person为库名,mt为表名,id为分表字段,3为子表数量,可设置多项,以逗号分隔
pwds = user1:+jKsgB3YAG8=, user2:GS+tr4TPgqc=

用户名与其对应的加密过的密码密码使用加密程序encrypt加密,此设置项用于多个用户名同时访问同一个Atlas实例的情况,若只有一个用户名则不需要设置该项

charset = utf8 #认字符集,若不设置该项,则认字符集为latin1

三、编译安装
-------------------
依赖:glib(2.32.0以上)、libevent(1.4以上)、Lua(5.1以上)、OpenSSL(0.9.8以上)

./bootstrap.sh #可能需要修改其中的路径
make
sudo make install

四、启动与停止
-------------------
进入PREFIX/conf目录,编辑instance.conf,此处instance的实际名称应与其中instance设置项相同,其他设置项含义见第二节。

启动:
PREFIX/bin/MysqL-proxyd instance start

停止:
PREFIX/bin/MysqL-proxyd instance stop

重启:
PREFIX/bin/MysqL-proxyd instance restart

查看运行状态:
PREFIX/bin/MysqL-proxyd instance status

Atlas MySQL 官网

https://github.com/Qihoo360/Atlas

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

相关推荐