眼病得治啊,今天眼花了,浪费了俩小时

参考自:https://www.jianshu.com/p/4e02b0f567a0 或者 https://blog.csdn.net/weixin_40254498/article/details/79219355

不过原博主写得有些许的问题,我把这个流程重新理一遍
首先在docker中下载使用

docker pull redis:3.0.7
docker pull ruby

分别下载redis的3.0.7版本和ruby。之所以用3.0.7版本的redis是因为ruby的redis插件没有最新版本的,如果安装最新版本的redis会导致redis.x.x.x.gem和redis版本不一致而产生问题。所以将就选择3.0.7吧。你可以去gem的官网上面看看最新版的gem对应的redis是多少版本了,然后再下载最新的即可,我这里就用3.0.7版本。gem是ruby的包管理软件,就跟php的Composer,linux的yum一样。
然后,在本地电脑上面也下载和docker中相同版本的redis,取出redis.conf文件,在你的工作路径上面创建一个文件夹,随便命名就可以了,然后在里面放入复制的redis.conf。为了使redis支持分布式,打开cluster配置。

保存后,在当前文件夹中创建Dockerfile文件,简单的说,Dockerfile文件就是在容器外面定义了将要在容器里面执行的操作。这些操作实际上也可以自己在容器中进行创建。Dockerfile文件的内容如下:

FROM redis:5.0.3
EXPOSE 6379
ADD redis.conf /redis.conf
ENTRYPOINT [ "redis-server", "/redis.conf" ]

然后当前目录就有两个文件了

使用命令行窗口进入到这个文件夹目录,执行docker build的指令

docker build -t "your image name" .

注意最后那个点,代表的是当前文件夹

创建好之后,用docker images 查看当前的镜像

可以发现镜像创建好了。为了使得不同的集群端口相互之间不冲突,自己创建一个network。

docker network create --subnet=172.10.0.0/16  redis1

创建了一个名为redis1的network。ip地址是虚拟的,可以随便写。只要是本地地址就可以了。
然后运行三个主节点和三个从节点

docker run -d --net redis1 --ip 172.10.0.91 -p 8001:6379 --name redis-test1 redis-cluster
docker run -d --net redis1 --ip 172.10.0.92 -p 8002:6379 --name redis-test2 redis-cluster
docker run -d --net redis1 --ip 172.10.0.93 -p 8003:6379 --name redis-test3 redis-cluster
docker run -d --net redis1 --ip 172.10.0.94 -p 8004:6379 --name redis-test4 redis-cluster
docker run -d --net redis1 --ip 172.10.0.95 -p 8005:6379 --name redis-test5 redis-cluster
docker run -d --net redis1 --ip 172.10.0.96 -p 8006:6379 --name redis-test6 redis-cluster

分别执行上面六条语句。开启六个redis节点。

然后在你的工作目录上再创建一个空文件夹,里面放入 redis-trib.rb ,这个文件在redis.x.x.x /src下面的,我今天就是在这个文件夹里面找这个文件没找到,花了俩小时才发现了它,藏得太好了,手动滑稽。然后在redis-trib.rb同目录下创建一个Dockerfile,用来构建ruby镜像,里面填入

FROM rubyADD redis-trib.rb /redis-trib.rb

保存之后,命令行窗口来到当前文件夹,执行

docker build -t "your image name" .

然后,查看当前的镜像,

ruby-redis创建好了,然后,在跟刚才运行的redis节点相同的network环境下执行:

docker run --net=redis1 --ip 172.10.0.100 --name ruby11 -i -d ruby-redis

这样就打开了ruby容器,docker exec -it ruby11(这里为你的容器的名字) /bin/bash 进入创建的容器。然后执行

gem install redis --version 3.0.7

用 --version 来指定特定版本的redis插件,然后执行

./redis-trib.rb  create --replicas 1  172.10.0.91:6379 172.10.0.92:6379 172.10.0.93:6379 172.10.0.94:6379 172.10.0.95:6379 172.10.0.96:6379




就可以了,可以看到所有的节点都打开了。
然后可以进行测试
分别打开六个cmd,然后进入到六个节点中

用redis-cli -c进入redis。然后在其中一个节点set一个值,在其他节点查看结果。如图:

在其他节点查看:

打开windows上面的客户端:

注意:

host既可以填写127.0.0.1也可以写Docker的ip:10.0.75.1。

注意,在windows for docker 上面,如果重启了操作系统,需要重启docker Desktop,否则docker与本机的socket会失效。导致本机无法连接到docker上。

如果想要每次重启docker 之后不需要手动重新打开各个容器,就在容器run 的时候加上 --restart=always。

