手写redis的docker文件,通过docker-compose配置redis

在前面一遍随笔,配置的是mysql主从的docker-compose配置。今天我们来学习配置编排容器redis。

准备环境:

docker 18.06.1-ce

docker-compose 1.23.0-rc3

redis最新版

开始:

1、首先我们创建下docker文件的目录,并新建Dockerfile、redis-entrypoint.sh、redis.conf

如下图:

Dockerfile文件内容如下:

FROM redis:latest        #指定启动容器的镜像

MAINTAINER cc <cc@qq.com>  #署名

RUN mkdir -p /redis/log;   #在容器里运行创建目录/redis/log

WORKDIR /redis     #设置工作目录为/redis

COPY redis.conf .  #拷贝redis.conf配置文件到工作目录(这里其实就是在Dockerfile同级下的redis.conf文件拷贝到容器内当前工作目录,也就是/redis目录)
COPY redis-entrypoint.sh /usr/local/bin/ #拷贝redis.entrypoint.sh 到容器内/usr/local/bin/目录下

RUN chown redis:redis /redis/* && \   #给容器内的/redis/*设置归属用户,并设置redis.entrypoint.sh文件的可执行权限
    chmod +x /usr/local/bin/redis-entrypoint.sh

EXPOSE 6379       #暴露端口6379

CMD ["redis-entrypoint.sh"]  #执行redis-entrypoint.sh文件

redis.conf内容如下:

#修改daemonize为yes,即默认以后台程序方式运行(还记得前面手动使用&号强制后台运行吗)。
daemonize no
#可修改默认监听端口
port $REDIS_PORT
#修改生成默认日志文件位置
logfile "/redis/log/redis.log"
#配置持久化文件存放位置
dir "/tmp"
requirepass $REDIS_PASSWORD

redis-entrypoint.sh内容如下:

#!/usr/bin/env sh

sed -i "s/\$REDIS_PORT/$REDIS_PORT/g" /redis/redis.conf   #声明参数,为了docker-compose里面可以动态配置
sed -i "s/\$REDIS_PASSWORD/$REDIS_PASSWORD/g" /redis/redis.conf  #声明参数

redis-server /redis/redis.conf

到这步,我们就以及把redis的所有配置都准备好了,接下来在Dockerfile的目录,执行脚本,生成redis镜像文件

2、生成docker 镜像文件

docker build -t iqeq/redis:1.0 .   # 生成了一个iqeq/redis:1.0的镜像文件

3、编排docker-compose文件

version: ‘3‘  #版本号

services:
redis:
container_name: redis_container  #容器名,自定义
image: iqeq/redis:1.0   #刚才生成的镜像名
environment:            #环境参数:配置刚才shell启动脚本里面声明的2个参数
- REDIS_PORT=6379
- REDIS_PASSWORD=密码
ports:                  #暴露容器内部端口6379并映射到外部也为6379
- "6379:6379"
restart: unless-stopped   #启动方式
volumes:
- $PWD/redis/data:/data     #文件绑定挂载:$PWD表示当前目录,然后这里就是当前目录下的/redis/data子目录,挂载为容器内的/data目录
- $PWD/redis/log:/redis/log

然后保存文件为docker-compose.yml

4、查看下我们整个工作的目录结构

写的不是很好,制作的时候,特别要注意的目录要相对应的配对哈。

最后:

我们在docker-compose.yml的同级目录下,执行以下脚本:

docker-compose up -d

成功启动。

原文地址:https://www.cnblogs.com/contraII/p/10017798.html

时间: 2024-08-29 18:36:20

手写redis的docker文件,通过docker-compose配置redis的相关文章

阿里微服务专家手写Spring Boot 实现一个简单的自动配置模块

为了更好的理解 Spring Boot 的 自动配置和工作原理,我们自己来实现一个简单的自动配置模块. 假设,现在项目需要一个功能,需要自动记录项目发布者的相关信息,我们如何通过 Spring Boot 的自动配置,更好的实现功能呢? 实战的开端 – Maven搭建 先创建一个Maven项目,我来手动配置下 POM 文件. 参数的配置 - 属性参数类 首先,我们定义一个自定义前缀,叫做 custom 吧.之前说到,这里的配置参数,可以通过 application.properties 中直接设置

reportviewer在web端手写代码导出excel文件

private void Page_Load(object sender, System.EventArgs e) { this.rdlViewer.ProcessingMode = ProcessingMode.Local; this.rdlViewer.LocalReport.ReportPath = @"d:\Group+Process+by+Steps+(+Open+)+report.rdl"; } protected void Button1_Click(object sen

redis 数据库在linux下的安装配置与使用

linux安装redis 完整步骤(1)安装: 1.获取redis资源 wget http://download.redis.io/releases/redis-4.0.8.tar.gz 2.解压 tar xzvf redis-4.0.8.tar.gz 3.安装 cd redis-4.0.8 make cd src make install PREFIX=/usr/local/redis 4.移动配置文件到安装目录下 cd ../ mkdir /usr/local/redis/etc mv re

suse 配置redis远程访问

1.在redis.conf配置文件中配置requirepass的密码(当redis重启时密码依然有效). # requirepass foobared (480行) 如  修改成 :requirepass  a123456 2.[[email protected]]# ./redis-cli redis 127.0.0.1:6379> redis 127.0.0.1:6379> config get requirepass1) "requirepass"2) (nil) 显

docker 构建带健康检查的redis镜像

=============================================== 2018/11/5_第1次修改                       ccb_warlock =============================================== 由于希望引入docker的健康检查,即对不健康容器的策略(如果容器进入 unhealthy 状态,它会停止容器并且重新启动一个新容器来取代它),故根据官方给出的脚本进行修改后构建出带健康检查的redis镜像.

docker 配置redis主从配置 集群 正式部署

转至 平凡的学生族发表于后端技术 在这篇文章中: 前言 环境 目录 0.确立计划 1. 运行master容器 2. 编写redis.conf 3. 解决WARNING THP 4. 解决WARNING somaxconn 5. 最终的docker run 最后 参考 前言 在正式部署前,你可以先阅读前置准备,对部署过程中用到的docker.redis操作和配置有一个理解,以防在自己电脑上复现时出错. 我们将在一台windows10机器上运行多个docker容器,配置Redis主从集群. 环境 宿

DOCKER简明教程 : 通过容器连接REDIS数据库

序言 本文重点讲解了如何通过Redis的官方镜像和Docker容器来搭建redis-cli,并将其连接到Redis镜像.首先要跟大家简单介绍一下Redis,这是一个键值存储系统,除了对场景进行缓存之外,Redis还提供了很多强大的功能,因此也目前是非常受欢迎的一个数据库. Docker镜像仓库简介 大家可以在Docker Hub里搜索到目前所有的主流应用和服务的镜像,像Python语言.MySQL数据库等等镜像在Docker Hub里面都有.而且Docker Hub里面的镜像数量非常多,不管我们

docker文件拷贝

向docker管理的"块"拷贝文件可以存在于三个时段(这里的块,可以指代镜像也可以指代运行实例.简单来说,即是docker管理的,程序员开发的,在容器中的东西) (1)镜像生成之前 (2)实例运行起来之后 实际操作 (1)镜像生成之前 即使用docker images 还不能查询到镜像时(一般是通过docker pull或docker build进行) (a)使用docker build命令可以通过编写Dockerfile,在其中使用COPY命令将指定目录下的文件.文件夹,组装容器.具

手写PE文件(二)

[文章标题]: 纯手工编写的PE可执行程序 [文章作者]: Kinney [作者邮箱]: [email protected] [下载地址]: 自己搜索下载 [使用工具]: C32 [操作平台]: win 7 [作者声明]: 只是感兴趣,没有其他目的.失误之处敬请诸位大侠赐教! ---------------------------------------------------------------------------------------------------------------