base操作系统镜像: centos7.4
私有仓库的创建
建立私有仓库是便于构建私有的镜像,而且存储在本地,在进行拉取时,提高效率。
建立私有仓库的基本方法:
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 指定容器的名称
在网络不给力的情况下,本地源码安装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端口到宿主机的映射)
image.png
作者:拾荒猎人
链接:https://www.jianshu.com/p/2514ec929e4d
共同学习,写下你的评论
评论加载中...
作者其他优质文章