Docker 安装 Redis
Docker 安装 Redis
方法一、docker pull redis:3.2
查找 Docker Hub上的 redis 镜像:
docker search redis
这里我们拉取官方的镜像,标签为3.2:
docker pull redis:3.2
等待下载完成后,我们就可以在本地镜像列表里查到 REPOSITORY 为 redis,标签为3.2的镜像:
docker images | grep redis
方法二、通过 Dockerfile 构建
创建Dockerfile
首先,创建目录redis,用于存放后面的相关东西:
mkdir -p ./redis ./redis/data
data 目录将映射为 redis 容器配置的 /data 目录,作为 redis 数据持久化的存储目录
进入创建的 redis 目录,创建Dockerfile:
FROM debian:jessie # add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added RUN 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" ]
通过Dockerfile创建一个镜像,替换成你自己的名字
docker build -t redis:3.2 .
使用 redis 镜像
运行镜像,生成容器
使用 docker run 命令运行镜像:
docker run --name my-redis -p 6379:6379 -v $PWD/data:/data -d redis:3.2 redis-server --appendonly yes
命令说明:
-p 6379:6379 : 将主机的 6379 端口映射到容器的 6379 端口
-v $PWD/data:/data : 将主机中当前目录下的 data 挂载到容器的 /data
redis-server --appendonly yes : 在容器执行 redis-server 启动命令,并打开 redis 持久化配置
查看容器启动情况
docker ps
连接、查看容器
使用 docker exec 命令执行redis-cli命令连接到刚启动的容器 my-redis:
docker exec -it my-redis redis-cli
在 redis 客户端执行简单命令,测试 redis 字符串的可用性:
SET key "miracle luna" GET key
在 redis 客户端执行简单命令,测试 redis 集合的可用性:
SADD urls "http://www.baidu.com" SADD urls "https://github.com" SMEMBERS urls SCARD urls
使用 exit 命令退出 my-redis 容器:
exit
PS:
参考:https://www.runoob.com/docker/docker-install-redis.html