linux安装redis 部署redis集群

linux安装redis 部署redis集群

一、安装redis

linux下安装

  1. 获取redis资源
1 wget http://download.redis.io/releases/redis-4.0.10.tar.gz
  1. 解压 
1 tar zxvf redis-4.0.10.tar.gz
  1. 把redis编译过来
1 cd redis-4.0.10
2 make

img

make完后 redis-2.8.17目录下会出现编译后的redis服务程序redis-server,还有用于测试的客户端程序redis-cli,两个程序位于安装目录 src 目录下:

下面启动redis服务.

1 $ cd src
2 $ ./redis-server

注意这种方式启动redis 使用的是默认配置。也可以通过启动参数告诉redis使用指定配置文件使用下面命令启动。

1 $ cd src
2 $ ./redis-server ../redis.conf

redis.conf 是一个默认的配置文件。我们可以根据需要使用自己的配置文件。

启动redis服务进程后,就可以使用测试客户端程序redis-cli和redis服务交互了。 比如:

1 $ cd src
2 $ ./redis-cli
3 redis> set foo bar
4 OK
5 redis> get foo
6 "bar"

ubuntu下安装

在 Ubuntu 系统安装 Redis 可以使用以下命令:

1 $sudo apt-get update
2 $sudo apt-get install redis-server

启动redis

1 $ redis-server

查看redis是否启动

1 $ redis-cli

以上命令将打开以下终端:

1 redis 127.0.0.1:6379>

127.0.0.1 是本机 IP ,6379 是 redis 服务端口。现在我们输入 PING 命令。

1 redis 127.0.0.1:6379> ping
2 PONG

以上说明我们已经成功安装了redis。

ubuntu先设置外部可链接

redis在ubuntu安装后默认是只有本地访问,需要别的ip访问我们需要修改redis的配置文件

1 dpkg -L redis-server

这命令我们可以看到redis的安装的文件在那些目录

1557803281147

2.之后我们就修改配置文件

1 sudo vim /etc/redis/redis.conf

1557803573628

默认是127.0.0.1

这里修改为0.0.0.0 也就是随意哪个 ip都可以访问,当然也可以配置多个ip访问,多个ip间用空格隔开就行了

重启服务: service redis-server restart

二、linux下搭建集群

​ 安装部署任何一个应用其实都很简单,只要安装步骤一步一步来就行了。下面说一下 Redis 集群搭建规划,由于集群至少需要6个节点(3主3从模式),所以,没有这么多机器给我玩,我本地也起不了那么多虚拟机(电脑太烂),现在计划是在一台机器上模拟一个集群,当然,这和生产环境的集群搭建没本质区别。

  1. 创建文件夹
    我们计划集群中 Redis 节点的端口号为 9001-9006 ,端口号即集群下各实例文件夹。数据存放在 端口号/data 文件夹中

1557813956247

1 mkdir /usr/local/redis-cluster
2 cd redis-cluster/
3 mkdir -p 9001/data 9002/data 9003/data 9004/data 9005/data 9006/data
  1. 复制执行脚本

/usr/local/redis-cluster 下创建 bin 文件夹,用来存放集群运行脚本,并把安装好的 Redis 的 src 路径下的运行脚本拷贝过来。看命令:

1 mkdir redis-cluster/bin cd /usr/local/redis/src cp mkreleasehdr.sh redis-benchmark redis-check-aof redis-check-dump redis-cli redis-server redis-trib.rb /usr/local/redis-cluster/bin
  1. 复制一个新 Redis 实例

我们现在从已安装好的 Redis 中复制一个新的实例到 9001 文件夹,并修改 redis.conf 配置。

1557814043014

