Docker 一文详解介绍(docker入门精通详解)

Docker 一文详解介绍Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用

Docker 是一个开源应用程序容器引擎,允许开发人员将应用程序和依赖项打包到可移植容器中,并将其暴露给常见的Linux 机器,这些机器也可以虚拟化。容器使用完全沙盒机制,彼此之间没有接口。

官网:https://www.docker.com/

相关信息:

1. Docker 入门教程Docker 教程| 初学者教程

2. Docker_百度百科Docker_百度百科

3.有史以来最全的Docker资料合集http://special.csdncms.csdn.net/BeDocker/

4. Docker – 主题精华- 知乎Docker – 知乎

5.Docker简明教程|建国网Docker简明教程|

6. 如何使用Dockerfile 构建镜像Docker 镜像入门教程|

7. Dockerfile 参考- Dockerhttps://docs.docker.com/engine/reference/builder/

Docker与虚拟机比较

Docker 是一种轻量级虚拟化方法,在运行应用程序方面比传统虚拟机具有显着优势。

Docker 容器速度非常快,可以在几秒钟内启动和停止。这比传统的虚拟机方法要快得多。 Docker 容器需要很少的系统资源,并且您可以在单个主机上同时运行数千个Docker 容器。 Docker允许用户通过类似Git的操作轻松获取、分发和更新应用程序镜像,步骤简单,学习成本低。 Docker通过Dockerfile配置文件支持灵活的自动创建和部署机制,提高工作效率。

(本段节选自《Docker技术入门与实战》)

虚拟机在硬件上实现虚拟化,而Docker在操作系统层面实现虚拟化。

安装

Docker 要求Ubuntu 系统具有3.10 或更高版本的内核版本。使用uname -r 命令检查当前内核版本:

[root@bogon ~]# uname -r

3.10.0-327.22.2.el7.x86_64

Docker 支持以下CentOS 版本:

CentOS 7(64 位)CentOS 6.5(64 位)或更高版本

Docker 支持以下Ubuntu 版本:

Ubuntu Precise 12.04 (LTS)Ubuntu Trusty 14.04 (LTS)Ubuntu Wily 15.10其他更新版本.

Linux安装

卷曲-fsSL https://get.docker.com/sh

#daocloud.io国内镜像

卷曲-sSL https://get.daocloud.io/docker sh |

该安装包适用于Ubuntu、Debian、Centos等大多数主流Linux发行版。

当以普通用户身份使用docker 镜像时,出现以下错误:

尝试连接位于unix: 的Docker 守护进程套接字时权限被拒绝///var/run/docker.sock: 获取http://%2Fvar%2Frun%2Fdocker.sock/v1.26/images/json: 拨打unix /var/run/docker.sock: connect: 权限被拒绝

这是因为权限问题。

添加sudo 组docker

sudo gpasswd -a ${USER} docker

重新启动sudo 服务docker

newgrp-docker

CentOS7支持使用yum安装。

美味的更新

百胜安装码头工人

请参阅文档。

https://docs.docker.com/engine/installation/linux/centos/

道云企业5.0

显示版本:

码头工人版本

展示:

客户:

版本: 1.11.2

API版本: 1.23

围棋版本: go1.5.4

git commit: b9f10c9

建成: 2016 年6 月1 日星期三21:23:11

操作系统/Arch: Linux/amd64

服务器:

版本: 1.11.2

API版本: 1.23

围棋版本: go1.5.4

git commit: b9f10c9

建成: 2016 年6 月1 日星期三21:23:11

操作系统/Arch: Linux/amd64

启动Docker服务:

启动服务docker

或者

systemctl启动docker

centos7使用systemctl而不是service来管理服务。 systemctl的常见用途:

格式

systemctl 操作服务名称.service

# 常用命令

systemctl 启动docker #start

systemctl 重新启动docker #restart

systemctl 停止docker #stop

systemctl status docker #显示状态

使用systemctl 启用docker #self-starting

systemctl禁用docker#禁用自动启动

.service 是可选的。

(更多信息请参见《在RHEL7上使用systemctl》《在RHEL 7上使用systemctl(Service和chkconfig替换)》_redhat systemctl替换-CSDN博客)

从此处下载ubuntu 映像以备后用。

docker 搜索ubuntu

docker 拉ubuntu

# 显示所有可用图像

docker镜像-a

这将在本地下载最新的ubuntu 系统映像,并允许您从此映像创建多个容器。该命令的具体含义将在后面介绍。

Docker 中一些比较重要的概念包括注册服务器、仓库、镜像和容器。

仓库:注册服务器是存放仓库的地方,通常一个注册服务器上会存放多个仓库。每个仓库集中存储一定类型的图片,往往包含多个图片文件,并通过不同的标签进行区分。例如,存放Ubuntu操作系统镜像的仓库称为Ubuntu仓库,可能包含不同版本的镜像,例如14.04、12.04等。

镜像:Docker镜像(image)可以理解为Docker引擎的只读模板,包括文件系统。例如,一个镜像可以只包含完整的Ubuntu操作系统环境,称为Ubuntu镜像。

容器:容器是运行从映像创建的应用程序的实例,可以启动、启动、停止和删除。这些容器彼此分开,彼此看不到。您可以从单个映像创建无限数量的容器。通常,我们主要使用容器。您还可以将容器打包成镜像,方便复用。图像本身是只读的。当容器从镜像启动时,Docker会在镜像之上创建一个可写层,而镜像本身保持不变。

客户端和守护进程

本部分介绍docker的结构以及管理docker服务。

Docker 的 C/S 模式

Docker是C/S架构,使用客户端与服务器进行通信。

支持三种连接方式。

unix:///var/run/docker.sock

tcp://主机:端口

fd://socketfd

Docker 守护进程的配置和操作

使用ps -ef grep docker 查看docker 进程。

管理Docker 服务。

启动服务docker

服务泊坞窗停止

重启docker服务

例如,使用service docker start 实际上运行/bin/systemctl start docker.service 命令。

我们建议重新启动并使用它。

重新加载systemctl 守护进程

systemctl 重新启动docker.service

Docker守护进程配置及运行方式:

docker -d [选项]

-d 在后台模式下运行容器。

以下是创建容器时的一些设置,请根据需要添加。初学者可以先看一遍,以后需要的时候再找。

跑步相关:

-D,–调试=假

-e,–exec-driver=\’本机\’

-p,–pidfile=\’/var/run/docker.pid\’

服务器相关:

-G,–group=\’docker\’

-H,–主机=[]

–tls=假

远程API相关:

–api-enable-cors=false

存储相关:

-S,–存储驱动=\’\’

–selinux-enabled=false

–存储-opt=[]

网络设置相关:

-b,–bridge=\’\’ 设置自定义桥

–bip=\’\’

–dns=[]

–ip=0.0.0.0

启动配置文件

Ubuntu: /etc/default/docker

CentOS: /etc/sysconfig/docker

如果没有配置文件,可以直接编辑。

vim /lib/systemd/system/docker.service

内部ExecStart是一个启动配置。

ExecStart=/usr/bin/docker -H fd://

您可以添加一些配置。

ExecStart=/usr/bin/docker -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock -H fd://–label name=server_1

然后重新启动。

重新加载systemctl 守护进程

systemctl 重新启动docker.service

# 如果出现问题,可以使用以下命令进行检查:

systemctl 状态docker.service

您可以使用ps -ef grep docker 查看您添加的信息。

[root@localhost ~]# ps -ef grep docker |

root 8262 1 0 23:50?00:00:00 /usr/bin/docker daemon -H tcp://0.0.0.0:4243 -H unix:///var/run/docker.sock -H fd://–label name=server_1

解决centos7和docker 1.9配置文件丢失问题- 网站建设- IT精英集团

http://www.itnpc.com/news/web/145083113731628.html

Docker 的远程访问

一台安装了Docker 的机器可以访问另一台安装了Docker 的机器。通常,您使用当前计算机的Docker 客户端访问当前计算机的服务器端。下面介绍如何访问其他Docker服务器。

第一个IP:192.168.12.3

第二个IP:192.168.12.4

出于演示目的,我们将使用安装了Docker 的第二台服务器。为了区分它们,设置不同的标签。

更改守护进程(服务器):的默认启动配置。

默认为:-H fd://

您可以这样更改它: -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock -H fd://–label name=server_1

可设置多种连接方式。

第一台机器访问第二台机器的Docker 服务。

通过http连接到Server:

卷曲http://192.168.12.4:2375/信息

访问服务器192.168.12.4:2375的信息接口,返回服务器相关信息。

通过Docker 客户端访问服务器。

docker -H tcp: //192.168.12.4:2375信息

如果第一台机器访问第一台机器的Docker服务器,则使用127.0.0.1:2375。

与服务器端类似,客户端也支持三种连接方式。默认为-H unix:///var/run/docker.sock:

-H unix:///到/sock的路径

tcp://主机:端口

fd://socketfd

Docker客户端默认使用Docker信息来访问本地服务器。您可以通过修改环境变量DOCKER_HOST 来更改默认连接。直接从命令行输入。

导出DOCKER_HOST=\’tcp://127.0.0.1:2375\’

127.0.0.1:237 可以替换为您的实际服务器地址。

如果要恢复本地连接,请将DOCKER_HOST 留空。

导出DOCKER_HOST=\’\’

Docker容器

容器的基本操作

您可以从图像创建容器。

Docker run IMAGE [COMMOND] [ARG.] 在新容器中运行命令

每次运行此命令时都会创建一个新容器。下面展示了如何从下载的ubuntu 映像创建并运行新容器。

# 只执行一次命令

docker run ubuntu echo \’hello world\’ 运行一个新容器并运行echo 命令

#创建并运行容器,进入容器

docker run -i -t –name test ubuntu /bin/bash 在交互式终端中运行一个新容器。镜像是使用bash 的ubuntu,容器别名是test。

-i 交互界面,默认为false

-t 伪终端,默认为false

–name 容器的别名,默认随机命名

exit 退出交互界面,容器停止运行。

按Crtl+P或Crtl+Q退出交互界面并在后台运行容器。 (注意大写的P和Q)

显示容器。

查看正在运行的容器docker ps

docker ps -a 显示所有容器

docker ps -l 显示最近运行的容器

例子:

[root@localhost ~]# docker ps -a

容器ID 镜像命令创建状态端口名称

8c52c83c1903 redis \’docker-entrypoint.sh\’ 结束于2 小时前(0) 2 小时前myredis

集装箱业务:

docker create 容器名称或容器ID 创建容器

docker start [-i] 启动容器的容器名称

docker run 运行容器的容器名称或容器ID(相当于docker create + docker start)

将docker 容器名称或容器ID 添加到容器命令行。

docker stop 容器名称停止容器

docker rm 容器名称删除容器

docker top容器名称显示Web应用程序容器进程

docker 检查容器名称显示底层Docker 信息

如果要删除容器,则必须停止它。如果不停止就会报错。

守护式容器

您可以使用守护进程容器来运行一项或多项服务,例如lamp 服务、redis 服务、mysql 服务等。

什么是受保护容器?

适合运行无需交互式会话即可长时间运行的应用程序和服务

启动守护进程容器。

docker run -d IMAGE [COMMOND] [ARG.]

-d 在后台运行容器。

在后台运行任务:

docker run -d –name d1 ubuntu /bin/sh -c \’while true;do echo hello world;sleep 1;done;\’

b89b9ce64d34bd202a642c8190428f4776f15e882f138949259722f22120201a

返回守护进程的唯一ID。

检查守护进程的运行状态。

[root@localhost ~]# docker ps

容器ID 镜像命令创建状态端口名称

b89b9ce64d34 ubuntu \’/bin/sh -c \’while tr\’ 3 分钟前直到3 分钟d1

[root@localhost ~]# docker 日志-f b89b9ce64d34

你好世界

你好世界

你好世界

你好世界

你好世界

[root@localhost ~]# docker log -f -t –tail 2 b89b9ce64d34

2016-06-26T10:13:19.786516589Z 你好,世界

2016-06-26T10:13:20.788871572Z 你好世界

2016-06-26T10:13:21.791921389Z 你好,世界

[root@localhost ~]# docker top b89b9ce64d34

UID PID PPID C STIME TTY TIME CMD

root 4156 4148 0 06:05 ? 00:00:00 /bin/sh -c while true;do echo hello world;sleep 1;done;

根4850 4156 0 06:16 00:00:00 睡眠1

docker log [-f] [-t] [–tail] 容器名称或ID,查看容器内WEB应用日志

-f –follow=true|false,默认为false,始终跟随日志更改。

-t –timestamps=true|false,默认为false,添加时间戳

–tail=\’all\’,返回最新日志

在正在运行的容器中启动一个新进程。

docker exec [-d] [-i] [-t] 容器名称[COMMOND] [ARG.]

停止守护进程。

docker stop 容器名称发送停止信号并等待关闭

dockerkillcontainername 直接关闭容器

在容器中部署静态网站

docker run -d -p 80 -i -t ubuntu /bin/bash 主机端口随机

docker run -d -p 8080:80 -i -t ubuntu /bin/bash 自定义主机端口

docker run -d -p 0.0.0.0:80 -i -t ubuntu /bin/bash

docker run -d -p 0.0.0.0:8080:80 -i -t ubuntu /bin/bash

-P –publish-all=true|false, 默认为false

-p –publish=[],自定义端口,将容器内部使用的网络端口映射到你要使用的主机上。

docker run -d -P Training/webapp python app.py 在后台运行容器应用程序

docker run -d -p 5000:5000 Training/webapp python app.py 将容器中的5000端口映射到本地主机上的5000端口。

docker port 容器ID 查看容器端口映射

Nginx 部署示例:

# 使用映射的80端口创建交互接口。

docker run -p 80 –name web -i -t ubuntu /bin/bash

# 第一次使用更新源

apt-get 更新

# 安装Nginx

apt-get 安装nginx

# 安装vim

apt-get 安装vim

nginx 在哪里

nginx: /usr/sbin/nginx /etc/nginx /usr/share/nginx

vim /etc/nginx/conf.d/localhost.conf

配置文件位于/etc/nginx/conf.d。

conf.d/localhost.conf

服务器{

听80。

服务器名称本地主机;

位置/{

根/var/www/;

索引index.htmlindex.htm;

}

}

创建一个新目录。

mkdir -p /var/www/

vim /v

ar/www/index.html

内容随便写。

# 启动nginx
nginx

使用Crtl+P(即Crtl+shift+p)退出容器,并后台运行。
查看:

[root@localhost ~]# docker port web
80/tcp -> 0.0.0.0:32769
[root@localhost ~]# docker top web
UID PID PPID C STIME TTY TIME CMD
root 12123 12113 0 07:14 pts/2 00:00:00 /bin/bash
root 12159 12123 0 07:14 ? 00:00:00 nginx: master process nginx
33 12160 12159 0 07:14 ? 00:00:00 nginx: worker process
[root@localhost ~]# curl http://127.0.0.1:32769

正常的话会显示网页内容。

如果exit退出了容器,想开启nginx服务,还可以:

docker start web
docker exec web nginx

链接另一个容器

我们可以使用–link使用另一个容器的服务。
创建mysql_db 容器:

docker run –name mysql_db -e MYSQL_ROOT_PASSWORD=123456 -d mysql

创建一个应用,并使用刚才创建的mysql_db容器服务:

docker run –name some-wordpress –link mysql_db:mysql -p 8001:80 -d wordpress

Docker镜像

搜索镜像

docker search [-s] IMAGE

下载镜像

docker pull [OPTIONS] NAME[:TAG|@DIGEST]
[root@bogon ~]# docker pull ubuntu:16.04
[root@bogon ~]# docker pull daocloud.io/library/ubuntu:16.04

下载镜像名称其实由三部分组成:daocloud.io/library/ubuntu:16.04
其中其中daocloud.io是注册服务器地址,默认是registry.hub.docker.com;ubuntu是仓库名,16.04是标签名,默认是latest。

查看已下载镜像列表

