在阿里云部署redis集群

在阿里云中实现redis集群操作
作者:全宇宙超级无敌大帅哥
时间:2019-11-12
----------------------------版权归我所有想看原文请跳转网页 新手推荐 ----------------------------------

1.Redis简介

Redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。

2.Redis集群介绍

Redis 集群是一个提供在多个Redis间节点间共享数据的程序集。 Redis集群并不支持处理多个keys的命令,因为这需要在不同的节点间移动数据,从而达不到像Redis那样的性能,在高负载的情况下可能会导致不可预料的错误。

Redis 集群通过分区来提供一定程度的可用性,在实际环境中当某个节点宕机或者不可达的情况下继续处理命令,Redis 集群的优势:

1.自动分割数据到不同的节点上。
2.整个集群的部分节点失败或者不可达的情况下能够继续处理命令。

3.阿里云搭建redis集群

随着互联网发展,数据量越来越大,对性能要求越来越高,传统数据库存在着先天性的缺陷,即单机(单库)性能瓶颈,并且扩展困难。这样既有单机单库瓶颈,却又扩展困难,自然无法满足日益增长的海量数据存储及其性能要求,所以才会出现了各种不同的 NoSQL 产品,NoSQL 根本性的优势在于在云计算时代,简单、易于大规模分布式扩展,并且读写性能非常高。下面分析下两者的特点,及优缺点

4…Redis主从复制

3.1 主从复制的简单流程介绍:

  • Master可以拥有多个slave
  • 多个slave可以连接同一个Master外,还可以连接到其他的slave
  • 主从复制不会阻塞Master在主从复制时,Master可以处理client请求。
  • 提供系统的伸缩性。

2、主从复制过程:

  • slave与master建立连接,发送sync同步命令;
  • master会开启一个后台进程,将数据库快照保存到文件中,同时master主进程会开始收集新的写命令并缓存;
  • 后台完成保存后,就将文件发送给slave;
  • slave将此文件保存到硬盘上;

在阿里云部署redis集群_第1张图片

开始安装

以下步骤集群各机器均需操作,保持一致。

1)下载所需要的redis安装包redis-3.2.11.tar.gz
redis-3.2.11.tar.gz
2)将redis-3.2.11.tar.gz上传
在阿里云部署redis集群_第2张图片

1)安装gcc

yum -y install gcc
在阿里云部署redis集群_第3张图片

2.(2)使用yum命令安装 ruby1 (我们需要使用ruby脚本来实现集群搭建)

// 安装ruby
1.yum install ruby
2.yum install rubygems
在阿里云部署redis集群_第4张图片

3.下载redis源码包,并解压

// 下载redis
wget http://download.redis.io/releases/redis-5.0.6.tar.gz
//解压redis
tar -zxvf redis-5.0.6.tar.gz
在阿里云部署redis集群_第5张图片
在阿里云部署redis集群_第6张图片

4.进入redis源码文件夹进行编译

// 编译redis源码
make
在这里插入图片描述

5.创建目录/usr/local/redis-cluster目录, 安装6个redis实例,分别安装在以下目录

/usr/local/redis-cluster/redis-1
/usr/local/redis-cluster/redis-2
/usr/local/redis-cluster/redis-3
/usr/local/redis-cluster/redis-4
/usr/local/redis-cluster/redis-5
/usr/local/redis-cluster/redis-6
在阿里云部署redis集群_第7张图片
// 编译redis源码
make install PREFIX=/usr/local/redis-cluster/redis1
在阿里云部署redis集群_第8张图片

6.复制配置文件 将 /redis-3.0.0/redis.conf 复制到redis下的bin目录下、

// 复制配置文件
cp redis.conf /usr/local/redis-cluster/redis1/bin
在阿里云部署redis集群_第9张图片

配置集群

1.修改每个redis节点的配置文件redis.conf,
注释bind、
修改protected-mode配置、
修改运行端口为7001 (7002 7003 …)
将cluster-enabled yes 前的注释去掉
在阿里云部署redis集群_第10张图片
在阿里云部署redis集群_第11张图片
在这里插入图片描述

3.启动每个redis实例,以第一个实例为例,命令如下

// 启动每个redis实例
cd /usr/local/redis-cluster/redis1/bin/
./redis-server redis.conf
在阿里云部署redis集群_第12张图片

4.上传redis-3.0.0.gem ,安装 ruby用于搭建redis集群的脚本,然后执行下面代码

// 安装redis-3.0.0.gem
gem install redis-3.0.0.gem
在阿里云部署redis集群_第13张图片

5.使用 ruby 脚本搭建集群,进入redis源码目录中的src目录 执行下面的命令

// 进入redis源码目录中的src目录
cd /usr/java/redis-5.0.6/src
//5.0.0以下的版本使用一下命令(Ruby)
./redis-trib.rb create --replicas 1 121.199.29.101:7001 121.199.29.101:7002 121.199.29.101:7003 121.199.29.101:7004 121.199.29.101:7005 121.199.29.101:7006
//5.0.0以上的版本使用一下命令(C语言)
./redis-cli --cluster create --cluster-replicas 1 121.199.29.101:7001 121.199.29.101:7002 121.199.29.101:7003 121.199.29.101:7004 121.199.29.101:7005 121.199.29.101:7006
在阿里云部署redis集群_第14张图片

6.最后一步测试

Redis-cli 连接集群:
redis-cli -h 主机ip -p 端口(集群中任意端口) -c
-c:代表连接的是 redis 集群

例:进入 端口为7001的redis : redis-cli -p 7001

查看redis 信息 : info replication
在阿里云部署redis集群_第15张图片

注意:

在阿里云服务器搭建的。分享一些小技巧出来希望能帮到你。整个步骤就不说了,说一下在这个过程中遇到的问题:
redis.conf中属性bind:
(1)默认的是127.0.0.1不能使用这个否则只能内部访问,在连接时使用的搭建的命令:./redis-trib.rb create --replicas 1 127.0.0.1:7001 127.0.0.1.171:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006(7001-7006是我使用的端口)
(2)私网就是使用ifconfig命令出来的那个,搭建是命令:./redis-trib.rb create --replicas 1 私网ip:7001 私网ip:7002 私网:7003 私网ip:7004 私网ip:7005 私网ip:7006。如果使用这个用RedisDesktManager(windows下的一个图形界面客户端)能够访问和连接,但用JedisCluster连接连接时会报异常(redis.clients.jedis.exceptions.JedisConnectionException:Could not get a resource from the pool)。
(3)公网ip(就是你访问的服务器的地址)emmm就会发现连服务都启动不起来。
(4)正确版本,注释掉用#bind XXXXXXX并且在redis.conf中需要将改为:protected-mode no。然而执行:./redis-trib.rb create --replicas 1 公网ip:7001 公网ip:7002 公网ip:7003 公网ip:7004 公网ip:7005 公网ip:7006执行到一半的时候会卡住(waiting for the cluster to join…),这时需要将你的端口+10000开放我的是把17001,17002等开放了(本机包括阿里云的的安全规则)。之后再从新搭建就可以成功了,使用JedisCluster2.9.0访问也能访问了。

建立小Demo,连接测试Redis-Cluster

1.建立springboot项目,pox.xml中配置

在阿里云部署redis集群_第16张图片
在阿里云部署redis集群_第17张图片

2.application.yml配置

在阿里云部署redis集群_第18张图片

你可能感兴趣的:(在阿里云部署redis集群)