docker学习 - docker启动和镜像

docker daemon启动

载体为daemon,调度管理engine,任务执行靠job
Engine是map[string]Handler,type Handler func(*Job) Status

Daemon的启动流程:

  • 注册serve job、pull job、create job、start job等
  • 构建serveapi job,并执行ServeApi handler,创建支持多种协议请求(tcp/socker fd/默认unix socket)的http Server,支持TLS,包含http路由规则”POST”:{“/images/create”: postImagesCreate}
  • 初始化graphdriver、graphdb、 graph.TagStore、 execdriver、volumedriver、daemon网络环境
  • 构建init_networkdriver job,创建docker0网桥,配置iptables对容器发出的数据包做snat地址转换,是否开启容器间的通信

镜像下载

Docker pull Ubuntu:14.04
Docker client流程

  • 解析命令行获取镜像名和register地址,反射机制调用DockerCli.CmdPull,从dockercfg中读出用户认证信息,构建RESTful请求/images/create

Docker server流程

  • http路由规则对应执行postImagesCreate,从url中解析出镜像名、register地址和用户认证信息,执行pull job与registry建立session
    Session包含认证信息和主机环境信息的http请求的工厂模式,需要和register发起多次请求

和docker register的通信

  • 请求获取指定镜像名的image所有tag信息,存到RepositoryData中
  • 获得下载镜像的image_id后,通过TagStore.pullingPool检查是否该镜像正在下载,map[string]chan struct{}
  • 请求获取指定image_id的所有parent的image_id
  • 对每个待下载的image_id,通过graph.idIndex检查是否在本地的镜像仓库graph中
  • 请求获取该image_id的image json和大小信息,构建Image对象
  • 请求获取该image_id的内容
  • 在graph文件系统aufs/overlayfs存储image

配置TagStore

  • 将下载的所有image_id都写入TagStore.Repositories中
  • TagStore持久化到path.Join(config.root, “repositories-{graphfs}”)

镜像存储

注册到Graph中(aufs)

  • aufs在layers/diff/mnt中创建image_id目录layers保留每个镜像的所有祖先镜像列表diff存储每个镜像layer的内容mnt该层镜像上挂载的可读写layer
  • Union mount先以只读方式mount该镜像的所有祖先镜像的diff目录到该镜像的mnt目录,再以读写方式mount该镜像的diff目录到其mnt目录
  • 将压缩的镜像内容(http body)解压到layer目录,通过文件流开头的10字节来判断文件类型,文件流封装在ProcessReader带进度条的文件流
  • path.Join(Graph.root, image_id)中保留image json和文件大小的layersize文件
  • 注册镜像id,idIndex是基数树/前缀树image_id由64位字符组成
时间: 2024-10-25 02:53:52

docker学习 - docker启动和镜像的相关文章

docker学习 - docker run

docker run流程 创建容器 通过用户指定的镜像名和tag,在TagStore中查找image_id,获取image对象(本地的image json文件里有镜像信息) 检查镜像layer数(不超过127),镜像层数太多会造成性能问题 将runconfig.Config和image.Config合并 创建{Container.ID}-init和Container.ID镜像的目录,在init layer创建.dockerinit./etc/hosts./etc/hostname等, Conta

docker学习(3) 容器的启动过程

这一节我们来稍微了解下docker原理性的东西 docker run -i -t ubuntu /bin/bash 输入上面这行命令,启动一个ubuntu容器时,到底发生了什么? 大致过程可以用下图描述: 首先系统要有一个docker daemon的后台进程在运行,当刚才这行命令敲下时, 1. docker client(即:docker终端命令行)会调用docker daemon请求启动一个容器, 2. docker daemon会向host os(即:linux)请求创建容器 3. linu

Docker学习路线图 (持续更新中)

Docker学习路线图 Docker基础 101 学习Docker基本概念 Docker容器 Docker镜像 Dockerfile初步概念 练习 安装Docker Toolbox或Docker Engine Docker Toolbox 阿里云镜像源 Docker Engine 阿里云镜像源 配置本地Docker环境 利用Docker Machine创建本地Docker Environment 配置阿里云Docker镜像加速器 管理容器的生命周期与配置 创建.删除.检查.启动.停止容器 ...

docker学习笔记

docker学习笔记 一.更新内核,升级内核至3.x 二.安装docker: rpm --import/etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6 yum -y install docker-io 三.启动docker: service docker start chkconfig docker on 四.下载基础镜像: docker pull centos:latest 五.查看本地镜像: docker images 六.添加运行文件:(以javaSE为例) Dock

docker学习(1) 安装

docker是啥就不多讲了,简言之就是更轻量.更牛叉的新一代虚拟机技术.下面是安装步骤: 一.mac/windows平台的安装 docker是在linux内核基础上发展而来的,无法直接运行在mac/windows上,需要借助docker-machine工具,先在mac/windows上建一个linux的虚拟机,然后才能继续玩下去.默认内置的虚拟机引擎是Oracle的免费软件VirtualBox,可支持vmware fusion之类的商业软件. 1.1 下载docker toolbox 下载地址:

Docker学习笔记之docker入门_docker

学习的一些疑问 如何热更新镜像(images)?(你可以快速启动或者销毁容器.这种时间几乎是实时的) 如何热更新游戏服? 好处在于各个应用之间环境相互独立,即使某一个容器崩溃也不会影响到其它容器: 每个容器使用端口如何维护?(方法1写在Dockerfile里面,不灵活:方法2在run的时候-p指定): 那这样的话,会存在好多linux用户,相当于每一个容器就要维护一个物理机(虚拟): 需要一套工具来管理维护镜像.容器的操作和状态: 目前主流使用docker都是应用到哪些场景中? 1. docke

docker学习(4) 一些常用操作

继续docker的学习之旅,今天练习一些常用的命令: 一.镜像相关 1.1 列出本机所有镜像 docker images 后面的操作,都以ubuntu做为练习的目标. 另外:如果某些镜像文件不想要了,可以用下面的命令删除 1.2 删除镜像 docker rmi 镜像Id(即:1.1图中的IMAGE ID) 有时候删除会失败,比如:有一个容器正在使用该镜像文件.这时可以加参数-f 强制删除,如果不清楚每个命令可以加哪些参数,可以用 docker 命令 --help 查看帮助,比如: bin doc

Docker学习(一)

今天公司请到了惠普的厂家人员来讲解Kubernetes 学习Kubernetes 当然要学习docker 那么从安装到简单的命令来一遍吧,我实在自己的虚拟机上(VM+CentOS) 刚开始怎么也连不上外网,后来发现有一个服务没有启动,不知道你会不会遇见这样的情况: VMware DHCP Service 这个服务要启动 安装Docker: wget -qO- https://get.docker.com/ | sh 拉取MySQL镜像: docker pull mysql:5.6 运行: doc

学习Docker容器网络模型 - 搭建分布式Zookeeper集群

ZooKeeper是一个流行的分布式协调服务.它提供了两种不同的部署方式:单机模式和分布式模式.其中单机模式的部署非常简单,网上也有很多资料,我们今天会利用Docker搭建分布式Zookeeper集群,并来帮助大家熟悉Docker中容器网络模型的使用. ZooKeeper集群中所有的节点作为一个整体对分布式应用提供服务.节点中有两个的角色:Leader和Follower.在整个集群运行过程中,只有一个Leader,其他节点的都是Follower,如果ZK集群在运行过程中Leader出了问题,系统