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