docker images [-a]
[root@bogon ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
daocloud.io/library/ubuntu 16.04 12543ced0f6f 2 weeks ago 122.4 MB
ubutun latest 12543ced0f6f 2 weeks ago 122.4 MB
daocloud.io/daocloud/dao-2048 latest 6c1ff658e77e 3 months ago 7.598 MB
daocloud.io/daocloud/alpine latest e9f3e32a4303 3 months ago 11.52 MB
daocloud.io/library/centos 7.1.1503 fac97c5c4748 8 months ago 212.1 MB
daocloud.io/daocloud/dao-redis master-init 173a30377d85 13 months ago 190.4 MB

各个选项说明:

REPOSTITORY:表示镜像的仓库源
TAG:镜像的标签
IMAGE ID:镜像ID
CREATED:镜像创建时间
SIZE:镜像大小

同一仓库源可以有多个 TAG,代表这个仓库源的不同个版本,我们使用 REPOSTITORY:TAG 来定义不同的镜像。

给镜像添加标签

docker tag [OPTIONS] IMAGE[:TAG] [REGISTRYHOST/][USERNAME/]NAME[:TAG]
[root@bogon ~]# docker tag daocloud.io/library/ubuntu:16.04 ubuntu:latest

删除镜像

docker rmi [OPTIONS] IMAGE [IMAGE…]
# 按标签删除:多个标签,仅会删除当前标签,不会删除镜像
[root@bogon ~]# docker rmi ubuntu:latest
# 按ID删除:直接删除镜像
[root@bogon ~]# docker rmi 12543ced0f6f

选项:
-f, –force 强制删除镜像
–no-prune 不删除untagged parents

导出镜像

docker save [OPTIONS] IMAGE [IMAGE…]
[root@bogon ~]# docker save -o ubuntu_latest.tar ubuntu:latest
[root@bogon ~]# ls -l
-rw-r–r–. 1 root root 128086528 Jun 28 12:39 ubuntu_latest.tar

选项:
-o, –output 写入到文件

导入镜像

docker load –input ubuntu_latest.tar
# 或者
docker load < ubuntu_latest.tar

选项:
-i, –input 从压缩包载入镜像

创建镜像

当我们从docker镜像仓库中下载的镜像不能满足我们的需求时,我们可以通过以下两种方式对镜像进行更改。
1.从已经创建的容器中更新镜像,并且提交这个镜像
2.使用 Dockerfile 指令来创建一个新的镜像

从容器生成镜像

假设有一容器2c74d574293f,可以使用commit命令生成镜像:

docker commit -m \”create images\” -a \”52fhy\” 2c74d574293f 52fhy/test:v1

-m 加一些改动信息,-a 指定作者相关信息,2c74d这一串为旧容器id,再后面为新镜像的名字。

上传镜像

docker push [OPTIONS] NAME[:TAG|@DIGEST]

选项:
–disable-content-trust=true 跳过镜像签名

Docker仓库

仓库是集中存放镜像的地方。官方提供的公共仓库是https://hub.docker.com。不用注册即可使用里面的众多仓库资源,包含了常用的ubuntu、centos、php、nginx、mysql等仓库。

由于国外仓库访问比较慢,可以使用国内的仓库,一般需要注册,使用docker pull的时候需要指明注册服务器地址。

DaoCloud DaoCloud 道客阿里云 开放云原生应用-云原生(Cloud Native)-云原生介绍 – 阿里云网易蜂巢 网易数帆-为每一个组织构建独特的数智竞争力
示例:

docker pull registry.aliyuncs.com/acs-sample/mysql

其中registry.aliyuncs.com是注册服务器地址,acs-sample/mysql是仓库名,所有者是acs-sample,没有指定镜像标签,则默认是latest。

根据所存储的镜像公开分享与否,Docker仓库可以分为公开仓库(Public)和私有仓库(Private)两种形式。

Docker数据卷及数据卷容器

在使用容器的过程中,我们可能需要共享数据:
1、共享本地主机数据到容器;
2、共享容器数据到另一个容器。

Docker里的数据卷及数据卷容器恰好满足了这个需求。

数据卷

数据卷(Data Volumes)是一个可供容器使用的特殊目录,它提供了很多有用的特性:

对数据卷的修改会立马生效数据卷会一直存在,直到没有容器使用数据卷可以被多个容器使用
数据卷类似于Linux的mount。实质是在当前机器映射了一个目录到容器内部。

创建或运行容器的时候,使用-v创建一个数据卷,多次使用-v可以创建多个数据卷。

docker run -d -P –name test1 -v /data1 ubuntu
# 挂载本地已有目录到容器中
docker run -d -P –name test2 -v /tmp/data2:/data2 ubuntu
# 挂载本地已有目录到容器中,指定只读
docker run -d -P –name test3 -v /tmp/data3:/data3:ro ubuntu

挂载的数据卷默认权限是读写rw。

数据卷容器

数据卷容器(Data Volume Dontainers)其实就是一个普通的容器,只是我们专门用它提供数据卷供其它容器挂载使用。

创建数据库容器很简单,创建一个普通容器就行了:

docker run –name db1 -v /data ubuntu

其他容器使用该数据卷容器:

docker run -it –name test4 –volumes-from db1 ubuntu

使用–volumes-from指定数据卷容器。多个–volumes-from将挂载多个数据卷容器。

注意:使用–volumes-from参数所挂载的数据卷容器本身并不需要保持运行状态。如果删除了挂载的容器,数据卷并不会被自动删除,如果要删除一个数据卷,必需使用docker rm -v命令来指定同时删除管联的容器。

使用Dockerfile创建镜像

Dockerfile用来创建一个自定义的image,包含了用户指定的软件依赖等。Dockerfile文件可以用docker build命令生成一个新的镜像。

Dockerfile文件示例:

FROM daocloud.io/centos:7
# Install Nginx.
# WORKDIR /etc/yum.repos.d/
RUN \\
yum update -y && \\
yum install -y wget && \\
# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo && \\
wget -O /etc/yum.repos.d/CentOs-Base.repo http://mirrors.163.com/.help/CentOS7-Base-163.repo && \\
yum makecache && \\
yum update -y && \\
yum install -y vim && \\
yum install -y nginx && \\
yum install -y net-tools && \\
echo \”daemon off;\” >> /etc/nginx/nginx.conf && \\
echo \”master_process off;\” >> /etc/nginx/nginx.conf
# Define mountable directories.
VOLUME [\”/usr/share/nginx\”, \”/etc/nginx/conf.d\”, \”/var/log/nginx\”]
# Define working directory.
WORKDIR /etc/nginx
# Define default command.
CMD [\”/usr/sbin/nginx\”]
# Expose ports.
EXPOSE 80
EXPOSE 443

运行如下命令:

docker build -t nginx:v1 .

进行镜像构建。成功后,从生成的镜像运行容器:

docker run -d -p 8090:80 nginx:v1

Dockerfile文件语法

(1)FROM(指定基础image)
构建指令,必须指定且需要在Dockerfile其他指令的前面。后续的指令都依赖于该指令指定的image。FROM指令指定的基础image可以是官方远程仓库中的,也可以位于本地仓库。镜像可以指定标签。格式:

FROM <image>:<tag>

(2)MAINTAINER(用来指定镜像创建者信息)
构建指令,用于将image的制作者相关的信息写入到image中。当我们对该image执行docker inspect命令时,输出中有相应的字段记录该信息。
格式:

MAINTAINER <name>

(3)RUN
构建指令,RUN可以运行任何被基础image支持的命令。如基础image选择了ubuntu,那么软件管理部分只能使用ubuntu的命令。RUN指令可以有多条,每条RUN指令将在当前镜像基础上执行指定命令,并提交为新的镜像。当命令较长时,可以用\\来换行。
该指令有两种格式:

# 在shell终端中运行 – `/bin/sh -c`
RUN <command>
# 使用exec执行
RUN [\”executable\”, \”param1\”, \”param2\” … ]

(4)CMD(设置容器启动时执行的操作)
设置指令,用于容器启动时指定的操作。该操作可以是执行自定义脚本,也可以是执行系统命令。该指令只能在文件中存在一次,如果有多个,则只执行最后一条。
该指令有三种格式:

# 格式一:like an exec, this is the preferred form
CMD [\”executable\”,\”param1\”,\”param2\”]
# 格式二:as a shell
CMD command param1 param2
# 当Dockerfile指定了ENTRYPOINT,那么使用下面的格式:作为ENTRYPOINT的缺省参数
CMD [\”param1\”,\”param2\”]

注意:

CMD运行在镜像构建之后,容器启动的时候;CMD只执行最后一条CMD可以被用户指定的命令覆盖
(5)ENTRYPOINT(设置容器启动时执行的操作)
设置指令,指定容器启动时执行的命令,可以多次设置,但是只有最后一个有效。
两种格式:

# 格式一:like an exec, this is the preferred form
ENTRYPOINT [\”executable\”, \”param1\”, \”param2\”]
# 格式二:as a shell
ENTRYPOINT command param1 param2

该指令的使用分为两种情况,一种是独自使用,另一种和CMD指令配合使用。

当独自使用时,如果你还使用了CMD命令且CMD是一个完整的可执行的命令,那么CMD指令和ENTRYPOINT会互相覆盖只有最后一个CMD或者ENTRYPOINT有效:

# CMD指令将不会被执行,只有ENTRYPOINT指令被执行
CMD echo “Hello, World!”
ENTRYPOINT ls -l

另一种用法和CMD指令配合使用来指定ENTRYPOINT的默认参数,这时CMD指令不是一个完整的可执行命令,仅仅是参数部分;ENTRYPOINT指令只能使用JSON方式指定执行命令,而不能指定参数:

FROM ubuntu
CMD [\”-l\”]
ENTRYPOINT [\”/usr/bin/ls\”]

注意:

和CMD指令基本一样,但是不能被用户指定的命令所覆盖;可以和CMD组合使用,ENTRYPOINT提供不可变得命令,CMD提供缺省参数。
(6)USER(设置容器的用户)
设置指令,设置启动容器的用户,默认是root用户。

# 指定memcached的运行用户
ENTRYPOINT [\”memcached\”]
USER daemon
# 或
ENTRYPOINT [\”memcached\”, \”-u\”, \”daemon\”]

(7)EXPOSE(指定容器需要映射到宿主机器的端口)
设置指令,该指令会将容器中的端口映射成宿主机器中的某个端口。格式为:

EXPOSE <port> [<port> …]

例如:

EXPOSE 80 443 11211

告诉Docker服务端容器暴露的端口号,供互联系统使用。在启动容器时需要通过-P,Docker主机会自动分配一个端口转发到指定的端口;使用-p,则可以具体指定哪个本地端口映射过来。

(8)ENV(用于设置环境变量)
构建指令,在image中设置一个环境变量。格式:

ENV <key> <value>

设置了后,后续的RUN命令都可以使用,容器启动后,可以通过docker inspect查看这个环境变量,也可以通过在docker run –env key=value时设置或修改环境变量。

假如你安装了JAVA程序,需要设置JAVA_HOME,那么可以在Dockerfile中这样写:

ENV JAVA_HOME /path/to/java/dirent

(9)ADD(从src复制文件到容器的dest路径)
构建指令,所有拷贝到容器中的文件和文件夹权限为0755,uid和gid为0。格式为:

ADD <src> <dest>

<src> 是相对被构建的源目录的相对路径,可以是文件或目录的路径,也可以是一个远程的文件url;<dest>是容器中的绝对路径。

该命令将复制指定的<src>到容器中的<dest>。其中<src>可以是Dockerfile所在目录的一个相对路径(文件或目录);也可以是一个URL;还可以是一个tar文件(自动解压为目录)。

如果是一个目录,那么会将该目录下的所有文件添加到容器中,不包括目录;如果文件是可识别的压缩格式,则docker会帮忙解压缩(注意压缩格式);如果<src>是文件且<dest>中不使用斜杠结束,则会将<dest>视为文件,<src>的内容会写入<dest>;如果<src>是文件且<dest>中使用斜杠结束,则会<src>文件拷贝到<dest>目录下。

(10)COPY
格式为

COPY <src> <dest>

复制本地主机的<src>(为Dockerfile所在目录的相对路径,文件或目录)为容器中的<dest>。目标路径不存在时,会自动创建。
当使用本地目录为源目录时,推荐使用COPY。

(11)VOLUME(指定挂载点))
设置指令,使容器中的一个目录具有持久化存储数据的功能,该目录可以被容器本身使用,也可以共享给其他容器使用。我们知道容器使用的是AUFS,这种文件系统不能持久化数据,当容器关闭后,所有的更改都会丢失。当容器中的应用有持久化数据的需求时可以在Dockerfile中使用该指令。格式:

