适合读者

Dockerfile,docker-compose(docker compose)初学者,老司机。

Dockerfile

Dockerfile简介

Dockerfile就是镜像的描述文件,作用是根据描述的字段定义制作一个新的镜像。

如何通过Dockerfile构建自己的镜像?

  1. 在指定位置创建一个Dockerfile文件,编写Dockerfile相关语法。

  2. 通过Dockerfile构建镜像

    docker build -t name:v1.0 . #.表示指定Dockerfile文件所在位置。-t表示tag
    docker build -f Dockerfile2 -t mycentos:1.0.0 .  #修改默认的默认使用的Dockerfile文件
    

镜像,容器,仓库之间关系

image.png

Dockerfile规范:

  • 习惯性把Dockerfile的第一个字母大写,

    • 因为build构建的时候默认是这个文件名,也可以修改构建时加上-f参数:docker build -f test
  • 一行只存在一条命令,命令按照从上到下执行。

  • 上下文路径,就是Dockerfile文件所在路径。比如Dockerfile在宿主机/root目录,那么/root就是上下文路径。

  • #表示注释,请单独放一行,不要放在命令行后面。

  • 经验:Dockerfile构建后,运行容器,此时执行:docker inspect 容器名 ,可以看到所有构建过程中的效果,比如构建的环境变量,工作目录,网络等信息。

Dockerfile构建步骤:

  1. 把Dockerfile文件写在目录a,Dockerfile路径就是上下文(context)路径。

  2. docker build命令开始构建,就会把目录a的所有文件一起发送到docker engine;所以通常,我们习惯性把Dockerfile建立一个单独的目录。如果一些文件不需要发的写上.dockerIgnore参数。

  3. Dockerfile的每一行命令会生成一个临时image,第二行命令一句第一行再生成一个临时image,直到最后一条命令。临时image会存放到缓存docker cache中,这样设计的目的是下次修改Dockerfile的时候,能快速从缓存读取,速度快。等会儿看日志可以看得到。

    #构建示例
    [root@gitlab ems]# docker build -t mycentos:1.0.7 .
    Sending build context to Docker daemon  216.5MB
    Step 1/8 : FROM centos:latest
     ---> 300e315adb2f
    Step 2/8 : RUN echo 11 >> /tmp/1.txt
     ---> Using cache  #原来有缓存,使用缓存
     ---> e0328869b3f9
    Step 3/8 : RUN ["/bin/bash","-c","echo 22 >> /tmp/1.txt"]
     ---> Using cache
     ---> 3d1b3bee45fe
    Step 4/8 : WORKDIR /tmp
     ---> Using cache
     ---> 98e35136b720
    Step 5/8 : EXPOSE 8080/tcp 8081/tcp
     ---> Using cache
     ---> 61d499141810
    Step 6/8 : ENV username="root" passwd="password_01"
     ---> Using cache
     ---> 8a6a373c1c22
    Step 7/8 : ADD hostfile.txt /tmp/
     ---> Using cache
     ---> 68d58ff9c559
    Step 8/8 : CMD docker-compose
     ---> Running in 9c875e0f18f2
    Removing intermediate container 9c875e0f18f2
     ---> a5dd0adcaabf
    Successfully built a5dd0adcaabf
    Successfully tagged mycentos:1.0.7
    
    

image.png

Dockerfile命令

