首页 > 代码库 > Redis 集群部署

Redis 集群部署

1.集群方式

客户端分片(静态分片)  取余 一致性Hash  根据自己的算法  

优点:可控、简单  缺点:无法扩展,无法自动迁移

代理分片:twemproxy  缺点:无法自动迁移,性能最多是proxy的性能 

redis cluster:1.案例少,主要专用的客户端,

优点:分布式,容错,无中心

codis: 1.案例多,2.dashboard ,3.迁移工具

依赖于:zookeeper ectd

 

2.codis安装依赖包和go环境

yum install gcc glibc gcc-c++ make gitcd /usr/local/srcwget https://storage.googleapis.com/golang/go1.7.linux-amd64.tar.gz --no-check-certificatetar -zxvf go1.7.linux-amd64.tar.gzmv go /usr/local

3.创建GOPATH

mkdir /usr/local/go/workvim ~/.bash_profileexport GOROOT=/usr/local/goexport GOPATH=/usr/local/go/workPATH=$PATH:/HOME/bin:$GOROOT/bin:$GOPATH/binsource ~/.bash_profile

4.下载codis源码并编译

go get -d github.com/CodisLabs/codisgo get github.com/tools/godepcd $GOPATH/src/github.com/CodisLabs/codismake && make gotest

 5.下载安装zookeeper

cd /usr/local/srcwget http://mirrors.cnnic.cn/apache/zookeeper/stable/zookeeper-3.4.8.tar.gztar zxf zookeeper-3.4.8.tar.gzmv zookeeper-3.4.8 /usr/local/ln -s /usr/local/zookeeper-3.4.6/ /usr/local/zookeepercd /usr/local/zookeeper/conf/mv zoo_sample.cfg zoo.cfg

  6.创建三个目录用来存放zookeeper数据

mkdir -p /data/zk1 /data/zk2 /data/zk3echo "1" >/data/zk1/myidecho "2" >/data/zk2/myidecho "3" >/data/zk3/myid

 7.生成三份zookeeper配置文件

cd /usr/local/zookeeper/confcp zoo.cfg zk1.cfgcp zoo.cfg zk2.cfgcp zoo.cfg zk3.cfg

 8.修改zk2和zk3的配置,使用对应的数据目录和端口

 

 

 

http://navyaijm.blog.51cto.com/4647068/1637688?utm_source=tuicool&utm_medium=referral 

Redis 集群部署