docker配置redis持久化

确认docker已安装并配置好redis

未配置redis可以参考docker配置redis

以下内容是在我自己学习过程中,自己做持久化。其实菜鸟教程上也有完整的安装以及配置教程。
redis默认持久化方式为RDB,RDB就是Snapshot快照存储,是默认的持久化方式。
本文用的是aof持久化方式,具体区别,可以

创建Dockerfile

因为我们以及创建完 目录 /root/redis 及 /root/redis/data/ 所以直接创建Dockerfile文件

1.进入redis目录,创建Dockerfile

    cd /root/redis/

    touch Dockerfile

2.修改Dockerfile内容如下:
data目录将映射为redis容器配置的/data目录,作为redis数据持久化的存储目录


FROM debian:jessie
# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get addedRUN groupadd -r redis && useradd -r -g redis redis

RUN apt-get update && apt-get install -y --no-install-recommends \

                ca-certificates \

                wget \

        && rm -rf /var/lib/apt/lists/*

# grab gosu for easy step-down from root

ENV GOSU_VERSION 1.7

RUN set -x \

        && wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)" \

        && wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc" \

        && export GNUPGHOME="$(mktemp -d)" \

        && gpg --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \

        && gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \

        && rm -r "$GNUPGHOME" /usr/local/bin/gosu.asc \

        && chmod +x /usr/local/bin/gosu \

        && gosu nobody true

ENV REDIS_VERSION 3.2.0

ENV REDIS_DOWNLOAD_URL http://download.redis.io/releases/redis-3.2.0.tar.gz

ENV REDIS_DOWNLOAD_SHA1 0c1820931094369c8cc19fc1be62f598bc5961ca

# for redis-sentinel see: http://redis.io/topics/sentinel

RUN buildDeps='gcc libc6-dev make' \

        && set -x \

        && apt-get update && apt-get install -y $buildDeps --no-install-recommends \

        && rm -rf /var/lib/apt/lists/* \

        && wget -O redis.tar.gz "$REDIS_DOWNLOAD_URL" \

        && echo "$REDIS_DOWNLOAD_SHA1 *redis.tar.gz" | sha1sum -c - \

        && mkdir -p /usr/src/redis \

        && tar -xzf redis.tar.gz -C /usr/src/redis --strip-components=1 \

        && rm redis.tar.gz \

        && make -C /usr/src/redis \

        && make -C /usr/src/redis install \

        && rm -r /usr/src/redis \

        && apt-get purge -y --auto-remove $buildDeps

RUN mkdir /data && chown redis:redis /data

VOLUME /data

WORKDIR /data

COPY docker-entrypoint.sh /usr/local/bin/

ENTRYPOINT ["docker-entrypoint.sh"]

EXPOSE 6379

CMD [ "redis-server" ]

3.修改redis配置文件redis.conf
具体aof持久化方式的配置详解,可以查看https://blog.csdn.net/xyw591238/article/details/51729044
本文启用aof持久化方式,其他默认,未修改

   appendonly yes

4.启动redis

docker run --privileged=true -p 192.168.31.131:6379:6379 -v /root/redis/data:/data -v /root/redis/conf/redis.conf:/etc/redis/redis.conf  --name myredis --restart=always -d redis redis-server /etc/redis/redis.conf --appendonly yes

这样基本就完事啦。

谢谢。。。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 在上一篇文章中,介绍了Redis内存模型,从这篇文章开始,将依次介绍Redis高可用相关的知识——持久化、复...
    Java架构阅读 2,348评论 3 21
  • 一、Redis高可用概述 在介绍Redis高可用之前,先说明一下在Redis的语境中高可用的含义。 我们知道,在w...
    空语阅读 1,609评论 0 2
  • 【本教程目录】 1.redis是什么2.redis的作者3.谁在使用redis4.学会安装redis5.学会启动r...
    徐猿猿阅读 1,880评论 0 35
  • 企业级redis集群架构的特点 海量数据 高并发 高可用 要达到高可用,持久化是不可减少的,持久化主要是做灾难恢复...
    lucode阅读 2,222评论 0 7
  • 1 Redis介绍1.1 什么是NoSql为了解决高并发、高可扩展、高可用、大数据存储问题而产生的数据库解决方...
    克鲁德李阅读 5,354评论 0 36