使用DockerCompose安装Redis

2024-04-14 19:52

本文主要是介绍使用DockerCompose安装Redis,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文使用docker-compose的方式安装Redis,如何未安装docker-compose,可以参考这篇文章进行安装【在Ubuntu上安装Docker Compose】

一、创建一个DockerCompose配置文件

第一步:创建相关目录文件
为了更好的组织管理Docker容器的配置文件和映射数据,这里我习惯在根目录下创建一个docker目录进行管理;

sudo mkdir /docker /docker/docker-compose /docker/redis

第二步:修改/docker目录的所以权给当前用户
如果你就只有root用户的话,不用执行这步;

sudo chown -R $USER /docker

第三步:编写redis的DockerCompose配置文件

cd /docker/docker-compose/
vim redis.yml

写入以下内容

version: '3' 
services:redis: # 定义名为 redis 的服务image: redis:6.2.14 # 使用 Redis 版本为 6.2.14 的 Docker 镜像container_name: redis-6379 #容器的名称ports:- 6379:6379 # 将容器内的 6379 端口映射到主机的 6379 端口(左边的6379是主机的端口)volumes:- /docker/redis/redis.conf:/usr/local/etc/redis/redis.conf # 将主机上的 Redis 配置文件挂载到容器内的相应位置- /docker/redis/data:/data # 将主机上的 Redis 数据目录挂载到容器内的 /data 目录- /docker/redis/logs:/var/log/redis # 将主机上的 Redis 日志目录挂载到容器内的 /var/log/redis 目录command: redis-server /usr/local/etc/redis/redis.conf # 容器启动时执行的命令restart: always # 容器的重启策略

最终的目录结构如下:
目录结构

二、创建redis的配置文件

cd /docker/redis/
touch redis.conf #创建一个空白的配置文件即可,后续要配置再修改即可。

因为我们在redis.yml里配置了- /docker/redis/redis.conf:/usr/local/etc/redis/redis.conf 进行映射,所以之后可以直接在/docker/redis/redis.conf进行配置,然后重启容器即可。
以下是我的redis.conf

# 配置密码
requirepass tiger
# 开启aof
appendonly yes
# aof文件名
appendfilename "appendonly.aof"
# aof记录的策略
appendfsync always
# appendfsync everysec
# appendfsync no

注意:容器启动时需要会加载aof、rdb等文件,默认会存在容器内的/data路径里。容器里的redis配置和物理主机上安装redis配置有点不一样,不能随意配置“dir /var/lib/redis ”去指定持久化文件的路径,否则会启动redis容器不成功,用“docker logs 容器名”查看就会知道是加载文件时没有权限!

三、启动redis容器

docker-compose -f /docker/docker-compose/redis.yml up -d

由于docker-compose启动时,默认会找当前路径下的docker-compose.yml,所以我们要用-f去指定要执行的配置文件;up 是启动命令;-d 表示后台执行。

如果因为网络原因执行失败,可以参考这篇文章修改镜像【docker更换镜像源】。

在这里插入图片描述

这篇关于使用DockerCompose安装Redis的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/903867

相关文章

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C