数据支撑环境与旧环境是不同的,经过了合理改造。
1. 添加Redis集群的切片机制
2. MongoDB的仲裁机制优化
3. MariaDB的选择,摒弃了Mysql
(1) Redis切片机制,旧环境没有切片
没有进行切片的redis集群有很大的缺陷,首先失去了负载均衡功能,其次重启后集群效果有可能不保。所以未切片的redis集群,就完全丧失了分布式的意义。因此城轨数据支撑环境进行了切片化改造,每个切片都包含一主一从。
切片命令如下:
./redis-trib.rb reshard 172.16.16.18:7000
./redis-trib.rb create --replicas 1 master.hadoop:7000 master.hadoop:7001 master.hadoop:7002 slave1.hadoop:7003 slave1.hadoop:7004 slave1.hadoop:7005
部署完成后,check得到如下切片集群。
(2)MongoDB的仲裁机制优化,添加旧环境没有的仲裁机制。
数据支撑环境的集群,必须有三部分构成:主、从、仲裁。
设计院环境缺乏仲裁机制,主一旦挂掉,从不能升级为主,导致服务挂掉。
仲裁的作用是:一旦主机挂掉,进行投票,从机自动升级为主机,这样系统服务就不会挂掉,保证了高可用性。
经过大量血的教训,一个分片配置两个副本集时(一个是primary一个是secondary),如果primary挂掉,secondary是不会升级的,必须要加上一个不存储数据的仲裁节点
config = {"_id" : "tonghao", "members" : [ {"_id" : 0, "host" : "10.2.42.101:27017", priority:2},{"_id" : 1, "host" : "10.2.40.104:27017", priority:1},{"_id" : 2, "host":"10.2.40.104:27016", arbiterOnly:true}]}
priority:2,数字越大级别越高,级别高的作为主节点。
主从复制原理:
假如副本集的数据主从同步不一致,则需要把local db下的文件全复制。
也就是要迁移oplog时间戳
当Mongo DB 被设置成主库时(这一点很重要),在 local db 下有个 collection 叫oplog.$main ,这个就是Mongo 的 oplog。
当Primary节点完成数据操作后,Secondary会做出一系列的动作保证数据的同步:
1:检查自己local库的oplog.rs集合找出最近的时间戳。
2:检查Primary节点local库oplog.rs集合,找出大于此时间戳的记录。
3:将找到的记录插入到自己的oplog.rs集合中,并执行这些操作。
Secondary节点同步到哪了:
1:Primary节点插入一条数据
2:同时,会把该数据写入到Primary的oplog中,并且记录一个时间戳
3:db.runCommand({getlasterror:1,w:2})在Primary节点被调用时,Primary就完成了写入操作,等待其他非仲裁节点来同步数据
4:Secondary节点查询Primary的oplog并且拉去oplog
5:Secondary根据时间戳应用oplog
6:Secondary请求大于本身oplog时间戳的oplog
7:Primary更新时间戳
(3)关于MariaDB与Mysql的选择问题。
1.首先MariaDB的出现背景。
开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此社区采用分支的方式来避开这个风险。
MariaDB的目的是在遵循GPL协议的条件下完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。
MySQL之父Widenius先生离开了Sun之后,觉得依靠Sun/Oracle来发展MySQL,实在很不靠谱,而MariaDB和原来开源Mysql是同一团队研发。
2.MariaDB的优点。
MariaDB有一个缺点就是开源,同时它的优点也是开源。这样对MariaDB进行支撑的团队人员将更加灵活和高效。事实也证明,闭源mysql的版本更新进度是紧跟MariaDB的。
MariaDB不仅仅是Mysql的一个替代品,它的主要目的是创新和提高Mysql的技术。
MariaDB跟MySQL在绝大多数方面是兼容的,对于开发者来说,几乎感觉不到任何不同。目前MariaDB是发展最快的MySQL分支版本,新版本发布速度已经超过了Oracle官方的MySQL版本。
MariaDB 是一个采用Aria存储引擎的MySQL分支版本,是由原来 MySQL 的作者Michael Widenius创办的公司所开发的免费开源的数据库服务器。
最近Oracle进一步闭源的举措更是让人难以安心,众多互联网公司纷纷开始寻求MySQL的替代方案。Apple,Google、Facebook、Twitter、Wiki也大量使用MariaDB,在美国已经掀起了热潮。
此外Widenius团队对MariaDB进行了更充分的测试,更少的的警告语缺陷、真正的开源。
所以基于以上种种原因,一体化配置工具将采用MariaDB的设计方案。
原文:http://blog.51cto.com/zhaoanan/2328274