Codis 正在参加 2020 年度 OSC 中国开源项目评选,请投票支持!
Codis 在 2020 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
投票让它出道
已投票
授权协议: MIT
开发语言: C/C++ Google Go
操作系统: Linux
开发厂商: 豌豆荚
收录时间: 2014-11-09
提 交 者: 红薯

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 已经是稳定阶段,目前豌豆荚已经在使用该系统。

架构:

Snapshot1

特性:

  • 自动平衡

  • 使用非常简单

  • 图形化的面板和管理工具

  • 支持绝大多数 Redis 命令,完全兼容 twemproxy

  • 支持 Redis 原生客户端

  • 安全而且透明的数据移植,可根据需要轻松添加和删除节点

  • 提供命令行接口

  • RESTful APIs

安装:

  • Install go

  • go get github.com/wandoulabs/codis

  • cd codis

  • ./bootstrap.sh

  • make gotest

  • cd sample

  • follow instructions in usage.md

界面截图:

Dashboardmain

Migratemigrate

Slotsslots

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

Codis 的相关博客

codis,codis3.0和其他

codis参与者谈谈他所认识的codis,值得参考与阅读。

Codis

Codis 是一个分布式 Redis 解决方案, 对于上层的应用来说, 连接到 Codis Proxy 和连接原生的 Redis Server 没有明显的区别 (不...

codis

总体架构 192.168.199.223(zookeeper、codis-proxy、codis-dashborad:18080、codis-fe:18090、codis-server) 192.168.199....

接触Codis&Codis-ha

从接触到安装测试Codis&Codis-ha,安装的经历

使用codis-admin搭建codis集群

目的 在Redis Codis 部署安装的文章中,介绍了通过fe在web上搭建codis的基本步骤和方法,也介绍了codis-admin的相关说明,为...

Codis 安装

1.下载codis 下载地址:https://github.com/CodisLabs/codis.git 2.下载 go 环境库 下载地址:https://golang.org/ 3. 添加 ...

codis 使用

1:Jedis与Redisson对比 2.1. 概况对比 Jedis是Redis的Java实现的客户端,其API提供了比较全面的Redis命令的支持;Redisson实...

Codis 运维D3 - Codis 下命令使用帮助

摘要:昨天讲了Codis 的搭建,今天我们来说说 Codis 搭建完毕后,Codis 命令的使用及帮助。 首先我们来看下,Codis 下的所有命...

codis集群搭建

github文档https://github.com/CodisLabs/codis/blob/master/doc/tutorial_zh.md ####环境 codis-proxy+codis-config: 192....

评论 (19)

加载中

引用来自“xiaour”的评论

竟然连keys命令都不支持,辣鸡

引用来自“Hello_WOD”的评论

不支持keys? 呵呵呵 你这么说低级程序员无误了
还是你高级,发布订阅支持吗?Keys禁用是为了防止服务雪崩这个我不是不知道,但是你一个代理你为啥不让支持啊?你又不能代表所有生产环境。来彰显自己优越感么?
2019/02/27 10:25
回复
举报

引用来自“xiaour”的评论

竟然连keys命令都不支持,辣鸡
不支持keys? 呵呵呵 你这么说低级程序员无误了
2019/02/25 14:19
回复
举报
scan都不支持
01/03 16:41
回复
举报
竟然连keys命令都不支持,辣鸡
2018/12/20 09:06
回复
举报
找不到codis和spring整合的代码,新手不会弄啊
2017/06/05 17:31
回复
举报
最近使用codis,做session。报config和PUBLISH不允许访问。ERR handle request, command 'PUBLISH' is not allowed。求大神解决。
2017/05/08 14:49
回复
举报
欢迎加入343595434codis技术交流群,这里有codis作者以及各个codis使用大神为你答疑解惑
2017/02/14 13:13
回复
举报
codis-proxy通过硬件负载(DR)后,业务连接时,有的时候很慢。有的时候很快!在对于proxy的负载检查是不是有问题?
2017/01/12 17:02
回复
举报
打分: 力荐
公司再用,感觉很好!
2016/12/26 12:57
回复
举报
好东西!得好好研究一下! Codis
2014/11/09 08:23
回复
举报
比较叼的感觉,797979 Codis
2014/11/09 09:35
回复
举报
更多评论
19 评论
1.2K 收藏
分享
返回顶部
顶部