文档:https://docs.docker.com/engine/reference/builder

  • FROM命令。第一个命令必须是FROM,当前镜像是基于哪个镜像的。基于的镜像如果没有会自动下载。

  • RUN命令

    • 构建镜像时需要执行的指令。
    • 有两种形式:
    • RUN <command>shell形式,命令在 shell 中运行,默认/bin/sh -c在 Linux 或cmd /S /CWindows 上)
    • RUN ["executable", "param1", "param2"]执行形式)
    您可以使用\(反斜杠)将单个 RUN 指令继续到下一行
    RUN /bin/bash -c 'source $HOME/.bashrc; \
    echo $HOME'
    
    
    RUN /bin/bash -c 'source $HOME/.bashrc; echo $HOME'
    RUN ["/bin/bash", "-c", "echo hello"] #常用这个形式
    RUN yum install -y net-tools && ifconfig
    
    Dockerfile可以写多个RUN,都会执行。
    
  • MAINTAINER,新版已经废弃掉了。

  • EXPOSE命令。

    • (只是声明,是给别人看的,做个提示,不写也行。)
      声明某个服务需要暴露的端口,这里你不声明后期也可以暴露(docker run -p的时候),只是为了让看的人有个更好的描述,明白知道用什么端口号,或者暴露什么端口号就可以了。声明的端口,不会暴露到宿主机。
      
  • WORKDIR命令。在创建容器后,终端默认登录进来的工作目录,一个落脚点。

  • ENV。用来在构建镜像过程中,设置环境变量。

    • ENV username="root" passwd="password_01"
      
  • ADD。将宿主机上下文目录下的文件拷贝到镜像内,能处理:文件、目录、tar、tgz 等包解压(zip不能解压)、从URL下载文件(推荐使用)。

    • 支持通配符,*表示所有;?替换为任何单个字符;

    • 文档https://docs.docker.com/engine/reference/builder/#add

    • ADD 有两种形式:
      ADD [--chown=<user>:<group>] <src>... <dest>
      ADD [--chown=<user>:<group>] ["<src>",... "<dest>"] #路径有空格的使用这种
      
      ADD --chown=55:mygroup files* /somedir/
      
      ADD hostfile.txt /tmp/  #将上下文目录(宿主机目录)下hostfile.txt,添加一个到镜像/tmp下。
      ADD hostfile.tar.gz /tmp/ #将上下文目录(宿主机目录)下hostfile.tar.gz,解压后,添加一个到镜像/tmp下
      
      ADD dist /usr/share/nginx/html #把disk文件夹下的内容,复制到/usr/share/nginx/html
      
  • COPY。和ADD命令类似,只是功能少一些,将宿主机目录下的文件拷贝到镜像类,能处理:文件、目录。

  • VOLUME。容器数据卷,用于数据保存和持久化工作。

    • (只是声明,是给别人看的,做个提示,不写也行。)告别别人某个目录可以挂载到宿主机目录。
  • CMD和ENTRYPOINT命令。

    • 都是用来指定容器启动时(docker run时)默认执行指令。

    • Dockerfile中CMD,ENTRYPOINT可以有多个,但是只会最后一个生效。

    • 都有2种写法:shell命令方式、json数组方式(推荐数组,一定要习惯使用此方法)

    • java -jar ems.jar
      ["java","-jar","ems.jar"]
      
      二者区别:覆盖参数的方法不一样
      CMD命令覆盖参数:docker run mycentos:v1 ls /apps(ls /apps是自定义的指令和参数,要覆盖Dockerfile,就把它写到docker run的最后)
      
      ENTRYPOINT覆盖参数,要加--entrypint且在最后加参数:
      docker run --entrypint=ls mycentos:v1 /apps(--entrypint=覆盖指令,/apps是传递参数)
      
      如何使用?
      答:因为二者覆盖参数方式不一样,所以通常结合使用。
      ENTRYPOINT通常写在前面,用来书写一个容器固定的指定命令。
      CMD用来给ENTRYPOINT传递参数。
      注意:配合使用,必须使用json数组方式语法。
      
      配合使用展示:
      ENTRYPOINT ["java","-jar"]
      CMD ["ems.jar"]
      #docker run容器的时候会执行java -jar ems.jar ,如果docker run的时候要修改ems.jar参数,执行命令:docker run -d mycentos:1.0.1 ems2.jar,而不需要像前面加参数--entrypint或全部把所有指令写到最后。
      
      
  • ARG命令。该ARG指令定义了一个变量,用户可以在构建时通过使用 标志的docker build --build-arg 命令将其传递给构建器。--build-arg <varname>=<value>如果用户指定了未在 Dockerfile 中定义的构建参数,则构建会输出警告。

    • [Warning] One or more build-args [riqi2222] were not consumed
      
    • 可以给他设置缺省值,如果--build-arg没设置参数,ARG变量就会使用缺省值。

    • ARG <name>[=<default value>]  例子:ARG name=root
      
    • 文档:https://docs.docker.com/engine/reference/builder/#arg

