Redis单机版和集群版的安装和部署

时间:2022-04-19 09:07:37

1、单机版的安装

本次使用redis3.0版本。3.0版本主要增加了redis集群功能。

安装的前提条件:

需要安装gcc:yum install gcc-c++

1.1 安装redis

1、下载redis的源码包。

从官网下载

http://download.redis.io/releases/redis-3.0.0.tar.gz

2、把源码包上传到linux服务器

3、解压源码包并进入其目录

tar -zxvf redis-3.0.0.tar.gz

4、make

cd /usr/local/redis-3.0.0

make

5、make install

cd /usr/local/redis-3.0.0

[root@bogon redis-3.0.0]# make install PREFIX=/usr/local/redis

1.2 启动redis

1.2.1、前端启动模式(不推荐)

前端模式启动的缺点是ssh命令窗口关闭则redis-server程序结束,不推荐使用此方法。

/usr/local/redis/bin/redis-server

默认是前端启动模式,端口是6379

1.2.2、后端启动

1)从redis的源码目录中复制redis.conf到redis的安装目录。

2)修改配置文件

Redis单机版和集群版的安装和部署

3)[root@bogon bin]# ./redis-server redis.conf

2、集群版的安装

本次安装集群中有三个节点的集群,每个节点有一主一备。需要6台虚拟机。

搭建一个伪分布式的集群,使用6个redis实例来模拟。

2.1 搭建集群需要的环境

搭建集群需要使用到官方提供的ruby脚本。

需要安装ruby的环境。

2.1.1安装ruby

yum install ruby

yum install rubygems

redis集群管理工具redis-trib.rb

[root@bogon ~]# cd redis-3.0.0

[root@bogon redis-3.0.0]# cd src

[root@bogon src]# ll *.rb

-rwxrwxr-x. 1 root root 48141 Apr  1 07:01 redis-trib.rb

[root@bogon src]#

脚本需要的ruby包:

redis-3.0.0.gem

需要上传到linux服务。

2.1.2 安装ruby的包:

gem install redis-3.0.0.gem

[root@bogon ~]# gem install redis-3.0.0.gem

Successfully installed redis-3.0.0

1 gem installed

Installing ri documentation for redis-3.0.0...

Installing RDoc documentation for redis-3.0.0...

2.2 集群的搭建

2.2.1 创建6个redis实例,端口号从7001~7006

在/usr/local下创建redis-cluster目录,其下创建7001、7002。。7006目录

将redis安装目录bin下的文件拷贝到每个700X目录内,同时将redis源码目录src下的redis-trib.rb拷贝到redis-cluster目录下。

2.2.2  修改redis的配置文件

1、修改端口号

Redis单机版和集群版的安装和部署

2、打开cluster-enable前面的注释。

Redis单机版和集群版的安装和部署

2.2.3:把创建集群的ruby脚本复制到redis-cluster目录下。

2.2.4:启动6个redis实例

2.2.5:创建集群。

执行redis-trib.rb,此脚本是ruby脚本,它依赖ruby环境。

./redis-trib.rb create --replicas  192.168.131.102: 192.168.131.102: 192.168.131.102: 192.168.131.102: 192.168.131.102:  192.168.131.102:

说明:

redis集群至少需要3个主节点,每个主节点有一个从节点总共6个节点

replicas指定为1表示每个主节点有一个从节点

注意:

如果执行时报如下错误:

[ERR] Node XXXXXX is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0

解决方法是删除生成的配置文件nodes.conf,如果不行则说明现在创建的结点包括了旧集群的结点信息,需要删除redis的持久化文件后再重启redis,比如:appendonly.aof、dump.rdb

创建集群输出:

Can I set the above configuration? (type 'yes' to accept): yes

2.3 测试集群

[root@bogon redis-cluster]# redis01/redis-cli -h 192.168.25.153 -p 7002 -c

[root@bogon redis-cluster]# redis01/redis-cli -h 192.168.25.153 -p 7002

192.168.25.153:7002> set a 100

(error) MOVED 15495 192.168.25.153:7003

192.168.25.153:7002>

[root@bogon redis-cluster]# redis01/redis-cli -h 192.168.25.153 -p 7002 -c

192.168.25.153:7002> set a 100

-> Redirected to slot [15495] located at 192.168.25.153:7003

OK

说明:

./redis-cli -c -h 192.168.101.3 -p 7001 ,其中-c表示以集群方式连接redis,-h指定ip地址,-p指定端口号 -a myPassword

最后还有添加删除节点,暂时就不写了,可以参考下:http://blog.51yip.com/nosql/1726.html