文档详情

Codis安装部署全架构.doc

发布:2017-04-01约1.93万字共30页下载文档
文本预览下载声明
Codis安装部署全架构 Codis 是一个分布式 Redis 解决方案, 对于上层的应用来说, 连接到 Codis Proxy 和连接原生的 Redis Server 没有明显的区别 (不支持的命令列表), 上层应用可以像使用单机的 Redis 一样使用, Codis 底层会处理请求的转发, 不停机的数据迁移等工作, 所有后边的一切事情, 对于前面的客户端来说是透明的, 可以简单的认为后边连接的是一个内存无限大的 Redis 服务。 Codis 由四部分组成: Codis Proxy (codis-proxy) Codis Manager (codis-config) Codis Redis (codis-server) ZooKeeper codis-proxy 是客户端连接的 Redis 代理服务, codis-proxy 本身实现了 Redis 协议, 表现得和一个原生的 Redis 没什么区别 (就像 Twemproxy), 对于一个业务来说, 可以部署多个 codis-proxy, codis-proxy 本身是无状态的。 codis-config 是 Codis 的管理工具, 支持包括, 添加/删除 Redis 节点, 添加/删除 Proxy 节点, 发起数据迁移等操作. codis-config 本身还自带了一个 http server, 会启动一个 dashboard,用户可以直接在浏览器上观察 Codis 集群的运行状态。 codis-server 是 Codis 项目维护的一个 Redis 分支, 基于 2.8.13 开发, 加入了 slot 的支持和原子的数据迁移指令。Codis 上层的 codis-proxy 和 codis-config 只能和这个版本的 Redis 交互才能正常运行。 Codis 依赖 ZooKeeper 来存放数据路由表和 codis-proxy 节点的元信息, codis-config 发起的命令都会通过 ZooKeeper 同步到各个存活的 codis-proxy。 Codis 支持按照 Namespace 区分不同的产品, 拥有不同的 product name 的产品, 各项配置都不会冲突。 Codis架构图 前期规划 机器与应用列表: 操作系统:CentOS6.5 1,操作系统:CentOS6.5 06 ? ?codis-server1 07 ? ?codis-server2 08 ? ?codis-server3 11 ? ?codis-ha1 12 ? ?codis-ha2 13 ?zookeeper-1(codis-proxy-1) 14 ?zookeeper-2(codis-proxy-2) 15 ?zookeeper-3(codis-proxy-3) 2,硬件配置: ha ? ? ? ? ? ? ? mem:8G ? cpu:4 ? disk:100G zookeeper ? ? mem:16G ?cpu:8 ? disk:300G codis-server ? ? ?mem:16G ?cpu:8 ? disk:200G 3,架构应用 1), HA(11、12、VIP 59) hostname:codisha-1 ? apps:keepalived master,haproxy ? ? ? ? ? prots:19000 hostname:codisha-2 apps:keepalived slave ,haproxy,codis-config ?prots:19000,18087 2),zookeeper+codis-proxy hostname:zookeeper-1 ? ? apps: zookeeper1, codis_proxy_1 ? ? ? ? prots:2811,19000 hostname:zookeeper-2 ? ? apps: zookeeper2, codis_proxy_2 ? ? ? ? prots:2811,19000 hostname:zookeeper-3 ? ? apps: zookeeper3, codis_proxy_3 ? ? ? ? prots:2811,19000 3),codis-server codis-server(06、07、08) hostname: codis-server1 ? ?apps: codis_server_master,slave, ? ports:6379,6380,6389,6390hostname: codis-server2 ? ?apps: codis_server_master,slave ? ports:6379
显示全部
相似文档