继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

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

ITMISS
关注TA
已关注
手记 347
粉丝 51
获赞 244

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/bashmkdir /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端口到宿主机的映射)


https://img3.mukewang.com/5d5e43150001004804680134.png

image.png



作者:拾荒猎人
链接:https://www.jianshu.com/p/2514ec929e4d

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP