基于docker 搭建redis环境—redis单机版

base操作系统镜像: centos7.4

  1. 私有仓库的创建
    建立私有仓库是便于构建私有的镜像,而且存储在本地,在进行拉取时,提高效率。
    建立私有仓库的基本方法:
    docker run -d -v /home/docker/registry:/var/lib/registry -p 5000:5000 --restart=always --privileged=true --name registry registry:latest

 -v /home/docker/registry:/var/lib/registry 默认情况下,会将仓库存放于容器内的/var/lib/registry目录下,指定本地目录挂载到容器。
 -p 5000:5000 端口映射
 --restart=always1 在容器退出时总是重启容器,主要应用在生产环境
 --privileged=true 在CentOS7中的安全模块selinux把权限禁掉了,参数给容器加特权,不加上传镜像会报权限错误OSError: [Errno 13] Permission denied: ‘/tmp/registry/repositories/liibrary’)或者(Received unexpected HTTP status: 500 Internal Server Error)错误
 --name registry 指定容器的名称

  1. 在网络不给力的情况下,本地源码安装redis

l mkdir –p /home/docker/images/redis

l cd /home/docker/images/redis

l 下载redis源码

  wget   http://download.redis.io/releases/redis-3.2.10.tar.gz   

l 开始准备dockerfile,保存在/home/docker/images/redis目录中

    FROM localhost:5000/centos:7.4  #已存在本地docker镜像
    COPY redis-3.2.10.tar.gz /tmp
    RUN yum -y install make gcc libgcc gcc-c++ glibc-devel && \
            tar –zxvf redis-3.2.10.tar.gz &&\
        cd redis-3.2.10 && \
        make MALLOC=libc && \
        make install

  COPY redis_init_script /etc/init.d/redisd  #制作redis启动脚本
  COPY docker-entrypoint.sh /usr/bin/    # 制作docker容器启动脚本
  
  //ENV and CMD 配置容器默认启动脚本和开放6379端口
  CMD ["/usr/bin/docker-entrypoint.sh"]
  EXPOSE 6379      #放开redis 端口

 准备docker 启动脚本docker-entrypoint.sh

#!/bin/bash
mkdir /etc/redis
sed -i 's/^bind 127.0.0.1/# bind 127.0.0.1/g' /etc/redis.conf
sed -i 's/^protected-mode yes/protected-mode no/g' /etc/redis.conf

//以上两步作用是监听所有ip地址,并且去掉保护模式运行,否则只能是本机//连接redis,网络连接redis,读写数据时,将报错:
//(error) DENIED Redis is running in protected mode because protected mode is //enabled

cp /etc/redis.conf /etc/redis/6379.conf

#this shell main function
/etc/init.d/redisd  start-foreground
# 此处没有使用systemctl 命令启动,是由于在docker容器中,使用systemctl
#会报错:Failed to get D-Bus connection: Operation not permitted
#要解决此问题也可以解决:在docker容器启动的时候执行/usr/sbin/init脚本,#但是这样进入容器时,需要输入root 用户名与密码,比较麻烦。所以此处就
#使用这种方式。

 准备redis 启动脚本
Redis启动脚本,在源码包就已有redis_init_script,把它拷到/etc/init.d/, 重命名为redisd,再进行下修改:

#!/bin/sh
#
# Simple Redis init.d script conceived to work on Linux systems
# as it does use of the /proc filesystem.

REDISPORT=6379
EXEC=/usr/bin/redis-server
CLIEXEC=/usr/bin/redis-cli

PIDFILE=/var/run/redis_${REDISPORT}.pid
CONF="/etc/redis/${REDISPORT}.conf"

case "$1" in
    start)
        if [ -f $PIDFILE ]
        then
                echo "$PIDFILE exists, process is already running or crashed"
        else
                echo "Starting Redis server..."
                $EXEC $CONF      #这里是修改过的,如果redis.conf 设置了daemonize yes 为后台运行,此处必须改为前台运行,daemonize no,负责docker运行的话会闪退。
        fi
        ;;
    stop)
        if [ ! -f $PIDFILE ]
        then
                echo "$PIDFILE does not exist, process is not running"
        else
                PID=$(cat $PIDFILE)
                echo "Stopping ..."
                $CLIEXEC -p $REDISPORT shutdown
                while [ -x /proc/${PID} ]
                do
                    echo "Waiting for Redis to shutdown ..."
                    sleep 1
                done
                echo "Redis stopped"
        fi
        ;;
//增加了段重启命令
    restart)
        $0 stop
        $0 start
        ;;
    *)
        echo "Please use start or stop or restart as first argument"
        ;;
esac

 构建redis镜像

Docker build –t localhost:5000/redis:3.2.10

 运行redis docker镜像

docker run –d –name redis –p 6380:6379 localhost:5000/redis:3.2
后台运行容器

 测试redis运行是否正常
在宿主机上使用redis-cli进行远程连接
redis-cli -h 127.0.0.1 -p 6380 (6380是容器内的6379端口到宿主机的映射)


image.png

你可能感兴趣的:(基于docker 搭建redis环境—redis单机版)