Dockerfile环境变量引用

如何在dockerfile中使用变量,比如date,或者宿主机变量引用?

  1. 情况a,构建的时候,使用Dockerfile命令ENV定义的变量,这个很简单。
  2. 情况b,引用Dockerfile外部的环境变量,这里引用docker build --build-arg 参数定义的变量,--build-arg 参数就可以调用系统变量。
docker build --build-arg 参数定义的变量,在Dockerfile不能直接接收,必须要用ENV指令接收。

[root@gitlab ems]# vim Dockerfile 
FROM centos:latest
ARG riqi2 #
ENV riqi=20220822
RUN echo ${riqi} >> /tmp/1.txt
RUN echo ${riqi2} >> /tmp/1.txt
[root@gitlab ems]# docker build --build-arg riqi2=2022 -t mycentos:1.0.11 .  


docker build --build-arg riqi2=`date +%s` -t mycentos:1.0.12 .   #--build-arg 参数调用系统命令date获取时间戳。

docker build --build-arg riqi2=`echo $HOME` -t mycentos:1.0.12 .  #调用宿主机系统变量。

环境变量引用的时候,带默认值设置规则:

  • ${variable:-word}表示如果variable已设置,则结果将是该值。如果variable未设置,word则将是结果。
  • ${variable:+word}表示如果variable设置则为word结果,否则为空字符串。

Dockerfile样例

[root@gitlab ems]# cat Dockerfile 
FROM centos:latest
ENV riqi=20220822
ENV username="root" passwd="password_01"
RUN echo ${riqi} >> /tmp/1.txt

#引用变量,如果变量没设置,就是缺省值riqi333
RUN echo ${riqi3:-riqi333} >> /tmp/1.txt
RUN ["/bin/bash","-c","echo 22 >> /tmp/1.txt"]
WORKDIR /tmp
EXPOSE 8080/tcp 8081/tcp
ADD hostfile.tar.gz /tmp/
ENTRYPOINT ["java","-jar"]
CMD ems.jar

场景1-制作一个image

我有个一个前端的html工程文件夹,结合nginx做一个镜像。

文件:html工程文件夹叫做dist、基础镜像nginx

操作步骤:
1、基于nginx基础镜像,写一个Dockerfile文件,把工程文件夹dist的内容传到nginx默认启动页面目录。


[root@gitlab chenmh]# ls dist
css  favicon.ico  faviconv.ico  fonts  img  index.html  js
[root@gitlab chenmh]# cat Dockerfile 
FROM nginx:latest 
#使用基础镜像nginx

#定义工作目录
ENV workpath="/usr/share/nginx/html"
WORKDIR $workpath

#把dist文件夹的内容复制到nginx启动后默认目录
ADD dist $workpath

#这个是测试用的,用的时候测试需要,已注释掉了。
#CMD ls $workpath

[root@gitlab chenmh]# docker build  -t mycentos:1.0.12 .
[root@gitlab chenmh]# docker images
REPOSITORY         TAG           IMAGE ID       CREATED          SIZE
chenmh             1.0.2         6174db97222d   29 minutes ago   156MB

[root@gitlab chenmh]# docker run -d -p 80:80 chenmh:1.0.2

docker-compose介绍

​ 一个项目当中不可能只用到1个容器,可能会用到10个容器,每个容器去docker run启动,这个谁也记不住。由此引发出了compose工具容器编排,他也是开源的。

​ compose是开源的,负责对docker容器集群的快速编排。从功能上看,根openstack的heat十分类似,代码在https://github.com/docker/compose开源。

​ 是python编写的,实现调用了docker服务提供的api来对容器进行管理,因此,只要说操作的平台支持docker api就可以在其上利用compose。

compose目的:

  • 为了完成一个项目中使用到多个容器,容器之间会产生一种依赖,比如启动一个容器,必须另外一个容器先启动。
  • 站在项目管理的角度管理一组容器。

