手记

Docker学习笔记 - 第四篇:镜像仓库

最近疫情闹的,在家温习之前在私塾在线买的cc老师的课程Docker,为了加深印象及鞭策一下自己换高薪工作,坚持做系列笔记,记录自己成长的点点滴滴。不过看到消息cc老师最新一期的高级架构师课程也要推出了,里面包含了现在主流的架构,以及最新的技术,据说从理论到运用全部带着做,像现在面试常用的 Netty, Redis, Kafka,Zookeeper, Dubbo, Nginx + openResty + kong + Lua, ElasticSearch等技术都深入源码层级

1 Docker仓库

1.1 简介

官方Docker Hub地址:https://hub.docker.com/

1.2 搭建私有仓库

1:下载镜像:docker pull registry

2:启动Docker Registry容器

   docker run -d -p 5000:5000 -v /ccuse/myregistry/:/tmp/registry --privileged=true registry

3:查看Docker Registry进程:docker ps

1.3 私有仓库基本操作

1:查看Registry仓库中现有的镜像

   curl -XGET http://192.168.1.111:5000/v2/_catalog

2:将Docker镜像推到Registry中

  • 给本地镜像打Tag

       docker tag cctomcat9 192.168.1.111:5000/cctomcat9test
    
  • 推送镜像到Registry中

     docker push 192.168.1.111:5000/cctomcat9test
    

    会出现错误,因为client与Registry交互默认将采用https访问,但我们在安装Registry时并未配置指定相关的key和crt文件,https将无法访问

  • 在/etc/sysconfig/docker中做配置:

     ADD_REGISTRY='--add-registry 192.168.1.111:5000’
    
     INSECURE_REGISTRY=‘--insecure-registry 192.168.1.111:5000’
    
     然后重启docker服务:
    
     service docker restart
    
     然后重新推送镜像到仓库中。
    

1.4 配置Docker Registry管理界面

Docker官方只提供了REST API,并没有给我们一个界面。 可以下载镜像“hyper/docker-registry-web”来进行镜像的管理。
具体的运行和使用,请参见官方文档:https://hub.docker.com/r/hyper/docker-registry-web/
默认的只是浏览仓库中的镜像,如果要删除的话:

  • 要创建一个给registry用的config.yml,在里面设置可以delete,形如:
version: 0.1
log:
  level: info
  formatter: text
  fields:
    service: registry-srv
    environment: production
storage:
  cache:
    layerinfo: inmemory
  filesystem:
    rootdirectory: /tmp/registry
  delete:
    # 要在 ui 上能够删除镜像,enable 的值必须是 true
    enabled: true
http:
  addr: :5000
  • 创建一个给registry-web用的config.yml,这个官方网站上有

  • 重新启动registry,如:

    docker run -d -p 5000:5000 --name registry-srv -v /ccuse/myregistry/registryconf/:/etc/docker/registry:ro -v /ccuse/myregistry/:/tmp/registry --privileged=true registry  
    
  • 重新启动registry-web,形如:

     docker run -it -d -p 8080:8080 --name registry-web --link registry-srv -v /ccuse/myregistry/forwebconf/config.yml:/conf/config.yml --privileged=true hyper/docker-registry-web  
    

2 使用MySql镜像

docker pull mysql
docker run --name mysql -p 12345:3306 -v /ccuse/programes/mysqldata:/var/lib/mysql --privileged=true  -e MYSQL_ROOT_PASSWORD=cc -d mysql

这里指定了使用自己的mysql数据文件

  • 使用自定义配置文件,在mysqlconf下放着my.cnf文件:

    docker run --name mysql -p 12345:3306 -v /ccuse/programes/mysqldata:/var/lib/mysql -v /ccuse/programes/mysqlconf:/etc/mysql/conf.d --privileged=true -e MYSQL_ROOT_PASSWORD=cc -d mysql

  • 使用自定义日志目录

     -v /ccuse/programes/mysqllogs:/var/log/mysql 
    

