使用docker安装redis

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 该文档介绍了如何使用Docker快速搭建Redis数据库,以便于Spring Boot学习。主要内容包括获取Redis镜像、创建容器、配置持久化存储目录和修改默认配置文件,以及检查和访问Redis容器服务。此外,还提到若需外部访问,需开启宿主机防火墙相应端口。注意,本教程不深入讲解Docker,若想深入学习Docker,建议另寻专门课程。

本节的目的不在于去教大家理解docker容器(讲docker就脱离了我们课程的核心,我们的课程是Spring Boot 不是docker),而是希望通过docker的方式快速的为大家搭建一个redis数据库,从而方便大家学习使用,方便学习本章后续的内容。如果你想学好docker,你应该再去学另外的课程。

   如果你觉得docker安装redis对于你来说有困难,可以下载一个windows版本的redis安装,达到可以开始后续章节学习的目的即可。

准备工作

   首先要安装好docker。CentOS7如何安装docker方法在本文档的番外篇里面介绍

下面的安装过程如果看不懂,回头来看这个图理解一下。

一、获取 redis 镜像

如果你不熟悉docker,可以认为docker镜像是安装包。

   docker search redis

   docker pull redis:5.0.5

   docker images

其实更形象点的理解docker镜像和容器之间的关系,更像是Class类与对象之间的关系。一个类可以构造多个对象,一个镜像可以构造多个容器。类和镜像是实实在在存在的字节码文件;对象和容器是在系统内存里面,作为运行时状态存在。

二、创建容器

2.1.创建持久化存储目录

容器可以运行在内存里面,但是容器存储的数据需要进行持久化。所以在宿主机上创建redis 容器的数据和配置文件存储目录。

   # 这里我们在 /home/docker 下创建

   mkdir /home/docker/redis/{conf,data} -p

   cd /home/docker/redis

注意:后面所有的操作命令都要在这个目录/home/docker/redis下进行

2.2.获取 redis 的默认配置文件模版

   # 获取 redis 的默认配置模版

   # 这里主要是想设置下 redis 的 log / password / appendonly

   # redis 的 docker 运行参数提供了 --appendonly yes 但没 password

   wget https://gitee.com/hanxt/boot-launch/raw/master/src/main/resources/otherconfig/redis.conf -O conf/redis.conf

   

   # 直接替换编辑

   sed -i 's/logfile ""/logfile "access.log"/' conf/redis.conf;

   sed -i 's/# requirepass foobared/requirepass 123456/' conf/redis.conf;

   sed -i 's/appendonly no/appendonly yes/' conf/redis.conf;

   sed -i 's/bind 127.0.0.1/bind 0.0.0.0/' conf/redis.conf;

   

   sed -i是linux文件替换命令,替换格式为s/被替换的内容/替换之后的内容/

   替换logfile ""为logfile "access.log",指定日志文件名称为access.log

   替换# requirepass foobared为requirepass 123456,指定访问密码为123456

   替换“appendonly no“为”appendonly yes”,开启appendonly模式

   替换绑定IP“bind 127.0.0.1”为“bind 0.0.0.0”

   protected-mode 是在没有显式定义 bind 地址(即监听全网段),又没有设置密码 requirepass时,protected-mode 只允许本地回环 127.0.0.1 访问。所以改为bind 0.0.0.0

2.3.使用镜像创建一个容器

创建并运行一个名为 myredis 的容器,放到start-redis.sh脚本里面

   # 创建并运行一个名为 myredis 的容器

   docker run \

   -p 6379:6379 \

   -v $PWD/data:/data \

   -v $PWD/conf/redis.conf:/etc/redis/redis.conf \

   --privileged=true \

   --name myredis \

   -d redis:5.0.5 redis-server /etc/redis/redis.conf

   

   # 命令分解

   docker run \

   -p 6379:6379 \ # 端口映射 宿主机:容器

   -v $PWD/data:/data:rw \ # 映射磁盘目录 rw 为读写,宿主机目录:容器目录

   -v $PWD/conf/redis.conf:/etc/redis/redis.conf:ro \ # 挂载配置文件 ro 为readonly

   --privileged=true \ # 给与一些权限

   --name myredis \ # 给容器起个名字

   -d redis redis-server /etc/redis/redis.conf # deamon 运行容器 并使用配置文件启动容器内的 redis-server  

   $PWD是当前目录,也就是/home/docker/redis

2.4.查看活跃的容器

   # 查看活跃的容器

   docker ps

   # 如果没有 myredis 说明启动失败 查看错误日志

   docker logs myredis

   # 查看 myredis 的 ip 挂载 端口映射等信息

   docker inspect myredis

   # 查看 myredis 的端口映射

   docker port myredis

三、访问 redis 容器服务

安装好之后,可以进行访问测试

   docker exec -it myredis bash

   redis-cli

上面的测试是在宿主机内访问docker容器。如果在宿主机上可以访问到redis服务,在宿主机之外的主机无法访问该redis服务的话,可能是因为宿主机的防火墙没有打开。参考下面的做法。

四、开启防火墙端口,提供外部访问

开启docker容器所在的宿主机端口,提供给外部服务进行访问

   firewall-cmd --zone=public --add-port=6379/tcp --permanent

   firewall-cmd --reload

   firewall-cmd --query-port=6379/tcp


相关文章
|
3月前
|
关系型数据库 应用服务中间件 nginx
Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)
本系列脚本提供RocketMQ、Nginx、MySQL、MinIO、Jenkins和Redis的Docker一键安装与配置方案,适用于快速部署微服务基础环境。
|
28天前
|
关系型数据库 数据库 PostgreSQL
docker 安装 Postgres 17.6
本文介绍如何通过Docker安装和配置PostgreSQL 17.6。内容包括拉取镜像、导出配置文件、运行容器并挂载数据与配置文件目录,以及进入容器使用psql操作数据库的完整步骤,便于持久化管理和自定义配置。
161 3
docker 安装 Postgres 17.6
|
9天前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
134 5
kde
|
11天前
|
存储 NoSQL Redis
手把手教你用 Docker 部署 Redis
Redis是高性能内存数据库,支持多种数据结构,适用于缓存、消息队列等场景。本文介绍如何通过Docker快速拉取轩辕镜像并部署Redis,涵盖快速启动、持久化存储及docker-compose配置,助力开发者高效搭建稳定服务。
kde
305 7
|
9天前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
113 1
|
5月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
1月前
|
存储 缓存 NoSQL
Redis专题-实战篇二-商户查询缓存
本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
125 1
Redis专题-实战篇二-商户查询缓存
|
16天前
|
缓存 负载均衡 监控
135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。