compose可以做什么?

  1. 可以对容器进行编排
  2. 可以站在项目管理的角度管理一组容器。

compose两个重要概念:

  • 项目(project),由一组关联的应用容器组成的一个完整业务单元,在docker-compose.yml文件定义。compose的默认管理对象是项目,通过子命令对项目中的一组容器进行便捷的生命周期管理 。

  • 服务(service)。一个应用的容器。实际可以包括若干个实例容器。可以理解一个服务是1个容器,一个服务也可以是多个容器,在compose启动的时候有个scale参数,表示定义的1个服务,可以实例化成多个容器。

  • compose执行的时候会把当前目录当做一个项目, 在日志可以看到。生成的服务名(或容器)也会携带项目名。

compose安装

Docker Compose 是命令行的工具,如果用的mac或者windows,他是随着安装docker的时候已经安装上的。但是linux系统需要单独的安装Docker Compose。

安装方法:

  • yum安装
  • 安装到docker到用户/home/.docker/cli-plugins/目录下
  • 手动独立安装(视频里面用这种,常用)

安装方法文档:https://docs.docker.com/compose/install/compose-plugin/#install-using-the-repository

  • linux方法1(手动独立安装,常用)

​ 很简单,linux版本的docker compose是一个二进制文件,下载进来,拷贝到环境变量目录下,添加执行权限就好了。

curl -L https://github.com/docker/compose/releases/tag/1.25.5/docker-compose-`uname -s`-`uname -m` > /usr/local/sbin/docker-compose

chmod +x /usr/local/sbin/docker-compose

[root@node3 ~] # docker-compose version
docker-compose version 1.25.5, build 8a1c60f6
docker-py version: 4.1.0
CPython version: 3.7.5
OpenSSL version: OpenSSL 1.1.0l  10 Sep 2019
  • linu方法2(yum方式)

    yum install "docker-compose-plugin"  #docker-compose-plugin 来自docker-ce-stable  仓库
    [root@gitlab chenmh]# docker compose version
    Docker Compose version v2.6.0
    

compose模板命令

中文文档https://yeasy.gitbook.io/docker_practice/compose/compose_file

compose文件样例1

[root@node3 ems] # cat docker-compose.yml 
version: "3.0"
services: 
  tomcat1:
    container_name: tomcat01
    image: tomcat:latest
    ports: 
      - 10080:8080
    environment:
      - "name1=root"
      - "password=pwd"
    volumes: 
      - myvol:/var/lib/hosttmp
    depends_on: #依赖于tomcat2,tomcat2就会先启动
      - tomcat2

  tomcat2:
    image: "tomcat:${lastversion}" #${lastversion}会从当前目录.env文件读取,如果这个文件不存在会报错
    container_name: tomcat02
    ports:
      - 10081:8080
    environment: #习惯用双引号括起来,名字和value之间用等号。另外一种写法不要引号,名字和value之间用冒号
      - "name_1=test-test1"
    extra_hosts:
      - "dockerhub:52.1.157.61"
    labels:
        miaoshu: "this is labels region"
    networks:
      - network1
    volumes:
      - /tmp/test1:/var/lib/hosttmp1
      - /tmp/test2:/var/lib/hosttmp2:ro #设置只读,默认可写
    working_dir: /var/lib #使用docker exec进入容器后的目录

volumes:
  myvol:
networks:
  network1:

[root@node3 ems] # cat .env
username1=admin
password1=pwd
desc1="this is desc"
lastversion=latest
[root@gitlab chenmh]# docker-compose up -d

