kubernetes(二)之Docker容器及镜像

容器及镜像

容器

常见的容器状态

  • running
  • stopped
  • paused
  • created
  • deleted

注意: 查看docker状态使用的命令:html

  • docker ps: 查看running状态的容器
  • docker ps -a: 查看全部状态的容器
  • docker ps -qa: 查看全部容器ID
  • docker stop $(docker ps -qa) : 中止全部容器
  • docker rm $(docker ps -qa) : 删除全部容器

docker run 命令的使用

常见的选项介绍:node

--name : 指定容器名称
-i : 交互式运行和-t一块儿使用,能够合成-it使用
-t: 容许tty
-e : 设置容器启动的环境变量,例如mysql的容器启动须要指定-e MYSQL_ROOT_PASSWORD='12345'
-d: detach,后台运行
--network: 指定网络
--restart: always,
-p: 端口映射
-v: 指定存储卷
--rm : 运行以后删除,须要与-it配合使用,可是与-d互斥
-m : 限制最大使用内存
--oom-kill-disable :禁止oom
--cpus : 限定使用的CPU容量mysql

[root@centos7-node1 ~]# docker run --name redis -d redis:4-alpine

docker exec的使用

常见的选项介绍:linux

-d : 后台运行
-e : 指定环境变量
-it: 交互模式
-u: 指定用户
-w: 指定工做路径nginx

[root@centos7-node1 ~]# docker container exec redis netstat -tanlp    #对容器执行命令
[root@centos7-node1 ~]# docker exec -it redis /bin/sh 
/data # redis-cli    #客户端链接redis
127.0.0.1:6379> set hello my_name_is_wanghui
OK
127.0.0.1:6379> get hello
"my_name_is_wanghui"

容器的启停

[root@centos7-node1 ~]# docker stop redis     # 未指定存储卷的状况下,中止容器以后数据会丢失
[root@centos7-node1 ~]# docker start redis

其余实践

[root@centos7-node1 ~]# docker image pull nginx:1.18-alpine
[root@centos7-node1 ~]# docker run --name web -it --rm nginx:1.18-alpine /bin/sh      #推出交互模式就自动退出并删除容器
[root@centos7-node1 ~]# docker run --name web -d nginx:1.18-alpine
[root@centos7-node1 ~]# docker container exec web ifconfig    #获取建立机器的ip
[root@centos7-node1 ~]# elinks -dump 172.17.0.3                     #访问页面
[root@centos7-node1 ~]# docker logs web -f                              #查看Nginx 滚动日志
[root@centos7-node1 ~]# docker stats web                                #查看web这个容器运行时资源占用状况
[root@centos7-node1 ~]# docker top web                                   #查看web这个容器的进程状态

[root@centos7-node1 ~]# docker run --name c2 -it centos:7
[root@f879de456c8d /]# 
[root@f879de456c8d /]# [root@centos7-node1 ~]#     `ctrl+p,ctrl+q`
[root@centos7-node1 ~]# docker ps    #c2是运行状态的
[root@centos7-node1 ~]# docker attach c2     #进入容器

镜像

简介

docker镜像含有启动容器时所须要的文件系统及其内容,所以,其用于建立并启动容器web

  • 采用分层构建机制,最底层为bootfs,其次为rootfs
    • bootfs: 用于系统引导的文件系统,包括bootloader和kernel,容器启动完成后会被卸载,以此节约内存资源
    • rootfs: 位于bootfs之上,表现为docker容器的根文件系统
      • 传统模式中,在系统启动时,内核挂载rootfs时会首先挂在为只读模式,完整性比肩完成以后从新挂载为读写模式
        • docker中,rootfs由内核挂载为只读模式,然后经过联合挂载技术,额外在挂载一个可写层

docker镜像的构建方式

  • 位于下层的镜像称为父镜像,最底层的是基础镜像
  • 最上层为“可读写”层,其下的均为“只读”层

kubernetes(二)之Docker容器及镜像

镜像存放的graph driver类型(文件系统)

