Docker 安装 Redis 单机&集群总结
前言
Redis 是一个开源的使用 ANSI C 语言编写、遵守 BSD 协议、支持网络、可基于 内存 、 分布式 、可选持久性的键值对( Key-Value )存储数据库
- redis版本:redis:6.2.13
- 作者:易墨
安装单机版
安装源:DockerHub
运行时指定配置文件
docker run -v /myredis/conf:/usr/local/etc/redis --name myredis redis redis-server /usr/local/etc/redis/redis.conf
局域网访问配置
#不限制IP访问,局域网能够访问
bind 0.0.0.0
#禁用保护模式
protected-mode no
设置密码:
requirepass devops666v6.0 后的版本增加了通过 ACL 的方式设置用户名密码
持久化:
appendonly yes启用后默认使用的 AOF(Append-Only File)持久化方式
compose.yml
version: '3.1'
services:
redis:
container_name: db_redis_6_2
image: redis:6.2.13
restart: always
command: redis-server /usr/local/etc/redis/redis.conf
volumes:
- ./data:/data
- ./config/redis.conf:/usr/local/etc/redis/redis.conf
ports:
- "6379:6379"
networks:
- devopsnetwork networks:
devopsnetwork:
external: true
redis.conf
#不限制IP访问,局域网能够访问
bind 0.0.0.0
#禁用保护模式
protected-mode no #端口
port 6379 #密码
requirepass devops666 #开启AOF日志 指定持久化方式
appendonly yes
安装成功,可以使用 dbeaver 连接查看
搭建 Redis 集群
Redis 集群是一种高可用、可水平扩展的 Redis 部署方式。它将 Redis 数据库分布在多个节点上,是为了提供高性能、高可用性和可伸缩性而设计的分布式 Redis 解决方案
需要注意的点
- 配置、管理和维护成本相对高
- 不支持多数据库,只能使用 0 数据库
- 不支持跨节点的事务操作
- 批量操作时支持有限,如数据不在一个节点,则会报错
- 在部署 Redis 集群模式时,至少需要六个节点组成集群才能保证集群的可用性。
集群规划
节点分配
- devops02:192.168.123.216
- devops03:192.168.123.219
- devops04:192.168.123.222
端口分配
- 6389: redis 访问端口
- 16389: 集群端口, 普通端口号加 10000,集群节点之间的通讯
不要设置密码,未找到节点间通信带密码的解决方案,-a password 只是主节点访问使用
集群的 redis 配置模板
#端口
port 6380 #是否开启 Redis 集群模式
cluster-enabled yes #设置 Redis 集群配置信息及状态的存储位置
cluster-config-file nodes.conf #设置 Redis 群集节点的通信的超时时间
cluster-node-timeout 5000
appendonly yes
daemonize no
protected-mode no
pidfile /data/redis.pid #主节点需要的最小从节点数,只有达到这个数,主节点失败时,它从节点才会进行迁移。
# cluster-migration-barrier 1 #设置集群可用性
# cluster-require-full-coverage yes
# 集群节点 IP,如果要外部访问需要修改为宿主机IP,如:192.168.123.216
# cluster-announce-ip 默认172.x.x.x
#客户端连接端口
#cluster-announce-port 6380
#节点间通信端口
#cluster-announce-bus-port 16380
docker compose.yml 配置模板
version: '3.1'
services:
redis:
container_name: cluster_redis_6380
image: redis:6.2.13
restart: always
command: redis-server /usr/local/etc/redis/redis.conf
volumes:
- ./data:/data
- ./config/redis.conf:/usr/local/etc/redis/redis.conf
ports:
- '6380:6380'
- '16380:16380'
集群部署
将上面的配置模板文件按下面的目录结构创建
- node-cluster
- redis-6380
- config
- redis.conf :需要配置模板中修改 port:6380
- compose.yml:需要配置模板中修改 container_name: cluster_redis_6380
- redis-6381
- config
- redis.conf :需要配置模板中修改 port:6381
- compose.yml:需要配置模板中修改 container_name: cluster_redis_6381
修改 redis.conf 中的 port
修改 compose.yml 中的 container_name: cluster_redis_6381
将 node-cluster 目录上传到准备的集群节点服务器:192.168.123.216,192.168.123.219,192.168.123.222
在服务器的对应目录中执行
docker compose up -d,确保容器正常运行
依托于创建的 redis 容器,使用下面的命令创建集群并添加节点
devops02=192.168.123.216
devops03=192.168.123.219
devops04=192.168.123.222
docker exec -it cluster_redis_6380 redis-cli -p 6380 --cluster create \
${devops02}:6380 \
${devops02}:6381 \
${devops03}:6380 \
${devops03}:6381 \
${devops04}:6380 \
${devops04}:6381 \
--cluster-replicas 1 \
--cluster-yes

连接集群测试(redis-cli)
docker exec -it cluster_redis_6380 redis-cli -p 6380 -c
- 查看集群信息:
cluster info - 查看集群节点信息:
cluster nodes 
- 本地连接测试:
redis-cli -h 192.168.123.216 -p 6380 -c 


至此,终于是一步步的创建好了 Redis 集群
集群外部访问问题
当 redis.conf 没有设置 cluster-announce-ip 时,使用redis-cli访问没有问题,但是会发现连接时访问节点会变成容器内部IP