列表:

  • build指令,通过docker-compose在启动容器之前,先根据dockerfile构建镜像,然后根据构建镜像启动容器。指定 Dockerfile 所在文件夹的路径(可以是绝对路径,或者相对 docker-compose.yml 文件的路径)。

  • command指令。覆盖容器启动后默认执行的命令,它执行在容器内部。一般不使用这个,会覆盖掉dokerfile启动后的命令。

  • container_name指令。指定docker-compose启动容器名称,注意:不推荐指定容器名称,指定名称后scale命令使用会报错,因为有相同名字了。默认将会使用 项目名称_服务名称_序号 这样的格式。

  • depends_on指令。解决容器的依赖、启动先后的问题。

    • 注意:当前服务不会等待被依赖服务完全启动之后才启动,启动一半多的时候就启动了。
    • 本服务依赖于哪个服务,哪个服务就先启动,本服务后启动。
  • environment指令。用来给容器启动指定环境变量,相当于docker run -e选项。有多个重复字段,最后一个会覆盖前面的字段。

  • env_file指令。用来给容器启动指定环境变量文件,相当于docker run -e选项。

  • expose指令。用来指定构建镜像过程中容器暴露的端口号。

  • image指令。用来指定启动容器使用镜像,相当于docker run image

  • networks指令。用来指定启动容器使用网桥,相当于docker run --network;使用的网桥要在最后声明,否则会报错未声明

  • network_mode。设置网络模式。桥接,还是主机模式,none,共享模式。

  • ports指令。用来指定宿主机和容器端口映射,相当于docker run -p

  • volumes。用来指定宿主机中容器目录卷映射,相当于docker run -v

  • restart。用来指定docker容器(服务)总是运行,相当于docker run --restart=always

  • extra_hosts指令。类似 Docker 中的 --add-host 参数,指定额外的 host 名称映射信息,会在启动后的服务容器中 /etc/hosts 文件中添加条目。

  • healthcheck指令。通过命令检查容器是否健康运行,可以判断端口是否已经启动。

读取变量

  • 文档:https://yeasy.gitbook.io/docker_practice/compose/compose_file#du-qu-bian-liang

  • Compose 模板文件支持动态读取主机的系统环境变量和当前目录下的 .env 文件中的变量。

    version: "3"
    services:
    
    db:
      image: "mongo:${MONGO_VERSION}"
     
     #注意:
    #1 ${MONGO_VERSION}默认会读取当前目录存在 .env 文件,执行 docker-compose up命令时将从该文件中读取变量。 .env文件在上面不需要用其它命令指定。
    #2 environment指令字段的变量,是在创建后才会生成,如果想${MONGO_VERSION}从指令environment读取,是读取不到的,只能从.env文件。
    #3 ${MONGO_VERSION}可以从宿主机的系统环境变量中读取,比如可以写在/etc/profile
    

自己百度找一个docker部署es命令,根据命令写一个compose.yaml文件

compose模板命令-个人总结

Compose 文件的默认路径是../docker-compose.yml

docker-compose.yml文件示例1

compose文件格式要求:

  • version字段和docker 引擎有对应依赖关系
  • 数组列表有-的,在-下面的字段,冒号后不要空格。比如port字段下面的字段
  • environment字段下面的字段,必须要用双引号,否则执行后不会生效。
  • volumes字段,有两种方式挂载,一种是绝对路径,一种是别名。使用别名的时候,记得在最后要声明这个卷,下面有案例。
version: "3.9" #和docker 引擎有对应依赖关系,看下面解释
services: #必备服务列表名字

  redis:  #第一个服务名字
  	container_name: redis01 #容器名,如果不写,默认会按照项目名_服务名_序号,拼接成容器名。
    image: redis:last
    ports:  #两种写法。第一个6379参数表示宿主机端口,第二个端口表示容器端口;数组列表有-的,冒号后不要空格
      - "6379:6379"
      - 10080:8080
    volumes: #第一个参数表示宿主机路径,第二个表示容器内部路径,容器目录不存在会自动创建
      - /root/mysql:/var/lib/mysql
    environment:  #环境变量只有一种写法,必须用双引号。
      - "name1=root"
    networks:
      - frontend
    deploy:
      replicas: 2
      update_config:
        parallelism: 2
        delay: 10s
      restart_policy:
        condition: on-failure
        
[root@node3 ems] # cat docker-compose.yml 

volumes字段使用别名挂载案例

[root@node3 ems] # cat docker-compose.yml 
version: "3.0"
services: 
  tomcat:
    container_name: tomcat01
    image: tomcat:latest
    ports: 
      - 10080:8080
    environment:
      - "name1=root"
      - "password=pwd"
    volumes: #使用别名卷
      - myvol:/var/lib/hosttmp
