Dockerfile和docker compose
踏歌行 2023-02-04
工具
自动化
阅读量:
从应用软件的角度看:
- Dockerfile:面向开发,是软件的原材料
- Docker镜像:是交付标准
- Docker容器:是部署与运维,是镜像的运行态 摘自 (opens new window)
# Dockerfile
Dockerfile是为了避免不断commit得到镜像的麻烦,而根据脚本构建Docker镜像的文本文件。
官网介绍 (opens new window)
使用步骤:
- 编写Dockerfle文件
docker build -t 新镜像名字:TAG
命令构建镜像docker run
根据镜像运行实例
# DockerFile基础知识
- 保留字指令所有字母大写,指令后面至少跟一个参数
- 指令从上到下,按顺序执行
#
表示注释- 每条指令都会创建一个新的镜像层,并对镜像进行提交
# 常用保留字指令
FROM
:基础镜像EXPOSE
: 对外暴露端口WORKDIR
: 容器开始后的目录ENV
: 设置环境变量ADD
: 是COPY
加解压tar压缩包,并自动处理URLCOPY
: 拷贝文件和目录到镜像中VOLUME
: 容器数据卷,共享数据RUN
: 运行指令,支持shell和exec命令。docker build
时做的事情CMD
:和RUN
相似,但CMD
在docker run
时执行。Dockerfile中,只有最后一个CMD
生效,若docker run
之后有参数,则该参数表示的命令有效,Dockerfile中的CMD
被替换ENTRYPOINT
:和CMD
指令类型,但是ENTRYPOINT
不会被docker run
后面的指令覆盖,而是将这些命令行参数作为参数传给ENTRYPOINT
# Docker compose编排
curl -SL https://github.com/docker/compose/releases/download/v2.14.2/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
docker-compose --version
# 例子:CAdvisor监控收集 + InfluxDB存储数据 + Granfana展示数据
使用docker compose编排
- 在/mydocker/cig绝对路径下新建文件 docker-compose.yml
version: '3.1'
volumes:
grafana_data: {}
services:
influxdb:
image: tutum/influxdb:0.9
restart: always
environment:
- PRE_CREATE_DB=cadvisor
ports:
- "8083:8083"
- "8086:8086"
volumes:
- ./data/influxdb:/data
cadvisor:
image: google/cadvisor
links:
- influxdb:influxsrv
command: -storage_driver=influxdb -storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086
restart: always
ports:
- "8080:8080"
volumes:
- /:/rootfs:ro
- /var/run:/var/run:rw
- /sys:/sys:ro
- /var/lib/docker/:/var/lib/docker:ro
grafana:
user: "104"
image: grafana/grafana
user: "104"
restart: always
links:
- influxdb:influxsrv
ports:
- "3000:3000"
volumes:
- grafana_data:/var/lib/grafana
environment:
- HTTP_USER=admin
- HTTP_PASS=XXXXXX
- INFLUXDB_HOST=influxsrv
- INFLUXDB_PORT=8086
- INFLUXDB_NAME=cadvisor
- INFLIXDB_USER=root
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
- 检查compose文件的语法:
docker-compose config -q
- 启动:
docker-compose up -d
- 带有资源限制的启动:
docker-compose --compatibility up -d
- 查看是否启动成功:
docker ps
- 查看cadvisor: 8080端口;influxdb:8083端口;grafana:3000端口