Docker(开课吧笔记)

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实操环境

用命令行来创建、启动、停止、删除管理虚拟机的软件

https://github.com/liubin/docker101

端口转发

 

 

 

 

因为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

下载VirtualBoxRHEL软件库配置文件

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 Machine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBox Digital OceanMicrosoft 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调度策略和过滤机制

 

26.Docker网络基础

27.Docker网络模式

28.容器os和容器标准化

29.网络、存储和PaaS平台

30.基于Docker进行持续集成

31.使用灵雀云命令行工具

32.灵雀云简介

原文地址:https://www.cnblogs.com/liuyifeng/p/5690796.html