1 cp /usr/local/redis/* /usr/local/redis-cluster/9001

注意,修改 redis.conf 配置和单点唯一区别是下图部分,其余还是常规的这几项:

1 port 9001(每个节点的端口号)
2 daemonize yes
3 bind 192.168.119.131(绑定当前机器 IP)
4 dir /usr/local/redis-cluster/9001/data/(数据文件存放位置)
5 pidfile /var/run/redis_9001.pid(pid 9001和port要对应)
6 cluster-enabled yes(启动集群模式)
7 cluster-config-file nodes9001.conf(9001和port要对应)
8 cluster-node-timeout 15000
9 appendonly yes

集群搭建配置重点就是取消下图中的这三个配置的注释:

1557814078070

  1. 再复制出五个新 Redis 实例

我们已经完成了一个节点了,其实接下来就是机械化的再完成另外五个节点,其实可以这么做:把 9001 实例 复制到另外五个文件夹中,唯一要修改的就是 redis.conf 中的所有和端口的相关的信息即可,其实就那么四个位置。开始操作,看图:

1557814105060

1 cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9002
2 cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9003
3 cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9004
4 cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9005
5 cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9006

cp -rf 命令是不使用别名来复制,因为 cp 其实是别名 cp -i,操作时会有交互式确认,比较烦人。

  1. 修改 9002-9006 的 redis.conf 文件

其实非常简单了,你通过搜索会发现其实只有四个点需要修改,我们全局替换下吧,进入相应的节点文件夹,做替换就好了。命令非常简单,看图:

1557814156370

1 vim redis.conf
2 :%s/9001/9002g

回车后,就会有替换几个地方成功的提示,不放心可以手工检查下:

1557814184796

其实我们也就是替换了下面这四行:

1 port 9002
2 dir /usr/local/redis-cluster/9002/data/
3 cluster-config-file nodes-9002.conf
4 pidfile /var/run/redis_9002.pid

到这里,我们已经把最基本的环境搞定了,接下来就是启动了。

  1. 启动 9001-9006 六个节点

1557814295814

1 /usr/local/bin/redis-server /usr/local/redis-cluster/9001/redis.conf 
2 /usr/local/bin/redis-server /usr/local/redis-cluster/9002/redis.conf 
3 /usr/local/bin/redis-server /usr/local/redis-cluster/9003/redis.conf 
4 /usr/local/bin/redis-server /usr/local/redis-cluster/9004/redis.conf 
5 /usr/local/bin/redis-server /usr/local/redis-cluster/9005/redis.conf 
6 /usr/local/bin/redis-server /usr/local/redis-cluster/9006/redis.conf

可以检查一下是否启动成功:ps -el | grep redis

看的出来,六个节点已经全部启动成功了。

  1. 随便找一个节点测试试
1 /usr/local/redis-cluster/bin/redis-cli -h 192.168.119.131 -p 9001
2 set name mafly

1557814522647

连接成功了,但好像报错了阿???
(error) CLUSTERDOWN Hash slot not served(不提供集群的散列槽),这是什么鬼?
这是因为虽然我们配置并启动了 Redis 集群服务,但是他们暂时还并不在一个集群中,互相直接发现不了,而且还没有可存储的位置,就是所谓的**slot(槽)**。

  1. 安装集群所需软件

由于 Redis 集群需要使用 ruby 命令,所以我们需要安装 ruby 和相关接口。

1 yum install ruby
2 yum install rubygems
3 gem install redis 

1557814570870

这才是真正的创建集群

先不废话,直接敲命令:

1 /usr/local/redis-cluster/bin/redis-trib.rb create --replicas 1 192.168.119.131:9001 192.168.119.131:9002 192.168.119.131:9003 192.168.119.131:9004 192.168.119.131:9005 192.168.119.131:9006

1557814602521

简单解释一下这个命令:调用 ruby 命令来进行创建集群,--replicas 1 表示主从复制比例为 1:1,即一个主节点对应一个从节点;然后,默认给我们分配好了每个主节点和对应从节点服务,以及 solt 的大小,因为在 Redis 集群中有且仅有 16383 个 solt ,默认情况会给我们平均分配,当然你可以指定,后续的增减节点也可以重新分配。

M: 10222dee93f6a1700ede9f5424fccd6be0b2fb73 为主节点Id

S: 9ce697e49f47fec47b3dc290042f3cc141ce5aeb 192.168.119.131:9004 replicates 10222dee93f6a1700ede9f5424fccd6be0b2fb73 从节点下对应主节点Id

目前来看,9001-9003 为主节点,9004-9006 为从节点,并向你确认是否同意这么配置。输入 yes 后,会开始集群创建。

1557814656603

上图则代表集群搭建成功啦!!!

验证一下:
依然是通过客户端命令连接上,通过集群命令看一下状态和节点信息等。

1 /usr/local/redis-cluster/bin/redis-cli -c -h 192.168.119.131 -p 9001
2 cluster info
3 cluster nodes

1557814673644

通过命令,可以详细的看出集群信息和各个节点状态,主从信息以及连接数、槽信息等。这么看到,我们已经真的把 Redis 集群搭建部署成功啦!

设置一个 mafly:
你会发现,当我们 set name mafly 时,出现了 Redirected to slot 信息并自动连接到了9002节点。这也是集群的一个数据分配特性,这里不详细说了。

1557814689076

总结一下](http://blog.mayongfa.cn/287.html)

这一篇 Redis 集群部署搭建的文章真的是一步一步的走下来的,只要你安装我的步骤来,就保证你能成功搭建一个 Redis 集群玩玩,也可以这么说,除了步骤繁琐外,几乎不存在技术含量,估计能看完的人都感觉累(说真的,写这种文章真的很累人)。

接下来可能就是动态扩容、增加节点和减少节点,重新分配槽大小等,当然,还有最重要的就是怎么和我们程序结合起来,以及如何更好的把 Redis 缓存集群发挥出应有的效果,这些才是最重要的。

三、ubuntu下集群搭建具体步骤如下(注意要关闭防火墙)

  1. 在/home/rsckj/redis目录下新建redis-cluster目录,用于存放集群节点

1557804129849

  1. 拷贝redis.conf配置文件到9001.9002,9003,9004,9005,9006目录下作为各个节点的配置文件。

设置redis会后台启动.找到daemonize no 修改为 daemonize yes。

Redis集群搭建详细教程

找到port 6379 修改为对应节点目录的端口号。本次修改为6001目录下的,固修改为6001。

Redis集群搭建详细教程

找到bind这一行,bind后要修改为 当前机器的IP地址。

Redis集群搭建详细教程

找到 dir 这一行 指定数据文件的存放路径。设置为各个节点下的目录。目录结构类似为"/usr/local/las/redis-cluster/节点目录/"

Redis集群搭建详细教程

启动集群模式。找到cluster-enabled 修改为 cluster-enabled yes。

Redis集群搭建详细教程

设置集群的配置文件路径 。cluster-config-file nodes600*.conf。600*代表每个节点的目录对应的位置。本次修改为6001。

Redis集群搭建详细教程

修改appendonly 为yes 。然后按照6001节点配置格式分别修改6002,6003,6004,6005,6006这几个节点的配置文件。

Redis集群搭建详细教程

安装redisgem**

1 gem install redis

安装ruby

1 sudo apt-get install ruby
 
原文地址:https://www.cnblogs.com/hmy-1365/p/13094612.html