VOLUME [\”<mountpoint>\”]

示例:

FROM base
VOLUME [\”/tmp/data\”]

运行通过该Dockerfile生成image的容器,/tmp/data目录中的数据在容器关闭后,里面的数据还存在。例如另一个容器也有持久化数据的需求,且想使用上面容器共享的/tmp/data目录,那么可以运行下面的命令启动一个容器:

docker run -t -i -rm -volumes-from container1 image2 bash

container1为第一个容器的ID,image2为第二个容器运行image的名字。

(12)WORKDIR(切换目录)
设置指令,可以多次切换(相当于cd命令),对RUN,CMD,ENTRYPOINT生效。格式:

WORKDIR /path/to/workdir

示例:

# 在 /p1/p2 下执行 vim a.txt
WORKDIR /p1
WORKDIR p2
RUN vim a.txt

(13)ONBUILD(在子镜像中执行)

ONBUILD <Dockerfile关键字>

ONBUILD 指定的命令在构建镜像时并不执行,而是在它的子镜像中执行。

(14)ARG(指定构建过程中使用的环境变量)

ARG buildno
ARG password
RUN echo \”Build number: $buildno\”
RUN script-requiring-password.sh \”$password\”

Docker Compose

Compose是用于定义和运行复杂Docker应用的编排工具(旧版本叫Fig)。你可以在一个文件中定义一个多容器的应用,然后使用一条命令来启动你的应用,然后所有相关的操作都会被自动完成。