如果日志开启不成功,可能是因为 mysql用户没有对日志文件夹的操作权限,进入到容器里面,设置一下,示例如下:

chown -R mysql:mysql /var/log/mysql
  • 数据表备份

     docker exec 容器id sh -c 'exec mysqldump --all-databases -uroot -p"cc"' > /ccuse/all-databases.sql
    

3 使用Redis镜像

docker pull redis
docker run --name myredis -d redis,默认暴露6379端口
  • 如果想使用自己的配置文件启动redis,一种方法是在其基础上写一个dockerfile,例如:
 FROM redis
 COPY redis.conf /usr/local/etc/redis/redis.conf
 CMD [ "redis-server", "/usr/local/etc/redis/redis.conf" ]

另外一种方式是在启动命令中修改配置,如:

docker run -v /myredis/conf/redis.conf:/usr/local/etc/redis/redis.conf --name myredis redis redis-server /usr/local/etc/redis/redis.conf  

4:数据默认存储在VOLUME /data目录下,使用-v来指定挂载,如:

 docker run --name myreis -d -p 6379:6379 -v /redisdocker/data:/data -v /redisconf/redis.conf:/usr/local/etc/redis/redis.conf --privileged=true  redis redis-server /usr/local/etc/redis/redis.conf  

注意:自己写的conf文件里面,不要配置bind的ip,也不要daemonize的配置,直接注释掉

5:如果需要开启aof的持久化方式,默认是rdb的,可以在配置文件里面设置,也可通过命令行指定:

docker run --name some-redis -d redis redis-server --appendonly yes

6:如果应用需要连接redis:

docker run --name some-app --link some-redis:redis -d application-that-uses-redis

4 容器连接

4.1 简介

前面学习到的端口映射,并不是唯一把docker连接到另一个容器的方法。docker有一个连接系统允许将多个容器连接在一起,共享连接信息。docker连接会创建一个父子关系,其中父容器可以看到子容器的信息。
有时出于安全原因,可以强制docker只允许有连接的容器之间互相通信,可以在启动docker守护进程的时候,加上–icc=false,关闭没有连接的容器间通信。
在docker run的时候, 指定–link :标志创建了两个容器间的父子连接,这样容器就不用暴露端口了,大大增加安全性。

4.2 基本使用

基本语法:–link 要连接的容器的名字:这个连接的别名

  • 执行连接需要依靠容器的名字,因此创建每一个容器的时候,请使用–name来命名。

     注意:容器的名称必须是唯一的。如果想使用重复的名称来命名容器,需要使用docker rm命令删除以前的容器。
    
  • 被连接的容器必须运行在同一个Docker宿主机上

  • 示例:

    docker run --name db -e MYSQL_ROOT_PASSWORD=cc -d mysql
    docker run -d -p 9080:8080 --name web --link db:dblink cctomcat:9.0

  • 可以通过docker inspect查看里面的Links,如: “/db:/web/dblink”

4.3 启动常见错误解决方案

如果启动的时候,出现类似如下的错误:

COMMAND_FAILED: '/usr/sbin/iptables -w2 -t nat -A DOCKER -p tcp -d 0/0 --dport 9080 -j DNAT --to-destination 172.17.0.4:8080 ! -i docker0' failed:

这可能是网络问题造成,解决方法如下:

  • 首先先验证docker容器内部网络是否能ping通宿主机

     如果能ping通,即可通过重建docker0网络恢复
    
  • 先停掉宿主机上运行的docker容器,然后执行以下命令

    iptables -t nat -F
    ifconfig docker0 down
    brctl delbr docker0

  • 重启docker服务

如何使用容器连接来通信
最简单的方法就是在子容器里面,也就是web里面,直接使用link的别名来代替具体的host或者是ip地址,比如:

 jdbc:mysql://dblink:3306/mydb
0人推荐
随时随地看视频
慕课网APP