redis分片集群安装与部署

分片集群的优势

  1. 高可用。且方便扩展。
  2. 数据分片,多节点提供服务,提高性能,数据提供冗余备份。

分片集群部署

只需更改配置文件

部署架构:6个节点,3主3从。数据集分为3片,分别再A,B,C节点上。A1和B1和C1分别为A,B,C的分片。

散列槽:

​ Redis Cluster 不使用一致散列,而是一种不同形式的分片,其中每个键在概念上都是我们所谓的散列槽的一部分

​ Redis 集群中有 16384 个哈希槽,要计算给定键的哈希槽是多少,我们只需取密钥的 CRC16 模数 16384。

​ Redis 集群中的每个节点都负责哈希槽的一个子集。

部署规划

3台服务器,6个实例,每台服务器部署2个实例。

IP地址 角色 端口 配置文件 数据目录
192.168.0.77 分片A 7000 /data/redis-cluster/redis-7000/bin/redis-7000.conf /data/redis-cluster/redis-7000
192.168.0.89 分片B 7000 /data/redis-cluster/redis-7000/bin/redis-7000.conf /data/redis-cluster/redis-7000
192.168.0.218 分片C 7000 /data/redis-cluster/redis-7000/bin/redis-7000.conf /data/redis-cluster/redis-7000
192.168.0.77 副本分片B' 7001 /data/redis-cluster/redis-7001/bin/redis-7001.conf /data/redis-cluster/redis-7001
192.168.0.89 副本分片C' 7001 /data/redis-cluster/redis-7001/bin/redis-7001.conf /data/redis-cluster/redis-7001
192.168.0.218 副本分片A' 7001 /data/redis-cluster/redis-7001/bin/redis-7001.conf /data/redis-cluster/redis-7001

ps:由于我测试环境部署是单节点部署6个实例来做测试。3台服务器部署的架构可以参考以下操作步骤。一样的部署和配置,需要更换ip地址。

安装步骤

  1. 下载redis源码包

    官网地址:http://download.redis.io/releases/

    我选择最新版本redis-6.2.6,下载的源码tmp目录。

  2. 编译安装

    #解压后编译安装
    cd /tmp
    tar -zxvf redis-6.2.6.tar.gz
    cd
    make && make install PREFIX=/opt/redis-6.2.6 #编译安装完成后,源码文件目录就可以删除了
  3. 复制对应的文件,分别复制6份,用不同的目录来区分不同的实例。

  4. 分别修改各自的配置文件。

    #基本参数解析
    cluster-node-timeout 10000 #主节点在该时间内无法访问,它将由其从属节点进行故障转移。
    cluster-require-full-coverage no #设置为no,及时部分主节点不可用,可以的节点分片也能提供查询服务。
    cluster-slave-validity-factor 6 #有效因子,在5000X10时间内,不进行故障转移。设置了非0值,如果从节点都不可故障转移,则整个集群就不可用,直到主节点重新加入。
    --------- #以下是配置文件内容
    dir /data/redis-cluster/redis-6.2.6-7001 #工作目录,每个实例需变更
    bind 192.168.0.218 #变更为自己的ip
    port 7001 #变更为自己的端口
    daemonize yes
    pidfile /data/redis-cluster/redis-6.2.6-7001/redis.pid #根据每个实例路径变更
    logfile /var/log/redis-cluster/redis-7001.log #根据每个实例路径变更
    cluster-enabled yes
    cluster-config-file /data/redis-cluster/redis-6.2.6-7001/nodes-7001.conf #根据每个实例路径变更
    cluster-node-timeout 10000
    cluster-require-full-coverage no
    cluster-slave-validity-factor 6
    appendonly yes
    requirepass penngke
    masterauth penngke
  5. 实例比较多,创建一个一个集群启动脚本,方便启动

    vim start-redis-cluster.sh

    #!/bin/bash
    cd /data/redis-cluster/redis-7000
    ./bin/redis-server ./bin/redis-7000.conf cd /data/redis-cluster/redis-7001
    ./bin/redis-server ./bin/redis-7001.conf cd /data/redis-cluster/redis-7002
    ./bin/redis-server ./bin/redis-7002.conf cd /data/redis-cluster/redis-7003
    ./bin/redis-server ./bin/redis-7003.conf cd /data/redis-cluster/redis-7004
    ./bin/redis-server ./bin/redis-7004.conf cd /data/redis-cluster/redis-7005
    ./bin/redis-server ./bin/redis-7005.conf
  6. 用redis-cli客户端创建集群

    ./redis-cli --cluster create 10.255.65.99:7000 10.255.65.99:7001 10.255.65.99:7002 10.255.65.99:7003 10.255.65.99:7004 10.255.65.99:7005 --cluster-replicas 1 --pass '密码'
    #输出结果可以看到已经创建为3主3从
  7. 可以使用./redis-cli 客户端,登陆6个节点任意节点。查看状态。

    ./redis-cli -c -p 7000
    cluster info
    cluster nodes
    set test 666
    get test