特色: 分层叠加,写时复制(COW)
此文件系统是建构在底层操做系统文件系统之上用于存放镜像的文件系统,建议底层支持操做系统务必使用xfs文件系统
分类以下:redis

  • Aufs: 高级多层统一文件系统
  • Overlay2
  • DeviceMapper(DM)
    kubernetes(二)之Docker容器及镜像

    Aufs

  • 用于为Linux文件系统实现联合挂载
  • aufs以前是unionFS的从新实现,2006年由Junjiro Okjima开发
  • docker最初使用aufs做为容器文件系统层,目前仍然做为存储后端之一来支持
  • aufs的竞品是overlayfs,后者在3.18内核以后开始,被合并到linux内核
  • docker的分层镜像,除了aufs,还支持btfs,devicemapper和vfs等
    • ubuntu下,docker默认的文件系统是aufs,而在cnetos7上,用的是devicemapper

Docker Registry

  • 启动容器时,docker daemon会试图从本地获取相关镜像,本地镜像不存在时,其将从Registry中下载该镜像并保存到本地
    kubernetes(二)之Docker容器及镜像

docker registry的分类

Registry用于保存docker镜像,包括景象的层次结构和元数据
用户能够自建Registry,也能够使用官方的dockerhubsql

  • 分类以下:
    • Sponsor Restory:第三方的registry,供客户和docker社区使用
    • Mirror Registry:第三方的registry,只供客户使用
    • Vendor Registry: 由发布Docker镜像的供应商提供的Registry
    • Private Registry:经过舍友防火墙和额外安全层的私有实体提供的Registry

Docker Registry的组成

  • Repostorydocker

    • 由特定的docker镜像的全部迭代版本组成的镜像仓库
    • 一个registry能够存在多个Repostory
      • Registory能够分为顶层仓库用户仓库
      • 用户仓库名称更是为用户名/仓库名
    • 每一个仓库能够包含多个Tag,每一个Tag只对应一个镜像
  • Index: 维护用户帐户,镜像的校验以及公共命名空间信息,至关于为Registry提供了一个拥护认证和检索的接口

镜像的制做 与推送

docker registry中的镜像由开发或者运维人员制做,然后推送到“公共”或者“私有”Repostry上保存,供其余人使用
例如: 部署到生产环境ubuntu

kubernetes(二)之Docker容器及镜像

DockerHub的使用

  • 注册DockerHub帐户
  • 建立myimg仓库
  • 上传镜像到dockerHub的myimg仓库
[root@centos7-node1]# docker pull busybox:latest
[root@centos7-node1 ~]# docker run --name b1 -it -d busybox /bin/sh
/ # mkdir /data/web/html -p
/ # echo "<h1>this is a test page @busyboxServer</h1>" > /data/web/html/index.html
[root@centos7-node1 ~]# docker container commit b1 wanghui122725501/myimg:v0.1   #另起终端打包镜像
[root@centos7-node1 ~]# docker images    #查看镜像
REPOSITORY TAG IMAGE ID CREATED SIZE
wanghui122725501/myimg v0.1 baf6ad6a846f About a minute ago 1.22MB
[root@centos7-node1 ~]# docker run --name mybbox1 -it wanghui122725501/myimg:v0.1    #运行容器
/ # ls /data/web/html/     #此文件已被写入文件系统
[root@centos7-node1 ~]# docker login    #登录dockerhub
[root@centos7-node1 ~]# docker push wanghui122725501/myimg:v0.1    #推送镜像
[root@centos7-node1 ~]# docker container commit -p -a "wanghui@yeecall.com" -c "CMD ['/bin/httpd -f -h /data/web/html']" b1 wanghui122725501/myimg:v0.2   #前台运行httpd
[root@centos7-node1 ~]# docker tag wanghui122725501/myimg:v0.2 wanghui122725501/myimg:latest
[root@centos7-node1 ~]# docker push wanghui122725501/myimg:v0.2             #镜像推送
-----另起终端,进入b1容器
[root@centos7-node1 ~]# docker exec -it b1 sh
/ # /bin/httpd -f -h /data/web/html/                  #执行httpd
[root@centos7-node1 ~]# curl 172.17.0.5    #另起终端执行
<h1>this is a test page @busyboxServer</h1>
[root@centos7-node1 ~]# docker commit -p -a "wanghui@yeecall.com" -c 'CMD ["/bin/sh","-c","/bin/httpd -f -h /data/web/html"]' b1 wanghui122725501/myimg:v0.4
[root@centos7-node1 ~]# docker run --name mytinyweb2 -d wanghui122725501/myimg:v0.4
相关文章
相关标签/搜索