资料:
https://docs.docker.com/compose
GitHub – docker/compose: Define and run multi-container applications with Docker

安装Compose

# 方法一:
curl -L https://github.com/docker/compose/releases/download/1.8.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
# 方法二:
yum install python-pip python-dev
pip install docker-compose

查看版本号:

$ docker-compose –version
docker-compose 1.8.0

Compose示例

docker-compose.yml内容

web:
image: wordpress:latest
links:
– db:mysql
ports:
– \”8002:80\”
db:
image: mysql
environment:
– MYSQL_ROOT_PASSWORD=123456

启动应用:

docker-compose up

docker-compose.yml常用指令

image:镜像的ID
build:直接从pwd的Dockerfile来build,而非通过image选项来pull
links:连接到那些容器。每个占一行,格式为SERVICE[:ALIAS],例如 – db[:database]
external_links:连接到该compose.yaml文件之外的容器中,比如是提供共享或者通用服务的容器服务。格式同links
command:替换默认的command命令
ports: 导出端口。格式可以是:

ports:
-\”3000\”
-\”8000:8000\”
-\”127.0.0.1:8001:8001\”

expose:导出端口,但不映射到宿主机的端口上。它仅对links的容器开放。格式直接指定端口号即可。
volumes:加载路径作为卷,可以指定只读模式:

volumes:
-/var/lib/mysql
– cache/:/tmp/cache
-~/configs:/etc/configs/:ro

volumes_from:加载其他容器或者服务的所有卷

environment:
– RACK_ENV=development
– SESSION_SECRET

env_file:从一个文件中导入环境变量,文件的格式为RACK_ENV=development
extends:扩展另一个服务,可以覆盖其中的一些选项。一个sample如下:

# common.yml
webapp:
build:./webapp
environment:
– DEBUG=false
– SEND_EMAILS=false
# development.yml
web:extends:
file: common.yml
service: webapp
ports:
-\”8000:8000\”
links:
– db
environment:
– DEBUG=true
db:
image: postgres

net:容器的网络模式,可以为\”bridge\”, \”none\”, \”container:[name or id]\”, \”host\”中的一个。
dns:可以设置一个或多个自定义的DNS地址。
dns_search:可以设置一个或多个DNS的扫描域。
其他的working_dir, entrypoint, user, hostname, domainname, mem_limit, privileged, restart, stdin_open, tty, cpu_shares,和docker run命令是一样的,这些命令都是单行的命令。例如:

cpu_shares:73
working_dir:/code
entrypoint: /code/entrypoint.sh
user: postgresql
hostname: foo
domainname: foo.com
mem_limit:1000000000
privileged:true
restart: always
stdin_open:true
tty:true

docker-compose 自定义网络

创建自定义网络时,指定了网段

$ docker network create –subnet=172.18.0.0/16 mynetwork

在 yml 文件中,指定一下外部自定义网络,并绑定 IP 即可。
示例

version: \’3\’
services:
mysql:
image: mysql:5.7
container_name: mysql
ports:
– \’3336:3306\’
volumes:
– /data/mysql/conf:/etc/mysql/conf.d
– /data/mysql/data:/var/lib/mysql
environment:
– MYSQL_ROOT_PASSWORD=123456
networks:
default:
ipv4_address: 172.18.0.31
networks:
default:
external:
name: mynetwork
#以上关于Docker 一文详解介绍的相关内容来源网络仅供参考,相关信息请以官方公告为准!

原创文章,作者:CSDN,如若转载,请注明出处:https://www.sudun.com/ask/92967.html

Like (0)
CSDN的头像CSDN
Previous 2024年7月4日
Next 2024年7月4日

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注