专栏首页憧憬博客分享redis主从配置+集群搭建

redis主从配置+集群搭建

为什么需要主从配置?????

当出现高并发流量情况 如果我们只有一个redis服务器  挂掉之后  网站的运营会出现问题. 我们可以多弄几台redis服务器,使得一台服务器挂掉自动切换到另一台redis服务器,这个时候就实现了一个高可用的系统

主从配置 环境是2台 ubuntu server 18.04  虚拟机

首先安装redis-server

sudo apt-get update  
sudo apt-get install redis-server
  • 主库配置. 修改配置文件
vim /etc/redis/redis.conf

# bind 127.0.0.1 ::1   注释掉这个外链地址 允许外部连接麻   不然从库怎么去连接呢  对吧
  • 从库配置(也需要安装redis)也就是另一台服务器
修改配置文件
vim /etc/redis/redis.conf

# slaveof 主库ip 主库端口号  把这行注释打开  

配置完成都需要去重启服务
  • 主库查看

配置完成之后就需要去查看是否配置成功了,然后去主库服务器上使用redis-cli 连接 输入 info命令查看 有一个 Replication connected_slaves:1   为一就说明有了一个重库   好吧 因为比较简单 所以不做详细说明

手动搭建redis集群

  • 集群搭建一般需要的服务器比较多   redis最少需要6台   3主3从  我如果开这么多虚拟机我电脑可能炸掉 所以我直接在一台虚拟机上面搭建6个redis
  • 使用不同的端口号  redis版本使用的是4.0
  • 安装redis

在官网找到redis的包   使用wget获取资源 然后解压 因为官方提供了makefile 所以比较方便  直接make就可以了 编译好的会出现在src目录里面

  • 如果是一台新的机器 可能一些依赖都是需要我们自己手动去安装  apt-get install gcc g++ make 对吧  随后就可以为所欲为

为了方便  我直接把我们需要用到的一些东西直接拷贝到了我的家目录

cp ./src/redis-server /home/test/redis-cluster/
cp ./src/redis-cli /home/test/redis-cluster/
cp ./src/redis-trib.rb /home/test/redis-cluster/

拷贝过去后  然后我去redis-cluster里面创建6个文件夹  每个存放一个redis服务

mkdir 7000 7001 7002 7003 7004 7005

给每一个文件夹都设置他们的配置文件

redis.conf (内容如下)

port 7000  这是端口                  //你希望是啥就是啥
cluster-enabled yes                 //开启集群模式
cluster-config-file nodes.conf      //集群的配置  配置文件首次启动自动生成 
cluster-node-timeout 5000           //请求超时
appendonly yes                      //aof日志开启  有需要就开启,它会每次写操作都记录一条日志
  • 然后分别去每个目录下启动每个服务

../redis-server ./redis.conf   这样启动会发现  如果我们将终端关闭  这个redis也就关闭 所以我们使用nohub命令去后台运行

nohup ../redis-server ./redis.conf &   启动完6个redis

  • 随后我们需要创建集群

使用redis-trib.rb 来创建 因为是ruby编写的   所以需要先安装一个redis   顺便安装一个rubyredis gem install redis

  • 使用命令

./redis-trib.rb create --replicas 1 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005

这里使用的命令是create,因为我们要创建一个新的集群。该选项--cluster-replicas 1意味着我们希望每个创建的主服务器都有一个从服 其他参数是我要用于创建新集群的实例的地址列表。

显然,我们要求的唯一设置是创建一个包含3个主服务器和3个从服务器的集群。

Redis-cli将为您提供配置。键入yes接受建议的配置。将配置并加入群集,这意味着实例将被引导为彼此通信。最后,如果一切顺利,你会看到这样的消息: [OK] All 16384 slots covered  这意味着至少有一个主实例为16384个可用插槽提供服务。

然后使用 redis-cli -c -p 7000  连接redis  (-c 代表集群模式)

set name test

然后切换别的redis服务  去get 获取成功

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • SpringBoot 配置Redis操作

    这样本地环境就搭建起来啦。但是需要注意, Redis是默认只能本地访问 需要修改配置文件

    憧憬博客
  • Laravel实现redis发布-订阅

    如果说我们需要一个比较简单的这种机制,我们可以采用redis这个轻量级的订阅机制,我们可以参考redis的 Publish/Subscribe 机制,得到比较好...

    憧憬博客
  • Redis的高级特性与应用场景(二)

    Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。 这意味着通常情况下一个请求会遵循以下步骤:

    憧憬博客
  • 「小程序JAVA实战」安装单机环境的redis(38)

    PS:这就是我们linux下安装redis的,并用redis desktop连接。并测试了redis成功的安装。

    IT故事会
  • Ubuntu安装Redis(手动编译)

    现在进入先前解压后得到的文件夹(我的在/opt/software/redis-5.0.5),复制配置文件redis.conf到/etc/redis/下,并用vi...

    凡人飞
  • 今天,你遇到redis线上连接超时了吗?

    大量TimeoutException,说明当前redis服务节点上已经堆积了大量的连接查询,超出redis服务能力,再次尝试连接的客户端,redis 服务节点直...

    WindWant
  • centos7 安装 Redis

    简单来说,Redis就是开源使用C语言编写,基于内存持久化的日志型、key-value的非关系型数据库。支持多种语言API。

    Mokwing
  • redis的安装与启动以及注意事项

    安装步骤 (注意,在安装之前一定要注意系统的时间一定要正确,否则会出问题) 在redis中文官网上下载安装包 http://www.redis.cn/do...

    程序媛的养成日记
  • Redis单机安装以及集群搭建

    笔者在工作中也有接触到非关系型数据库Redis,主要用于缓存。但是也仅限于使用方面,底层没具体了解过,刚好有朋友正在研究这个,我也就再深入研究一...

    Liusy
  • redis实战第一篇 安装和使用

    我是李超人

扫码关注云+社区

领取腾讯云代金券