volumes: #声明卷
  myvol:
  
[root@node3 ems] # docker-compose up     #发现日志会先创建卷
Creating volume "ems_myvol" with default driver
Recreating tomcat01    ... done
Starting ems_tomcat3_1 ... done
Starting ems_tomcat2_1 ... done

[root@node3 ems] # docker volume ls |grep myvol
local     ems_myvol
[root@node3 ems] # 
[root@node3 ems] # docker inspect ems_myvol  #查找卷的路径
[
    {
        "CreatedAt": "2022-08-19T14:33:32+08:00",
        "Driver": "local",
        "Labels": {
            "com.docker.compose.project": "ems",
            "com.docker.compose.version": "1.25.5",
            "com.docker.compose.volume": "myvol"
        },
        "Mountpoint": "/var/lib/docker/volumes/ems_myvol/_data",
        "Name": "ems_myvol",
        "Options": null,
        "Scope": "local"
    }
]
[root@node3 ems] # ls /var/lib/docker/volumes/ems_myvol/_data

version字段

Compose 文件格式版本和docker 引擎版本依赖关系

(docker-compose.yml文件里面version字段写多少依赖docker 引擎),看表

https://docs.docker.com/compose/compose-file/compose-file-v3/

docker engine查看版本:docker version

image.pngimage-20220819082810857


port #两种写法,类似docker run -p。第一个参数10022是宿主机端口
  - 10022:22
  - "8081:8080"
environment: #两种写法,代表给当前容器启动指定环境,类似于docker run -e参数
  - NAME: ROOT
  - "NAME=ROOT"
volumes: #类似docker run -v,宿主机路径不存在docker-compose,对应的某个容器无法启动。
  - 宿主机路径:容器路径
  - /root/mysqldata:/var/lib/mysql

docker-compose各命令

docker-compose up #为一个服务构建,启动一个容器。当修改compose文件后,直接docker-compose up会重新读取文件变化的参数,不需要杀死再启动,up命令比较强悍。
docker-compose up -d  #后台启动
docker-compose up --no-start #只创建不启动
docker-compose down  #Stop and remove containers, networks, images, and volumes,先停止,再删除,执行的时候看日志就知道了。其实这个相当于清楚缓存一样,up过的服务退出后会一直在那里有个历史记录,down会根据本地compose文件全部删掉。 docker-compose restart会根据本地缓存来重启, docker-compose ps可以看到容器状态。
docker-compose restart # 重启服务Restart services,按照compose文件。也可以只重启其中一个。

docker-compose stop  #只停止文件里面的服务,不删除。
docker-compose stop tomcat2 #只停止一个,不加就停止compose文件的所有服务(服务理解就是容器)
docker-compose start  #Start services启动服务

docker-compose kill #强制kill容器
docker-compose rm #删除停止的容器

docker-compose config  #Validate and view the Compose file
docker-compose logs #View output from containers
docker-compose events  #Receive real time events from containers
docker-compose logs tomcatcon    #查看服务tomcatcon的日志。
docker-compose logs -f #动态查看日志

docker-compose scale tomcat3=2 #一次启动多个容器,容器使用的是一个镜像。

docker-compose create  #Create services创建服务不会启动。后面舍弃了,被docker-compose up --no-start替代

docker-compose pull  #从compose文件定义的镜像,先拉取,拉取完成不会重启容器
docker-compose push 

docker-compose ps  # 查看容器
docker-compose ps 可以看到停止的服务(服务理解就是容器),docker ps 要加参数-a才可以看到。
docker-compose images等于docker ps  -a命令,只显示compose文件以前执行过的,docker显示docker以前执行过的历史。


[root@node3 ems] # docker-compose exec tomcat2 bash  #在一个服务运行命令
root@a6335b1ccb08:/usr/local/tomcat# 
root@a6335b1ccb08:/usr/local/tomcat# ls

