美文网首页
Redis +Codis 百万并发同城多机房使用与经验

Redis +Codis 百万并发同城多机房使用与经验

作者: 暖夏未眠丶 | 来源:发表于2018-01-19 16:29 被阅读599次

摘要: Codis-Plus 是一个分布式 Redis 解决方案, Codis-Plus是基于Codis 2.x 分支进行修改的.Codis-Plus (后面直接称为Codis) 本身无单点. 对于上层的应用来说, 连接到 Codis Proxy 和连接原生的 Redis Server 没有明显的区别 (不支持的命令列表), 上层应用可以像使用单机的 Redis 一样使用, Codis 底层会处理请求的转发, 不停机的数据迁移等工作, 所有后边的一切事情, 对于前面的客户端来说是透明的, 可以简单的认为后边连接的是一个内存无限大的 Redis 服务。

本篇的Codis 经过修改先定名为:Codis-Plus

Codis-Plus

简介:

Codis-Plus 是一个分布式 Redis 解决方案, Codis-Plus是基于Codis 2.x 分支进行修改的.Codis-Plus (后面直接称为Codis) 本身无单点. 对于上层的应用来说, 连接到 Codis Proxy 和连接原生的 Redis Server 没有明显的区别 (不支持的命令列表), 上层应用可以像使用单机的 Redis 一样使用, Codis 底层会处理请求的转发, 不停机的数据迁移等工作, 所有后边的一切事情, 对于前面的客户端来说是透明的, 可以简单的认为后边连接的是一个内存无限大的 Redis 服务。

Codis 由4部分组成:

1.Codis Proxy (codis-proxy)2.Codis Dashboard (codis-config)3.Codis Redis (codis-server, 基于redis-2.8.21修改, 增加一些命令)4.ZooKeeper

注:官方的Codis 还有HA,在我们的版本中将HA合并到Dashboard 里了。

功能概述:

1.codis-proxy 是客户端连接的 Redis 代理服务, codis-proxy 本身实现了 Redis 协议, 表现得和一个原生的 Redis 没什么区别 (就像 Twemproxy), 对于一个业务来说, 可以部署多个 codis-proxy, codis-proxy 本身是无状态的.2.codis-config 是 Codis 的管理工具, 支持包括, 添加/删除 Redis 节点, 添加/删除 Proxy 节点, 发起数据迁移等操作. codis-config 本身还自带了一个 http server, 会启动一个 dashboard, 用户可以直接在浏览器上观察 Codis 集群的运行状态. dashboard 可以同时开启多个.  dashboard具有ha的功能, 如果开启ha, 则自动做主从切换.3.codis-server 是 Codis 项目维护的一个 Redis 分支, 基于2.8.21开发, 加入了 slot 的支持和原子的数据迁移指令. Codis 上层的 codis-proxy 和 codis-config 只能和这个版本的 Redis 交互才能正常运行.4.Codis 依赖 ZooKeeper 来存放数据路由表和 codis-proxy 节点的元信息, codis-config 发起的命令都会通过 ZooKeeper 同步到各个存活的 codis-proxy.5.Codis 支持按照 Namespace 区分不同的产品, 拥有不同的 product name 的产品, 各项配置都不会冲突.6.Zookeeper Codis将集群信息和状态保存到Zookeeper. codis-config和codis-ha都基于zookeeper实现 主从选举, 以实现无单点, 高可用!

原因Codis架构图:

经我们更改后的Codis架构图:

版权声明:本文内容由互联网用户自发贡献,版权归作者所有,本社区不拥有所有权,也不承担相关法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件至:yqgroup@service.aliyun.com 进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容。

原文链接

相关文章

  • Redis +Codis 百万并发同城多机房使用与经验

    摘要:Codis-Plus 是一个分布式 Redis 解决方案, Codis-Plus是基于Codis 2.x 分...

  • pika支持codis的slot迁移

    概述 pika使用redis协议,命令操作和redis一致,因而可以直接使用codis作为pika的集群解决方案,...

  • Ansible Role 数据库 之【codis】

    Ansible Role: Codis 安装Codis集群 介绍 Codis 是一个分布式 Redis 解决方案,...

  • 三、Codis-Cluster

    1、简介 redis是目前使用广泛的中间件,从3.0版本开始官方支持了redis cluster。理解codis ...

  • Codis初体验心得

    Codis是一个分布式的Redis解决方案,对于上层的应用来说,连接Codis Proxy和连接原生的Redis ...

  • Hbase 与 Codis 整合之 Maven 环境搭建

    一、Codis 简介 Codis是一个分布式Redis解决方案,对于上层的应用来说,连接到Codis Proxy和...

  • redis主从从跨机房同步

    获取安装redis (ubuntu 16.04 & redis 4.0.9) 安装服务 如下示例使用主从从跨机房同...

  • redis

    redis Redis - 高并发,内存高速cache ,处理读写io的高并发容忍。 redis 通常被使用来将那...

  • Codis 集群

    一、codis介绍codis是一个分布式redis集群解决方案,对于上层的应用来说, 连接到codis-proxy...

  • Java学习笔记系列——Codis

    什么是Codis 一个分布式 Redis 解决方案,多个 Redis 节点构成的集群 上层应用可以像使用单机的 R...

网友评论

      本文标题:Redis +Codis 百万并发同城多机房使用与经验

      本文链接:https://www.haomeiwen.com/subject/vbxaoxtx.html