适合读者
Dockerfile,docker-compose(docker compose)初学者,老司机。
Dockerfile
Dockerfile简介
Dockerfile就是镜像的描述文件,作用是根据描述的字段定义制作一个新的镜像。
如何通过Dockerfile构建自己的镜像?
-
在指定位置创建一个Dockerfile文件,编写Dockerfile相关语法。
-
通过Dockerfile构建镜像
docker build -t name:v1.0 . #.表示指定Dockerfile文件所在位置。-t表示tag docker build -f Dockerfile2 -t mycentos:1.0.0 . #修改默认的默认使用的Dockerfile文件
镜像,容器,仓库之间关系
Dockerfile规范:
-
习惯性把Dockerfile的第一个字母大写,
- 因为build构建的时候默认是这个文件名,也可以修改构建时加上-f参数:docker build -f test
-
一行只存在一条命令,命令按照从上到下执行。
-
上下文路径,就是Dockerfile文件所在路径。比如Dockerfile在宿主机/root目录,那么/root就是上下文路径。
-
#表示注释,请单独放一行,不要放在命令行后面。
-
经验:Dockerfile构建后,运行容器,此时执行:docker inspect 容器名 ,可以看到所有构建过程中的效果,比如构建的环境变量,工作目录,网络等信息。
Dockerfile构建步骤:
-
把Dockerfile文件写在目录a,Dockerfile路径就是上下文(context)路径。
-
docker build命令开始构建,就会把目录a的所有文件一起发送到docker engine;所以通常,我们习惯性把Dockerfile建立一个单独的目录。如果一些文件不需要发的写上.dockerIgnore参数。
-
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
Dockerfile命令
文档:https://docs.docker.com/engine/reference/builder
-
FROM命令。第一个命令必须是FROM,当前镜像是基于哪个镜像的。基于的镜像如果没有会自动下载。
-
RUN命令
- 构建镜像时需要执行的指令。
- 有两种形式:
RUN <command>
(shell形式,命令在 shell 中运行,默认/bin/sh -c
在 Linux 或cmd /S /C
Windows 上)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,或者宿主机变量引用?
- 情况a,构建的时候,使用Dockerfile命令ENV定义的变量,这个很简单。
- 情况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可以做什么?
- 可以对容器进行编排
- 可以站在项目管理的角度管理一组容器。
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
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
重要的命令清单:
-
docker-compose up命令很强大,后面如果没有写服务id,则会启动所有服务。且它会自动完成包括构建镜像,重新创建服务,启动服务,并关联服务相关容器的一系列操作,链接的服务都将会被启动,除非已经处于状态。 如果服务容器已经存在,然后你修改了compose文件,up会停止容器,然后重新读取文件创建容器。
docker-compose -f docker-compose.yml #指定某个compose文件 docker-compose up -d #在后台启动
-
down 对整个项目操作;后面如果接服务id,那么对一个服务操作;并且移除网络,如果有创建网络的情况下。
注意:不移除数据卷。
-
exec命令只能针对服务id,执行某个命令。如果是执行bash,会进入某个服务内部。
docker-compose exec fuwuid bash
-
ps命令。列出运行的服务,退出的服务没显示
docker-compose ps -q #只显示服务id
-
restart命令。重启某个服务,或者整个项目。
-
rm命令。删除停止状态的整个项目,或者某个服务。没停止强制删除不可以,加-f选项是表示删除的时候是否提示,不是强制删除,老师的解释有点问题。-s表示删除前停止。-v表示删除卷,默认不删除卷。
docker-compose rm -f -s tomcat1 #使用这个命令可以删除没停止的服务。达到强制删除的效果。
-
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
-
ps命令。列出容器,不是服务。
-
pause,unpause,暂停和恢复服务。服务状态有几种:启动,退出,暂停
-
logs。查看整个项目、或某个服务的日志。-f表示动态查看。
docker-compose logs [服务id]
docker可视化工具
别的公司,根据docker 接口写的一个工具的,可视化展示本台机器或者远端机器docker,叫做Portainer。
第三方公司,不是docker公司的。
Portainer项目是开源的。非常有用,方便调试看日志,监控,可以连接本地docker也可以连接远端docker,有空一定要研究。前提是命令很熟悉了。