#创建
[root@node3 ems] # docker-compose up --no-start   
ems_tomcatcon_1 is up-to-date
Recreating ems_tomcat3_1 ... 
Recreating ems_tomcat3_1 ... done
[root@node3 ems] # docker-compose ps
     Name             Command       State             Ports         
--------------------------------------------------------------------
ems_tomcat2_1     catalina.sh run   Up       0.0.0.0:10081->8080/tcp
ems_tomcat3_1     catalina.sh run   Exit 0                          
ems_tomcatcon_1   catalina.sh run   Up       0.0.0.0:10080->8080/tcp
[root@node3 ems] # 
[root@node3 ems] # docker ps -a
CONTAINER ID   IMAGE           COMMAND             CREATED          STATUS                    PORTS                     NAMES
e06b66076dc5   tomcat:latest   "catalina.sh run"   13 seconds ago   Created                                             ems_tomcat3_1
a6335b1ccb08   tomcat:latest   "catalina.sh run"   22 minutes ago   Up 16 minutes             0.0.0.0:10081->8080/tcp   ems_tomcat2_1
2af899bb64ab   tomcat:latest   "catalina.sh run"   22 minutes ago   Up 20 minutes             0.0.0.0:10080->8080/tcp   ems_tomcatcon_1

重要的命令清单:

  1. docker-compose up命令很强大,后面如果没有写服务id,则会启动所有服务。且它会自动完成包括构建镜像,重新创建服务,启动服务,并关联服务相关容器的一系列操作,链接的服务都将会被启动,除非已经处于状态。 如果服务容器已经存在,然后你修改了compose文件,up会停止容器,然后重新读取文件创建容器。

    docker-compose -f docker-compose.yml  #指定某个compose文件
    docker-compose up -d #在后台启动
    
  2. down 对整个项目操作;后面如果接服务id,那么对一个服务操作;并且移除网络,如果有创建网络的情况下。

    注意:不移除数据卷。

  3. exec命令只能针对服务id,执行某个命令。如果是执行bash,会进入某个服务内部。

    docker-compose exec fuwuid bash
    
  4. ps命令。列出运行的服务,退出的服务没显示

    docker-compose ps -q #只显示服务id
    
  5. restart命令。重启某个服务,或者整个项目。

  6. rm命令。删除停止状态的整个项目,或者某个服务。没停止强制删除不可以,加-f选项是表示删除的时候是否提示,不是强制删除,老师的解释有点问题。-s表示删除前停止。-v表示删除卷,默认不删除卷。

    docker-compose rm -f -s tomcat1 #使用这个命令可以删除没停止的服务。达到强制删除的效果。
    
  7. top命令。查看整个项目,或者某个服务容器内运行的进程。

    docker-compose top 【服务id】
    [root@node3 ems] # docker-compose top tomcat1
    tomcat01
    UID     PID    PPID    C   STIME   TTY     TIME                                                                      CMD                                                                  
    ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
    root   22530   22505   6   17:06   ?     00:00:04   /usr/local/openjdk-11/bin/java -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties                              
                                                        -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djdk.tls.ephemeralDHKeySize=2048                                   
                                                        -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Dorg.apache.catalina.security.SecurityListener.UMASK=0027              
                                                        -Dignore.endorsed.dirs= -classpath /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar                          
                                                        -Dcatalina.base=/usr/local/tomcat -Dcatalina.home=/usr/local/tomcat -Djava.io.tmpdir=/usr/local/tomcat/temp                           
                                                        org.apache.catalina.startup.Bootstrap start    
    
  8. ps命令。列出容器,不是服务。

  9. pause,unpause,暂停和恢复服务。服务状态有几种:启动,退出,暂停

  10. logs。查看整个项目、或某个服务的日志。-f表示动态查看。

    docker-compose logs [服务id] 
    

docker可视化工具

别的公司,根据docker 接口写的一个工具的,可视化展示本台机器或者远端机器docker,叫做Portainer。

第三方公司,不是docker公司的。

Portainer项目是开源的。非常有用,方便调试看日志,监控,可以连接本地docker也可以连接远端docker,有空一定要研究。前提是命令很熟悉了。