导致的结果就是 使用一些Redis客户端连接会超时,无法使用。要解决这个问题,需要将每个节点的 redis.conf 中的 cluster-announce-ip 配置修改为其宿主机IP即可,可以这样做
新建对应文件夹及配置
复制对应IP文件夹到服务器再创建集群即可
工具连接测试
后语
假期结束,先是折腾了一会创建集群密码的问题,然后又是尝试各种连接工具,终于搞定了集群的安装,完美的假期。
Docker 安装 Redis 单机&集群总结的更多相关文章
- docker 安装redis cluster集群
安装Redis镜像 docker pull yyyyttttwwww/redis 创建redis容器 docker run -it -d --name r1 -p 5001:6379 --net=ne ...
- 使用docker安装部署Spark集群来训练CNN(含Python实例)
使用docker安装部署Spark集群来训练CNN(含Python实例) http://blog.csdn.net/cyh_24/article/details/49683221 实验室有4台神服务器 ...
- docker1.12 安装redis第三方集群方案 codis
docker1.12 安装redis第三方集群方案 codis
- Docker安装部署es集群
Docker安装部署es集群:环境准备:已安装docker的centos服务器一台1. 拉取es版本docker pull elasticsearch:5.6.82. 新建文件夹 数据挂载目录 和 配 ...
- docker安装Elasticsearch7.6集群并设置密码
docker安装Elasticsearch7.6集群并设置密码 Elasticsearch从6.8开始, 允许免费用户使用X-Pack的安全功能, 以前安装es都是裸奔.接下来记录配置安全认证的方法. ...
- 单台服务器-利用docker搭建Redis哨兵集群模式
前言:只有一台华为云服务器,所以打算创建三个容器来模拟三个服务器了. 一:拉取redis镜像 二:拉取redis.conf文件 放在自定义的目录下:wget -c http://download.re ...
- linux 安装redis和集群
一.安装redis单机 1.安装编译环境 Redis是c语言开发的. 安装redis需要c语言的编译环境.如果没有gcc需要在线安装.yum install gcc-c++ 2.安装步骤: 第一步:r ...
- Docker 搭建 Redis Cluster 集群环境
使用 Docker 搭建 Redis Cluster,最重要的环节就是容器通信的问题,这一块我们在之前的文章中已经给大家解决了<Docker 网络模式详解及容器间网络通信>,本篇文章主要练 ...
- CentOS7 安装Redis Cluster集群
上一篇中已经讲到了如何安装单击版Redis,这一篇我们来说下如何安装Cluster,关于哨兵模式这里我就不写文章安装了,有兴趣的同学可以自己去研究,哨兵模式可以在主从模式下在创建三台机器的哨兵集群监控 ...
- Centos6 安装 Redis 和集群配置
Redis安装 先确认gcc和tcl已经安装 sudo yum install gcc-c++ sudo yum install tcl 解压, 编译和安装 .tar.gz /usr/src/ cd ...
随机推荐
- 好的,以下是我为您拟定的自然语言处理(NLP)领域的100篇热门博客文章标题,以逻辑清晰、结构紧凑、简单易懂的
目录 1. 引言 2. 技术原理及概念 3. 实现步骤与流程 4. 应用示例与代码实现讲解 1. 机器翻译 2. 文本分类 3. 情感分析 5. 优化与改进 6. 结论与展望 好的,以下是我为您拟定的 ...
- 密码学概念科普(加密算法、数字签名、散列函数、HMAC)
密码散列函数 密码散列函数 (Cryptographic hash function),是一个单向函数,输入消息,输出摘要.主要特点是: 只能根据消息计算摘要,很难根据摘要反推消息 改变消息,摘要一定 ...
- Springcloud2021+Nacos2.2+Dubbo3+Seata1.6实现分布式事务
示例代码地址:https://gitee.com/gtnotgod/Springcloud-alibaba.git 更详细参考Gitee完整的项目:https://gitee.com/gtnotgod ...
- 介绍Vue router的history模式以及如何配置history模式
引言 Vue router给我们提供了两种路由模式,分别是hash模式和history模式.其中默认是使用hash模式,即URL中带有一个#符号,但是处于业务或个人喜爱的差别,Vue router也提 ...
- C++笔记(1)——类的基本概念知识
C#和C++的部分面向对象方式类似,只记录不同点. 定义类与关键字: 下面是C++类的定义方式与C++关键字public和private的表达方式: class Box { private: // 私 ...
- Redis的设计与实现(6)-压缩列表
压缩列表 (ziplist) 是列表键和哈希键的底层实现之一. 当一个列表键只包含少量列表项, 并且每个列表项要么就是小整数值, 要么就是长度比较短的字符串, 那么 Redis 就会使用压缩列表来做列 ...
- fread()模板
char buf[1<<20],*p1,*p2;#define GC (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<20,stdin ...
- IRF技术介绍及配置介绍
IRF技术介绍及配置介绍 IRF(Intelligent Resilient Framework,智能弹性架构)是 H3C 自主研发的软件虚拟化技术. 它的核心思想是将多台设备通过 IRF 物理端口连 ...
- html标签tr td是什么意思
<table>代表表格</table><tr>代表表格中的一行</tr><td>代表表格中的一列</td>'tr'与'td'交成 ...
- SpringBoot3之Web编程
标签:Rest.拦截器.swagger.测试; 一.简介 基于web包的依赖,SpringBoot可以快速启动一个web容器,简化项目的开发: 在web开发中又涉及如下几个功能点: 拦截器:可以让接口 ...




