为了账号安全,请及时绑定邮箱和手机立即绑定

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

标签:
Docker

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


webp

image.png



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


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消