docker for windows搭建基于docker 的redis分布式集群相关推荐

  1. Redis 分布式集群搭建2022版本+密码(linux环境)

    Linux环境 安装 Redis-6.2.6 配置运行_01 https://gblfy.blog.csdn.net/article/details/105583077 文章目录 一.节点分布总览 二 ...

  2. Linux 系列(三)——Redis 分布式集群搭建

     在Redis的安装和部署(Linux)一文中详细介绍了在Linux环境中搭建Redis服务,本文将介绍关于Redis分布式 集群搭建细节. 一.Redis集群架构 1.Redis集群架构图 蓝色 ...

  3. redis分布式集群环境搭建

    redis 分布式集群可分为主从集群.哨兵集群.分片集群,本片文章我们就来分别介绍这三种集群环境的搭建. 本次搭建环境为 Linux 虚拟机系统. 在搭建 redis集群之前,需要先在 linux 系 ...

  4. 硬核干货!Redis 分布式集群部署实战

    原理: Redis集群采用一致性哈希槽的方式将集群中每个主节点都分配一定的哈希槽,对写入的数据进行哈希后分配到某个主节点进行存储. 集群使用公式(CRC16 key)& 16384计算键key ...

  5. Redis 分布式集群的几种方案及问题

    1.Redis 分布式集群的几种方案 1.1.主从复制 从服务器连接主服务器,发送SYNC命令: 主服务器接收到SYNC命名后,开始执行BGSAVE命令生成RDB文件并使用缓冲区记录此后执行的所有写命 ...

  6. down redis集群_硬核干货!Redis 分布式集群部署实战

    原理: Redis集群采用一致性哈希槽的方式将集群中每个主节点都分配一定的哈希槽,对写入的数据进行哈希后分配到某个主节点进行存储. 集群使用公式(CRC16 key)& 16384计算键key ...

  7. redis 槽点重新分配 集群_5000+字硬核干货!Redis 分布式集群部署实战

    原理: Redis集群采用一致性哈希槽的方式将集群中每个主节点都分配一定的哈希槽,对写入的数据进行哈希后分配到某个主节点进行存储. 集群使用公式(CRC16 key)& 16384计算键key ...

  8. redis分片_5000+字硬核干货!Redis 分布式集群部署实战

    原理: Redis集群采用一致性哈希槽的方式将集群中每个主节点都分配一定的哈希槽,对写入的数据进行哈希后分配到某个主节点进行存储. 集群使用公式(CRC16 key)& 16384计算键key ...

  9. SpringBoot2.x整合Redis 分布式集群_01

    文章目录 一.节点分布总览 二.软件配置初始化 三.集群配置修改 3.1. redis-7002.conf 3.2. redis-7003.conf 3.3. redis-8001.conf 3.4. ...

最新文章

  1. 低代码技术与市场(Mendix与 OutSystems)
  2. COJ 1006 树上操作
  3. CALL注入--扫雷辅助(二)
  4. antd table动态表头_解决react使用antd table组件固定表头后,表头和表体列不对齐以及配置fixed固定左右侧后行高度不对齐...
  5. 第四章: 4.1 logging模块 | 正则表达式
  6. 负数的 %求余和取模
  7. python的哲学内容_python 哲学或者说文化
  8. XCL-Charts图表库中柱形图的同源风格切换介绍
  9. 软件项目中的成本构成及估算方法【转】
  10. macos 系统固件 路径_itunes下载固件在哪里 itunes下载固件位置【介绍】
  11. GBase 8s 入门
  12. 不花里胡哨看电脑主板支持最大内存与频率
  13. BufferedImage缩小图片大小
  14. 微博超话显示服务器有点累,刚才手机刷微博,刷新了一下首页... - @菜菜_fz 的微博精选 - 微博国际站...
  15. Apache Kylin Buid Cube详细流程2
  16. scrollTo函数处理页面滚动问题
  17. Java毕设项目线上教学平台(java+VUE+Mybatis+Maven+Mysql)
  18. 截屏工具、录屏工具不能用?是因为这个!!
  19. 2021年的谷歌排名优化怎么做,69个重点告诉你
  20. Java——MVC框架

热门文章

  1. springboot的starters原理
  2. 微软官方工具_微软官方生产力工具箱PowerToys复活,电脑一批软件可以卸载了
  3. PO发布RESTful接口
  4. 异步通信先,有效数据速率计算
  5. 前端解决移动端适配的五种方法
  6. Redis发布订阅模式实现原理
  7. mysql无法导出表解决方案
  8. Windows安装RabbitMQ教程
  9. 携程移动端架构演进与优化之路
  10. Chrome浏览器HTTP网站显示“不安全”问题