Docker的常用命令
帮助命令
docker version
容器命令
说明:我们有个镜像才可以创建容器,linux,下载一个centos镜像来测试学习w
docker pull centos
新建容器并启动
docker run [可选参数] image
#参数说明
--name="Name" 容器名字 tomcat01 tomcat02 用来区分容器
-d 后台方式运行
-it 使用交互方式运行,进入容器查看内容
-p 指定容器的端口 -p 8080:8080
-p 主机端口:容器端口
-p 容器端口
-p ip:主机端口:容器端口
容器端口
-P(大写) 随机指定端口
#测试,启动并进入容器
[root@localhost ~]# docker run -it centos /bin/bash
[root@befa73c2a1fd /]# ls #查看容器内的centos,基础版本,很多命令都是不完善的。
bin etc lib lost+found mnt proc run srv tmp var
dev home lib64 media opt root sbin sys usr
#退出命令 从容器退回主机
[root@befa73c2a1fd /]# exit
exit
列出所有的运行的容器
# docker ps 命令
#列出当前正在运行的容器
-a #列出当前正在运行的容器+带出历史运行过的容器
-n=? #显示最近创建的容器
-q #只显示容器的编号
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
befa73c2a1fd centos "/bin/bash" 34 minutes ago Exited (0) 29 minutes ago cool_ramanujan
49a4be7f359a hello-world "/hello" 5 hours ago Exited (0) 5 hours ago naughty_haslett
退出容器
exit #直接容器停止并退出
Ctrl + p + q #容器不停止退出
docker rmi 删除镜像!
docker rmi -f 镜像id #删除指定的镜像
docker rmi -f 镜像id 镜像id 镜像id #删除多个镜像
docker rmi -f $(docker images -aq) #删除所有的镜像
docker rmi 删除容器!
docker rm 容器id #删除指定的容器,不能删除正在运行的容器,如果强制删除-f
docker rm -f 镜像id 镜像id 镜像id #删除多个镜像
docker rm -f $(docker ps -aq) #删除所有的容器
docker ps -a -q | xargs docker rm #删除所有的容器
启动和停止容器的操作
docker start 容器id #启动容器
docker restart 容器id #重启容器
docker stop 容器id #停止当前正在运行的容器
docker kill 容器id #强制停止当前的容器
常用其他命令
后台启动容器
# 命令 docker run -d 镜像名
[root@localhost ~]# docker run -d centos
234d6f5bc2a5d01b69f363998f0f3b1c85eeb2e9d71b2bd7be4de5d35aa35c0d
#问题docker ps 发现centos 停止了
# 常见的坑:docker容器使用后台启动,就必须要有一个前台进程,docker发现没有应用,就会自动停止。
查看日志
#显示日志
-tf #显示日志
--tail number #要显示日志条数
docker logs -tf --tail 10 容器Id
查看容器中进程信息
#命令 docker top 容器id
查看镜像的元数据
docker inspect 容器id
进入当前正在运行的容器
#我们通常容器都是使用后台方式运行的,需要进入容器,修改一些配置
#命令
docker exec -it 容器id
# 这里的-i 选项代表交互式模式,而-t 分配一个伪终端。
# 方式二
docker attach 容器id
#docker exec #进入容器后开启一个新的终端,可以在里面操作(常用)
#docker attach #进入容器正在执行的终端,不会启动新的进程。
从容器内拷贝文件到主机上
docker cp 容器id:容器内路径 目的主机路径
Docker 一些部署的测试
Docker 部署Nginx
#1,搜索镜像 search 可以去docker搜索,可以看到帮助文档
#2.下载镜像,pull
#3,运行测试
[root@localhost home]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest 605c77e624dd 13 days ago 141MB
mysql latest 3218b38490ce 3 weeks ago 516MB
hello-world latest feb5d9fea6a5 3 months ago 13.3kB
centos latest 5d0da3dc9764 3 months ago 231MB
# -d 后台运行
#--name 给容器命令
#-p 宿主机
[root@localhost home]# docker run --name nginx -p 80:80 -d nginx
819563d4625b7d3b1872b874bae052d8bd0b7975e3d8ce160d24a3c9b075339b
#访问测试
root@localhost home]# curl localhost
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
html { color-scheme: light dark; }
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>
<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>
<p><em>Thank you for using nginx.</em></p>
</body>
</html>
#进入Nginx
[root@localhost home]# docker exec -it nginx /bin/bash
root@819563d4625b:/#
Docker 部署Tomcat
#官方的使用
docker run -it --rm tomcat:9.0
#我们之前的启动都是后台,停止了容器之后,容器还是可以查到,docker run -it --rm ,一般是用来测试,用完删除
#下载再启动
docker pull tomcat:9.0
#启动运行
[root@localhost home]# docker run -d -p 3355:8080 --name tomcat tomcat:9.0
6cc5261a27231b91ef787915d9d9c37cc6101e575799e9e35b78cbec9584fc71
#进入容器
[root@localhost home]# docker exec -it tomcat /bin/bash
#问题:1,linux命令少了。2,没有webapps。阿里云镜像的原因,默认是最下的镜像,所有不必要的都剔除掉。
#保证最小可运行的环境。
如何提交一个自己的镜像
Commit镜像
docker commit 提交容器成为一个新的副本
#命令和git原理类似
docker commit -m="提交的描述信息" -a="作者" 容器id 目标镜像名:[TAG]
实战测试
#1,启动一个默认的tomcat
#2,发现这个默认的tomcat是没有webapps应用的,镜像的原因,官方的镜像默认webapps下没有任何文件。
#3,自己拷贝一些基本文件到webapps
#4,将我们操作过的容器通过commit提交为一个镜像!我们以后可以使用我们修改过的镜像。
容器数据卷
什么是容器数据卷
docker的理念回顾
将应用和环境打包为一个镜像!
数据?如果数据都在容器中,那么我们容器删除,数据就会丢失!需求:数据可以持久化
MySQL,容器删了,删库跑路需求:MySQL数据可以存储在本地!
容器之间可以有一个数据共享的技术!Docker容器中产生的数据,同步到本地!
这就是卷技术!目录的挂载,将我们容器内的目录,挂载到linux上。
总结:容器的持久化和同步操作
使用数据卷
方式一:直接使用命令挂载
docker run -it -v 主机目录:容器内目录
#测试
[root@localhost ~]# docker run -it -v /home/test:/home centos /bin/bash
#启动起来的时候,我们可以通过docker inspect 容器id
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-l1AjPPFj-1651884104870)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114114721489.png)]
测试文件的同步
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-msT5Up9k-1651884104871)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114115030402.png)]
再来测试
1,停止容器
2,宿主机上修改文件
3,启动容器
4,容器内的数据依旧是同步的!
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0WWX0IPz-1651884104872)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114115630587.png)]
好处:我们以后只需要在本地修改即可。容器内会自动同步。
实战:安装MySQL
思考:MySQL的数据持久化问题!
#获取镜像
[root@localhost ~]# docker pull mysql:5.7
#运行容器,需要做数据挂载! #安装启动MySQL,需要配置密码,这是要注意点!
#官方测试:docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
#启动:
-d 后台运行
-p 端口映射
-v 卷挂载
-e 环境配置
--name 容器名字
[root@localhost ~]# docker run -d -p 3306:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v/home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql0 mysql:5.6
如果我们将容器删除,挂载到本地的数据卷依旧没有丢失。这就实现了容器数据持久化功能!
具名和匿名挂载
#匿名挂载
-v 容器内路径!
docker run -d -P --name nginx01 -v /etc/nginx nginx
#查看所有的volume的情况
[root@localhost ~]# docker volume ls
DRIVER VOLUME NAME
local 97ef64b1ed6c0d61254cdcca54a129b65b4836076dea05c051797c7fe83e9e02
#这里发现,这种就是匿名挂载,我们在-v只写了容器内的路径,没有写容器外的路径!
#具名挂载
[root@localhost ~]# docker run -d -P --name nginx02 -v juming-nginx:/ect/nginx nginx
DRIVER VOLUME NAME
local juming-nginx
#通过-v 卷名:容器内路径
#查看这个卷
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Sv2Nbg5Y-1651884104872)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114135925625.png)]
所有docker容器内的卷,没有指定目录的情况下都是在/var/lib/docker/volumes/xxxx/_data
我们通过具名挂载可以方便的找到我们的一个卷,大多数情况下使用具名挂载。
#如何确定是具名挂载还是匿名挂载,还是指定路径挂载!
-v 容器内路径 #匿名挂载
-v 卷名:容器内路径 #具名挂载
-v /宿主机路径::容器内路径 #指定路径挂载
拓展:
#通过 -v 容器内路径:ro rw 改变读写权限
ro readonly #只读
rw readwrite #可读可写
#一旦设置了容器权限,容器对我们挂载出来的内容就有限定了。
docker run -d -P --name nginx02 -v juming-ngingx:/etc/nginx:ro nginx
docker run -d -P --name nginx02 -v juming-ngingx:/etc/nginx:rw nginx
#ro 说明和这个路径只能通过宿主机来操作,容器内是无法操作的!
初识Dockerfile
Dockerfile 就是用来构建docker镜像的构建文件!命令脚本!
通过这个脚本可以生成镜像,镜像是一层一层的,脚本一个个的命令,每个命令都是一层!
#创建一个dockerfile文件,名字可以随机,建议dockerfile
#文件中的内容,指令(大写) 参数
FROM centos
VOLUME ["volume01","volume02"]
CMD echo "----end----"
CMD /bin/bash
#这里的每个命令,就是镜像的一层。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-N3QcFkwi-1651884104872)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114142044370.png)]
#启动自己写的容器
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OTQv5T6E-1651884104873)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114142644809.png)]
这个卷和外部一定有一个同步的目录
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kbth31IH-1651884104874)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114142801791.png)]
查看一个卷挂载的路径
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IagTQ4Nu-1651884104874)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114144120756.png)]
数据卷容器
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cNo8ch8V-1651884104874)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114144655242.png)]
结论:容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止。
但是一旦持久化到了本地。这个时候,本地的数据是不会被删除的。
DockerFile
DockerFile介绍
dockerfile是用来构建docker镜像的文件。命令参数脚本!
构建步骤:
1,编写一个dockerfile文件。
2,docker build 构建成为一个镜像。
3,docker run 运行镜像。
4,docker push 发布镜像(DockerHub,阿里云镜像仓库)。
DockerFile构建过程
基础知识:
1,每个保留关键字(指令)都必须是大写字母。
2,执行从上到下顺序执行。
3,#表示注释
4,每一个指令都会创建一个新的镜像层,并提交!
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BBCkGAmc-1651884104875)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114150342599.png)]
dockerfile是面向开发的,我们以后要发布项目,做镜像,就需要编写dockerfile文件,这个文件十分简单!
Docker镜像逐渐成为企业交付的标准。
步骤:开发,部署,运维
DockerFile:构建文件,定义了一切的步骤,源代码。
DockerImages:通过DockerFile构建生成的镜像,最终发布和运行的产品。
Docker容器:容器就是镜像运行起来提供服务。
Docker的基本指令
FROM #基础镜像,一切从这里开始构建。
MAINTAINER #镜像是谁写的,姓名+邮箱
RUN #镜像构建的时候需要运行的命令
ADD #步骤:tomcat镜像,这个tomcat压缩包!添加内容
WORKDIR #镜像的工作目录
VOLUME #挂载的目录
EXPOST #保留端口配置
CMD #指定这个容器启动的时候要运行的命令,只有一个会生效,可被替代。
ENTRYPOINT #指定这个容器启动的时候要运行的命令,可以追加命令。
ONBUILD #当构建一个被集成DockerFile这个时候就会运行ONBUILD的指令。触发指令。
COPY #类似ADD,将我们文件拷贝到镜像中。
ENV #构建的时候设置环境变量。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-iOvV0ZQa-1651884104875)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220114150857593.png)]
实战测试
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-abw9i2nK-1651884104875)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220115130852605.png)]
创建一个自己的centos
#1,编写Dockerfile的文件
[root@localhost dockerfile]# cat mydockerfile-centos
FROM centos
MAINTAINER chengdashi<1847985602@qq.com>
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim
RUN yum -y install net-tools
EXPOSE 80
CMD echo $MYPATH
CMD echo "-----end-----"
CMD /bin/bash
#2,通过这个文件构建镜像
#命令 docker build -f dockerfile文件路径 -t 镜像名:[tag] .
Successfully built 77f22c72c9ce
Successfully tagged mycentos:0.1
#3,测试运行
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TINCbCYO-1651884104876)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220115132436239.png)]
对比:之前的原生的centos
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xQ1D4hJm-1651884104876)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220115132628851.png)]
我们增加之后的镜像。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EvH2oIi6-1651884104876)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220115132815414.png)]
我们可以列出本地镜像的变更历史。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZcOCefiM-1651884104877)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220115132927846.png)]
CMD和ENTRYPOINT 区别
CMD #指定这个容器启动的时候要运行的命令,只有一个会生效,可被替代。
ENTRYPOINT #指定这个容器启动的时候要运行的命令,可以追加命令。
测试cmd
#编写dockerfile文件
[root@localhost dockerfile]vim dockerfile-cmd-test
FROM centos
CMD ["ls","-a"]
#构建镜像
[root@localhost dockerfile]# docker build -f dockerfile-cmd-test -t cmdtest .
#run运行,发现我们的ls -a命令生效
[root@localhost dockerfile]# docker run 5d992cc604f3
.
..
.dockerenv
bin
dev
etc
home
lib
lib64
lost+found
media
mnt
opt
proc
root
run
sbin
srv
sys
tmp
usr
var
#想追加一个命令-l ls -al
[root@localhost dockerfile]# docker run 5d992cc604f3 -l
docker: Error response from daemon: OCI runtime create failed: container_linux.go:380: starting container process caused: exec: "-l": executable file not found in $PATH: unknown.
#cmd的清理下 -l 替换了 CMD ["ls","-a"] 命令,-l不是命令所以报错!。
测试ENTRYPOINT
[root@localhost dockerfile]# vim dockerfile-cmd-entrypoint
FROM centos
ENTRYPOINT ["ls","-a"]
[root@localhost dockerfile]# docker build -f dockerfile-cmd-entrypoint -t entrypointtest .
Sending build context to Docker daemon 4.096kB
Step 1/2 : FROM centos
---> 5d0da3dc9764
Step 2/2 : ENTRYPOINT ["ls","-a"]
---> Running in 84e6d08564e6
Removing intermediate container 84e6d08564e6
---> 66bc3ba82b23
Successfully built 66bc3ba82b23
Successfully tagged entrypointtest:latest
[root@localhost dockerfile]# ls
dockerfile-cmd-entrypoint dockerfile-cmd-test mydockerfile-centos
[root@localhost dockerfile]# docker run 66bc3ba82b23
.
..
.dockerenv
bin
dev
etc
home
lib
lib64
lost+found
media
mnt
opt
proc
root
run
sbin
srv
sys
tmp
usr
var
#我们追加命令,是直接拼接到我们ENTRYPOINT命令后面。
[root@localhost dockerfile]# docker run 66bc3ba82b23 -l
total 0
drwxr-xr-x. 1 root root 6 Jan 14 12:37 .
drwxr-xr-x. 1 root root 6 Jan 14 12:37 ..
-rwxr-xr-x. 1 root root 0 Jan 14 12:37 .dockerenv
lrwxrwxrwx. 1 root root 7 Nov 3 2020 bin -> usr/bin
drwxr-xr-x. 5 root root 340 Jan 14 12:37 dev
drwxr-xr-x. 1 root root 66 Jan 14 12:37 etc
drwxr-xr-x. 2 root root 6 Nov 3 2020 home
lrwxrwxrwx. 1 root root 7 Nov 3 2020 lib -> usr/lib
lrwxrwxrwx. 1 root root 9 Nov 3 2020 lib64 -> usr/lib64
drwx------. 2 root root 6 Sep 15 14:17 lost+found
drwxr-xr-x. 2 root root 6 Nov 3 2020 media
drwxr-xr-x. 2 root root 6 Nov 3 2020 mnt
drwxr-xr-x. 2 root root 6 Nov 3 2020 opt
dr-xr-xr-x. 141 root root 0 Jan 14 12:37 proc
dr-xr-x---. 2 root root 162 Sep 15 14:17 root
drwxr-xr-x. 11 root root 163 Sep 15 14:17 run
lrwxrwxrwx. 1 root root 8 Nov 3 2020 sbin -> usr/sbin
drwxr-xr-x. 2 root root 6 Nov 3 2020 srv
dr-xr-xr-x. 13 root root 0 Jan 14 02:37 sys
drwxrwxrwt. 7 root root 171 Sep 15 14:17 tmp
drwxr-xr-x. 12 root root 144 Sep 15 14:17 usr
drwxr-xr-x. 20 root root 262 Sep 15 14:17 var
实现:Tomcat 镜像
1、准备镜像文件tomcat压缩包,jdk的压缩包。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qCVLlR5A-1651884104877)(C:\Users\Serendipity\AppData\Roaming\Typora\typora-user-images\image-20220115141758422.png)]
2、
Springboot打包成docker镜像
1,构建springboot项目
2,打包应用
3,编写dockerfile
4,构建镜像
5,发布