一.Docker的应用场景
Web 应用的自动化打包和发布。
自动化测试和持续集成、发布。
在服务型环境中部署和调整数据库或其他的后台应用。
从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。
二.Docker 的优点
Docker 是一个用于开发,交付和运行应用程序的开放平台。Docker 使您能够将应用程序与基础架构分开,从而可以快速交付软件。借助 Docker,您可以与管理应用程序相同的方式来管理基础架构。通过利用 Docker 的方法来快速交付,测试和部署代码,您可以大大减少编写代码和在生产环境中运行代码之间的延迟。
1、快速,一致地交付您的应用程序
Docker 允许开发人员使用您提供的应用程序或服务的本地容器在标准化环境中工作,从而简化了开发的生命周期。
容器非常适合持续集成和持续交付(CI / CD)工作流程,请考虑以下示例方案:
您的开发人员在本地编写代码,并使用 Docker 容器与同事共享他们的工作。
他们使用 Docker 将其应用程序推送到测试环境中,并执行自动或手动测试。
当开发人员发现错误时,他们可以在开发环境中对其进行修复,然后将其重新部署到测试环境中,以进行测试和验证。
测试完成后,将修补程序推送给生产环境,就像将更新的镜像推送到生产环境一样简单。
2、响应式部署和扩展
Docker 是基于容器的平台,允许高度可移植的工作负载。Docker 容器可以在开发人员的本机上,数据中心的物理或虚拟机上,云服务上或混合环境中运行。
Docker 的可移植性和轻量级的特性,还可以使您轻松地完成动态管理的工作负担,并根据业务需求指示,实时扩展或拆除应用程序和服务。
3、在同一硬件上运行更多工作负载
Docker 轻巧快速。它为基于虚拟机管理程序的虚拟机提供了可行、经济、高效的替代方案,因此您可以利用更多的计算能力来实现业务目标。Docker 非常适合于高密度环境以及中小型部署,而您可以用更少的资源做更多的事情。
三.Docker架构
Docker 包括三个基本概念:
- 镜像(Image):Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
- 容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和实例一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
- 仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。
Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。
Docker 容器通过 Docker 镜像来创建。
容器与镜像的关系类似于面向对象编程中的对象与类。
四,核心概念
概念 | 说明 |
Docker 镜像(Images) | Docker 镜像是用于创建 Docker 容器的模板,比如 Ubuntu 系统。 |
Docker 容器(Container) | 容器是独立运行的一个或一组应用,是镜像运行时的实体。 |
Docker 客户端(Client) | Docker 客户端通过命令行或者其他工具使用 Docker SDK (Develop with Docker Engine SDKs | Docker Documentation) 与 Docker 的守护进程通信。 |
Docker 主机(Host) | 一个物理或者虚拟的机器用于执行 Docker 守护进程和容器。 |
Docker Registry | Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。 Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用。 一个 Docker Registry 中可以包含多个仓库(Repository);每个仓库可以包含多个标签(Tag);每个标签对应一个镜像。 通常,一个仓库会包含同一个软件不同版本的镜像,而标签就常用于对应该软件的各个版本。我们可以通过 <仓库名>:<标签> 的格式来指定具体是这个软件哪个版本的镜像。如果不给出标签,将以 latest 作为默认标签。 |
Docker Machine | Docker Machine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBox、 Digital Ocean、Microsoft Azure。 |
五,常用命令
docker 管理命令介绍 | builder Manage builds 管理构建 config Manage Docker configs 管理配置 container Manage containers 管理容器 context Manage contexts 管理上下文 engine Manage the docker engine 管理引擎 image Manage images 管理镜像 network Manage networks 管理网络 node Manage Swarm nodes 管理节点(集群) plugin Manage plugins 管理插件 secret Manage Docker secrets 管理密钥 service Manage services 管理服务 stack Manage Docker stacks 管理 swarm Manage Swarm 管理集群 system Manage Docker管理系统 trust Manage trust on Docker images 管理信任 volume Manage volumes 管理数据挂载(数据持久化 === 永久保存) |
镜像管理命令 | 1、镜像管理命令介绍 docker image 2、镜像获取 2.1 先搜索镜像 docker search <镜像> 2.2 然后下载镜像 docker image pull 3、镜像列表 docker image ls 4、镜像列表基本状态解析 各个选项说明: - **REPOSITORY:**表示镜像的仓库源 - **TAG:**镜像的标签 - **IMAGE ID:**镜像ID - **CREATED:**镜像创建时间 - **SIZE:**镜像大小 5、镜像详细 docker image inspect <镜像id> 6、镜像删除 docker image rm <镜像id> 7、镜像删除构建失败的镜像 docker image prune 7.1 清理未使用的镜像 docker image prune -a 8、镜像设置标签,也叫镜像设置版本 docker image tag image:v1 image 9、镜像历史(了解镜像的操作记录) docker image history [OPTIONS] <IMAGEid> 10、导出镜像导入导出 10.1 镜像导入 docker image import [OPTIONS] file|URL|- [REPOSITORY[:TAG]] 10.2 镜像导入 docker image load [OPTIONS] Options: -i, --input string Read from tar archive file, instead of STDIN -q, --quiet Suppress the load output 10.3 镜像导出,备份 docker image save [OPTIONS] IMAGE [IMAGE...] |
容器命令 | 1、容器命令介绍 docker container 容器的修改和增删 2、运行容器rmcore docker run rmcore 3、查看容器列表 docker ps -a 3、后台运行rmcore docker run -d rmcore -d 后台执行 4、暴露rmcore端口 docker run -d -P rmcore 4.1 自定义端口暴露 docker run -d -p 2020:80 2021:443 rmcore 5、进入容器 docker exec -it rmcore /bin/bash -i :交互式操作 t : 终端 /bin/bash 放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 /bin/bash,就好比xshell一样 6、退出容器 exit 7、停止容器 docker stop rmcore 8、启动容器 docker start rmcore nginx /etc/nginx/conf.d/default.conf |
附:Docker安装使用
1、Docker版本 17.03版本之后
1、CE(Community Edition: 社区版) ---- 免费
2、EE(Enterprise Edition: 企业版)---- 收费
2、windows 安装
条件
1、windows 10
2、开启Hyper-V
3、安装Toolbox
最新版 Toolbox 下载地址: https://www.docker.com/get-docker
点击 Download Desktop and Take a Tutorial,并下载 Windows 的版本
3、linux安装
1、centos7.0 以上的版本
2、安装docker 版本仓库 docker版本
2.1 设置仓库
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
2.2 稳定仓库
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
3、安装docker(默认安装最新版本)
sudo yum install docker-ce docker-ce-cli containerd.io
如果要安装其他版本
要安装特定版本的 Docker Engine-Community,请在存储库中列出可用版本,然后选择并安装:
1、列出并排序您存储库中可用的版本。此示例按版本号(从高到低)对结果进行排序。
yum list docker-ce --showduplicates | sort -r
docker-ce.x86_64 3:18.09.1-3.el7 docker-ce-stable
docker-ce.x86_64 3:18.09.0-3.el7 docker-ce-stable
docker-ce.x86_64 18.06.1.ce-3.el7 docker-ce-stable
docker-ce.x86_64 18.06.0.ce-3.el7 docker-ce-stable
2、通过其完整的软件包名称安装特定版本,该软件包名称是软件包名称(docker-ce)加上版本字符串(第二列), 从第一个冒号(:)一直到第一个连字符,并用连字符(-)分隔。例如:docker-ce-18.09.1。
sudo yum install docker-ce-<VERSION_STRING> docker-ce-cli-<VERSION_STRING> containerd.io
4、docker启动
sudo systemctl start docker
5、docker 运行(判断是否安装成功)
sudo docker run hello-world
docker-dockerfile介绍:
6、dockerfile的指令:
FROM:指定基础镜像(FROM是必备的指令,并且必须为第一条指令)。
RUN: 用来执行命令行命令。其基本格式:
shell格式: RUN <命令> ,输入在bash环境中的命令即可,一个dockerfile允许使用RUN不得超过127层,所以,使用一次RUN, 使用 ‘ \ ’ 换行,使用‘ && ’执行下一条命令。一般使用此种格式;
exec格式: RUN <"可执行文件", "参数1", "参数2">,此种方式像是函数调用中的格式;
COPY: 复制文件。 其基本格式:
格式1:COPY <源路径>...<目标路径>
格式2:COPY [“<源路径1>”,....."<目标路径>"]
ADD: 更高级的复制文件,在COPY的基础上增加了一些功能,如果复制的是压缩包的话,会直接解压,而不需要在使用RUN解压;
CMD:容器启动命令。其基本格式:
shell格式: CMD <命令>
exec格式: CMD ["可执行文件", "参数1", "参数2"...]
参数列表格式: CMD [“参数1”, “参数2”...],在指定了ENTRYPOINT指令后,用CMD指定具体的参数
ENTRYPOINT: 入口点。其基本格式分为exec和shell,
ENTRYPOINT的目的和CMD一样,都是在指定容器启动程序及参数。ENTRYPOINT在运行中可以替代,不过比CMD繁琐,需要通过docker run 的参数--entrypoint 来指定。当指定了ENTRYPOINT后,CMD的含义就发生了改变,不在是直接运行其命令,而是将CMD的内容作为参数传递给ENTRYPOINT指令。其执行时就变成了: <ENTRYPOINT> "<CMD>"
ENV: 设置环境变量。(都可以使用这里使用的变量)其基本格式:
格式1:ENV <key> <value>
格式2:ENV <key1>=<value1> <key2>=<value>...
ARG: 构建参数。构建参数和ENV的效果一样,都是设置环境变量,所不同的是ARG所构建的环境变量在将来容器运行时是不存在的。其基本格式:
格式1: ARG <参数名> [=<默认值>]
格式2: 该默认值可以在构建命令 docker build 中用 --build-arg <参数名>=<值> 来覆盖
VOLUME: 定义匿名卷。 其基本格式:
格式1: VOLUME ["<路径1>", "<路径2>"...]
格式2: VOLUME <路径>
EXPOSE: 暴露端口。EXPOSE指令是声明运行时容器所提供的端口,在启动容器时不会在因为这个声明而开启端口。 其基本格式:
格式1: EXPOSE <端口1> [<端口2>...]
WORKDIR: 指定工作目录。其基本格式:
格式1: WORKDIR <工作目录路径>
USER: 指定当前用户。USER是帮助你切换到指定用户。 其基本格式:
格式1: USER <用户名>
HEALTCHECK: 健康检查,判断容器的状态是否正常。 其基本格式:
格式1: HEALTCHECK [选项] CMD <命令> :设置检查容器健康状况的命令
格式2: HEALTCHECK NONE: 如果基础镜像有健康检查指令,使用此格式可以屏蔽掉其健康检查指令
7、Dockerfile核心命令
7.1、FROM 指定基础镜像构建
写法:
FROM 指定基础镜像
7.2、COPY 复制命令。从上下文目录中复制文件或者目录到容器里指定路径。
写法:
COPY 源路径,目标路径
COPY ["源路径","目标路径"]
7.3、RUN运行指令。构建的时候运行的指令
主要在于镜像构建的时候运行,运行build命令的时候
后面接的命令就是shell输入的命令
写法
RUN shell命令 参数1 参数2
RUN ["shell命令 ","参数1"," 参数2"]
例如:
RUN ["echo",">"," /usr/share/index.html"]
7.4、CMD运行指令。运行容器时候运行的指令
主要在于镜像运行容器的时候生成,运行run的时候运行
写法
CMD <shell 命令>
CMD ["<可执行文件或命令>","<param1>","<param2>",...]
例如:
CMD ["dotnet","rmcore.dll"]
缺点:在run 命令后面可以进行覆盖
docker run -d -P rmcore dotnet rmcore.dll 进行覆盖掉
7.5 ENTRYPOINT运行指令。运行容器时候运行的指令(不会被覆盖)
写法
ENTRYPOINT ["<executeable>","<param1>","<param2>",...]
可以和CMD动态结合,设置动态的配置参数
例如
ENTRYPOINT ["nginx", "-c"] 定参
CMD ["/etc/nginx/nginx.conf"]变参
7.6、EXPOSE暴露端口指令
仅仅声明端口,就是指定镜像暴露的端口
在run 的时候,通过docker run -p 会自动随机映射到EXPOSE端口
写法
EXPOSE 端口
EXPOSE 端口
例如
EXPOSE 5000
EXPOSE 5001
7.7、WORKDIR工作目录指令
用于应用在容器内的工作目录,就好比:ruanmou目录
写法
WORKDIR <工作目录路径>
例如
WORKDIR /rmcore
或者
WORKDIR /nginx
8、docker如何构建nginx镜像?
条件:
1、nginx-1.15.2.tar.gz
2、基础镜像centos
3、nginx安装命令
4、Dockerfile文件
9、linux中 nginx原始配置
1 安装 nginx需要工具
yum -y install gcc make pcre-devel zlib-devel tar zlib
2 下载nginx
wget http://nginx.org/download/nginx-1.15.2.tar.gz
3 nginx解压/nginx目录
tar -zxvf nginx-1.15.2.tar.gz
4 切换到/nginx/nginx-1.15.2
执行./configure
make
make install 进行安装
5 切换到/usr/local/nginx/sbin
执行 ./nginx 启动nginx
10、配置nginx Dcokerfile
FROM centos
RUN yum -y install gcc make pcre-devel zlib-devel tar zlib
WORKDIR /nginx
COPY nginx-1.15.2.tar.gz /nginx
RUN tar -zxvf nginx-1.15.2.tar.gz
RUN cd nginx-1.15.2 && ./configure && make && make install
EXPOSE 80
CMD /bin/bash