1.Docker基本概念
Docker运行在Linux,需要git技能
docker官网解析
来源于容器又不仅仅是容器,第一个版本基于LXC,远远超过容器概念
交付时拿到的是镜像,直接run运行想要的应用程序
持续集成持续交付更加普及
秒级启动,可轻易获取
可忽略与应用无关的操作,用dockerfile就可以构建一模一样的镜像,平民技术
2.Docker实现原理
Cgroups对内存、CPU限制
独立环境下不能看到别的机器
数据库使用ipc提高系统通讯效率
Userspace在3.8版本才有
3.Docker组件介绍
可运行成百上千的容器
只能在一台机器上部署
对docker镜像和容器进行管理
1.8.1版本后
帮助我们部署到云上
Kitematic提供gui管理docker容器
4.Docker实操环境
用命令行来创建、启动、停止、删除管理虚拟机的软件
端口转发
因为update后,导致os系统出现问题,重新安装客户端工具
运行docker
(实操)报错Dockerinfo
5.什么是docker容器
Docker启动参数
添加灵雀云加速服务
保存文件重启docker服务即可生效
6.深入docker容器
或者指定镜像id指定镜像,本地如没有就会去dockerhub查找
解决dockerrun慢的问题
容器也结束变为停止状态
系统中不能重复命名,如重复必须删除停止重名容器,指定端口打开服务供外部服务;detach(分离)后台容器,容器将会在控制台输出输入;打印64位容器id
使用浏览器localhost:5050,就能在命令行下面看到输出的日志,ctrl+C会同时退出attach和容器
禁止这些信号传递给容器的第一个进程,避免退出容器
为了调试简单
访问端口
将容器id赋值给cid
不能删除正在运行的容器
就行ssh到远程主机一样
不建议修改正在运行的容器配置
7.Docker容器的生命周期管理
Events显示docker事件发生时会输出到控制台
对运行的docker容器暂停pause
恢复运行
停止容器
删除容器
默认docker是不会自动重启容器的,需要手工重启
达到最大重试次数才会放弃重启;restart则会不管是正常退出还是异常都会重启容器;每次重启时间间隔是上次重启间隔的2倍
8.认识docker镜像
镜像是docker的创新
Rootfs操作系统文件系统
最大的特点是分享,
查看dockerHub的镜像
节省一个新镜像启动时花费的时间
查看镜像更详细的信息
Dockerhub上还存在
9.手工构建Docker镜像
设置nginx为前台运行
模式,容器启动后,nginx会在前台运行不会退出,启动容器时的进程退出,容器也就结束
取容器id放到变量cid中
新构建的镜像上传到云端
镜像id一样,仓库名不一样
Push到灵雀云
10.使用Dockerfile构建Ruby
没有打标签就会自动设置latest标签
Build context是构建环境,Dockerfile文件夹底下的所有资源,docker build从客户端传输到docker守护进程,构建是在守护进程里面进行的。如果不想将文件夹下的log之类的文件可在当前文件夹路径添加.dockerignore文件指定哪些文件不被上传到上下文,里面的语言模式匹配采用了go语言的filepass模式。
Centos基础镜像
每条env只能设置一条环境变量,空格后面的内容都会作为环境变量的值Key=value可以设置多个环境变量,不同变量用空格分隔
在容器中也能继续使用
第一个run安装 ruby所需的工具
第二个是下载源代码,解压编译
使用\和&&进行分隔,增加代码阅读性
Env、cmd不涉及到软件的修改,只会影响镜像的meta信息,因此增加层大小都是0,查看label,env是否正确报错到镜像当中
如果构建指令第5条失败,修改后即可从第4条缓存开始执行
Yum、update操作不想缓存可以添加参数
11.Dockerfile指令说明
推荐使用exec命令
需要run命令加-p打开指定端口,不能在Dockerfile指定主机映射关系,会降低镜像的可移植性
Run是容器构建构建过程中执行的命令,cmd是容器启动时指定执行的命令
CMD用于指定容器启动时执行的命令,run是构建过程
CMD参数会传递到entrypoint指定的命令,上图第二种方式,也可在run中覆盖cmd指定的设置。
与CMD指令相似,run指令中的参数都会当成参数再次传递给entrypoint指定的命令
Entrypoint使用数组方式,可避免/bin/ssh –c带来的问题
第一个没有指定参数,会默认使用CMD中的—help命令,传递给entrypoint通过entrypoint可以构建镜像,会显示帮助信息,第二条会覆盖CMD命令。
Wokerdir从镜像在创建容器时会在容器内部设置一个工作目录,entryponit和cmd命令会在这个目录执行,可以为dokerfile后续的命令设置工作目录,也可以为最终的容器中设置工作目录
Volume用于向基于镜像创建的容器中添加数据卷,一个数据卷可以存在于一个或多个容器内的特定目录,可以绕过联合文件系统,共享数据,对数据持久化的功能;可以将数据:源代码,数据库,或者其他容器添加到容器中,而不是将这些内容添加到镜像中,并允许多个容器间共享这些数据内容
dockerfile使用Volume指令以后的代码尝试对volume里面的内容进行修改,修改不会生效,都不会进行修改。因为在dockerfile中除了from指令中的每一行,都是基于上一次临时镜像创建一个容器执行一条指令并通过docker commit命令得到一个新镜像,docker commit不会对volume进行保存,volume指令以后进行修改都不会保存下来
用于将构建环境下的目录或文件复制到镜像中,文件原路径必须与当前构建环境相对于的文件或者目录,本地文件都会放到和docker同一目录下,我们不能复制该目录之外的文件,因为构建环境将会上传到docker的守护进程,而复制操作是在docker守护进程中进行的,任何构建文件之外的东西都是不可用的,也可使用url的形式,会在文件源下载
Zip等文件指定为源文件,docker会通过-x tar实现了解压包,不过不支持以url位置使用归档文件,路径中不存在,会自动创建,类似mkdir –p,新创建的文件目录和格式为0755(0rwx-wx-wx),UID和GID都是0
Copy类似add,只构建上下文中复制文件,只支持本地文件,不支持文件进行提取解压的工作,从远程下载,推荐使用,简单可控
添加将来执行的指令到镜像当中,当镜像作为From镜像的参数时,这些触发指令就会在from指令执行时中加入到构建过程中,如:将当前代码拷贝到容器中,可将拷贝源代码的指令写到父镜像中,子镜像就不必写,该指令会在子镜像构建from指令后自动执行。如上图父镜像指定了ONBUILD,如果使用该镜像为父镜像,镜像构建时from指令后会插入一条add指令,是ONBUILD触发器中指定的,执行完add命令后才会继续执行构建文件的命令。
ONBUILD防递归使用、from、container不使用。使用该命令需要标签如:ruby 2.0 ONBUILD
12.通过构建私有镜像服务器
将busybox重命名为
镜像是在registry中如何存储
有镜像的元数据和镜像的数据
除了将镜像数据挂载到宿主机以外,还可以通过storege driver存储到云存储服务,
只能声明在容器内的路径,如果启动容器时,没有给数据卷指定宿主机上的,它就会在以下目录创建数据卷
所以删除的时候需要加-v,否则数据卷是不会自动删除
基于log,发送报告等,除了邮件
13.为私有镜像服务添加Basic
14.为私有镜像服务添加Token
15.DockerHub和自动构建
16.Docker容器连接
17.创建和使用数据卷
18.使用数据卷容器
19.使用DockerCompose
20.Docker Compose配置文件解说
21.初识Docker Machine
Centos7安装vitualbox
查看版本
安装dockermachine
下载VirtualBox的RHEL软件库配置文件
cd /etc/yum.repos.d
wget -P /etc/yum.repos.d http://download.virtualbox.org/virtualbox/rpm/el/virtualbox.repo
安装RPMForge.
首先从http://pkgs.repoforge.org/rpmforge-release/上下载相应的rpm文件,我下载的是rpmforge-release-0.5.3-1.el7.rf.x86_64.rpm,具体版本信息请参考:http://wiki.centos.org/zh/AdditionalResources/Repositories/RPMForge
将安装包拷贝到/usr/local目录下
rpm -ivh rpmforge-release-0.5.3-1.el7.rf.x86_64.rpm
yum install dkms
安装开发环境
yum groupinstall "Development Tools"
安装qt和qt-
yum install qt qt-x11
将安装包拷贝到/usr/local然后执行命令
yum install VirtualBox-5.0-5.0.16_105871_el7-1.x86_64.rpm
报错信息
安装扩展VBoxManage extpack install Oracle_VM_VirtualBox_Extension_Pack-5.0-5.0.16_105871.vbox-extpack
解决办法
yum install kernel-headers
yum install make
重启
报错
/sbin/rcvboxdrv setup
是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBox、 Digital Ocean、Microsoft Azure
查看yum安装软件的目录
whereis yum
1、安装
curl -L https://github.com/docker/machine/releases/download/v0.5.3/docker-machine_linux-amd64 >/usr/local/bin/docker-machine && chmod +x /usr/local/bin/docker-machine
查看docker-machine版本:
docker-machine -v
基本使用
查看当前的machine:
docker-machine ls
报错
22.使用DockerMachine创建云主机
23.DockerMachine命令详解
24.Swarm简介
获取swarm集群的id
Master报错
创建agent01报错问题
解决
用mobatxterm连接centos7操作时报错:
将集群id保存在token变量
在centos7里面执行
创建两台agent
启动5个容器
过滤机制
Vagrant虚拟机启动swarm
25.Swarm调度策略和过滤机制