redis分片集群安装部署的更多相关文章

  1. Mongodb副本集+分片集群环境部署记录

    前面详细介绍了mongodb的副本集和分片的原理,这里就不赘述了.下面记录Mongodb副本集+分片集群环境部署过程: MongoDB Sharding Cluster,需要三种角色: Shard S ...

  2. Redis Sentinel 集群安装 step by step

    一. 准备材料 服务器 IP address 操作系统 位数 Redis 版本   CNT06CAH05 192.168.3.47 CentOS 6.5 x64 Redis-3.2.6 sentine ...

  3. Mongodb副本集+分片集群环境部署

    前面详细介绍了mongodb的副本集和分片的原理,这里就不赘述了.下面记录Mongodb副本集+分片集群环境部署过程: MongoDB Sharding Cluster,需要三种角色: Shard S ...

  4. HBase集群安装部署

    0x01 软件环境 OS: CentOS6.5 x64 java: jdk1.8.0_111 hadoop: hadoop-2.5.2 hbase: hbase-0.98.24 0x02 集群概况 I ...

  5. flink部署操作-flink standalone集群安装部署

    flink集群安装部署 standalone集群模式 必须依赖 必须的软件 JAVA_HOME配置 flink安装 配置flink 启动flink 添加Jobmanager/taskmanager 实 ...

  6. HBase 1.2.6 完全分布式集群安装部署详细过程

    Apache HBase 是一个高可靠性.高性能.面向列.可伸缩的分布式存储系统,是NoSQL数据库,基于Google Bigtable思想的开源实现,可在廉价的PC Server上搭建大规模结构化存 ...

  7. 1.Hadoop集群安装部署

    Hadoop集群安装部署 1.介绍 (1)架构模型 (2)使用工具 VMWARE cenos7 Xshell Xftp jdk-8u91-linux-x64.rpm hadoop-2.7.3.tar. ...

  8. Redis真集群安装

    Redis真集群安装 命令文档:http://redisdoc.com/index.html 下载:https://code.google.com/archive/p/redis/downloads ...

  9. redis cluster 集群 安装 配置 详解

    redis cluster 集群 安装 配置 详解 张映 发表于 2015-05-01 分类目录: nosql 标签:cluster, redis, 安装, 配置, 集群 Redis 集群是一个提供在 ...

随机推荐

  1. Learning ROS: Recording and playing back data

    本文主要部分来源于ROS官网的Tutorials. Description: This tutorial will teach you how to record data from a runnin ...

  2. golang channel原理

    channel介绍 channel一个类型管道,通过它可以在goroutine之间发送和接收消息.它是Golang在语言层面提供的goroutine间的通信方式. 众所周知,Go依赖于称为CSP(Co ...

  3. 性能测试工具JMeter 基础(二)—— 主界面介绍

    主界面介绍 JMeter的主界面主要分为菜单导航栏.工具栏.计划树标签栏.内容栏 菜单导航栏:全部的功能的都包含在菜单栏中 工具栏:相当于菜单栏常用功能的快捷按钮 计划树标签栏:显示测试用例(计划)相 ...

  4. vs code使用git---http方式

    1.从git上复制http路径 2.在vs code的工作区新建文件夹 3.选择添加远程储存库 4.输入复制的git路径然后命名远程储存库名称   5.选择从所有远程储存库中拉取分支 6.选择分支,切 ...

  5. 【第一篇】- Git 教程之Spring Cloud直播商城 b2b2c电子商务技术总结

    Git 教程 Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制 ...

  6. ClickOnce手动更新

    if (ApplicationDeployment.IsNetworkDeployed == true)             {                 ApplicationDeploy ...

  7. Docker 安装 MySQL5.6

    方法一.docker pull mysql查找Docker Hub上的mysql镜像 #docker search mysql 这里我们拉取官方的镜像,标签为5.6 #docker pull mysq ...

  8. STM32CbueIDE 体验

    STM32CbueIDE 体验 下载安装 官网下载链接:https://www.st.com/zh/development-tools/stm32cubeide.html. 软件启动时会令设置工作目录 ...

  9. 深入学习Composer原理(三)

    本系列第三篇文章,一起了解下PSR规范中的PSR4和PSR0规范 首先恭喜大家,包括我自己,坚持到了现在.这篇文章之后,Composer的基础原理就清晰明了咯.也就是说,Composer所利用的正是s ...

  10. tp5 引入 没有命名空间的类库的方法(以微信支付SDK为例)

    use think\Loader; Loader::import('Wxpay.WxPay',EXTEND_PATH,'.Api.php'); 注意扩展名的点"."不能省略 使用之 ...