3. Docker 常用命令(详细说明附有截图)
3. Docker 常用命令(详细说明附有截图)@
目录
[*]3. Docker 常用命令(详细说明附有截图)
[*]1. Docker 资助启动类命令
[*]1.1 启动 docker: systemctl start docker
[*]1.2 停止 docker: systemctl stop docker
[*]1.3 重启 docker: systemctl restart docker
[*]1.4 查看 docker 状态: systemctl status docker
[*]1.5 开机启动: systemctl enable docker
[*]1.6 查看 docker 概要信息: docker info
[*]1.7 查看 docker 总体资助文档: docker --help
[*]1.8 查看 docker 命令资助文档: docker 详细命令 --help
[*]2. Docker 镜像命令
[*]2.1 docker images列出本地主机已经存在/拉取到的镜像
[*]2.2 docker search 某个XXX镜像名字,从库当中查询某个镜像
[*]2.3 docker pull 某个XXX镜像名字 ,下载/拉取某个镜像
[*]2.4 docker system df 查看镜像/容器/数据卷所占的空间
[*]2.5 docker rmi 某个XXX镜像名字ID
[*]3. Docker 容器命令
[*]3.1 新建+启动容器 docker run IMAGE
[*]3.2 docker ps 列出当前全部正在运行的容器
[*]3.3 退出容器(两种方式,两种方式都是本身已经进入到容器当中了)
[*]3.4 启动已停止运行的容器 docker start 容器ID或者容器名
[*]3.5 重启容器 docker restart 容器ID或者容器名
[*]3.6 停止容器docker stop 容器ID或者容器名
[*]3.7 逼迫停止容器docker kill 容器ID或容器名
[*]3.8 删除已停止的容器docker rm 容器ID
[*]3.9 容器重点:把握
[*]3.9.1 启动保卫式容器(背景服务器)
[*]3.9.2 查看容器日志 docker logs 容器ID
[*]3.9.3 查看容器内运行的进程 docker top 容器ID
[*]3.9.4 查看容器内部细节docker inspect 容器ID
[*]3.9.5 进入“正在运行”的容器并以命令行交互exec和 attach
[*]3.9.6 从容器实例内拷贝文件到主机上—> docker cp容器ID:容器内路径 目标主机路径
[*]3.9.7 导入(import )和导出(export)容器(全部信息)
[*]4. 总结:
[*]最后:
1. Docker 资助启动类命令
1.1 启动 docker: systemctl start docker
# systemctl start dockerhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219495-143083030.png
1.2 停止 docker: systemctl stop docker
# systemctl stop dockehttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219678-1875098046.png
1.3 重启 docker: systemctl restart docker
# systemctl restart dockerhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219775-1031548758.png
1.4 查看 docker 状态: systemctl status docker
# systemctl status dockerhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219262-493827727.png
1.5 开机启动: systemctl enable docker
# systemctl enable dockerhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219558-1749187860.png
1.6 查看 docker 概要信息: docker info
# docker infohttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219436-1652956146.png
1.7 查看 docker 总体资助文档: docker --help
# docker --helphttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219681-1244397050.png
1.8 查看 docker 命令资助文档: docker 详细命令 --help
# docker cp --helphttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219686-741982633.png
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219715-2131783027.png
2. Docker 镜像命令
2.1 docker images列出本地主机已经存在/拉取到的镜像
# docker imageshttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219776-1195503897.png
docker images 各个选项说明:
[*]REPOSITORY:表现镜像的仓库源
[*]TAG:镜像的标签版本号
[*]IMAGE ID:镜像ID
[*]CREATED:镜像创建时间
[*]SIZE: 镜像巨细
对于同一仓库源可以有多个 TAG 版本,代表这个仓库源的差别个版本,我们使用 REPOSITORY:TAG 来定义差别的镜像,假如你不指定一个镜像的版本标签,例如:你只使用 ubuntu,docker 将默认使用 ubuntu:latest 镜像(latest 表现最新的版本)
OPTIONS 说明:
[*]-a : 列出本地全部的镜像(含汗青映像层)
# docker images -ahttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219178-195024223.png
[*]-q : 只显示镜像ID
# docker images -qhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219560-1154156284.png
[*]aq: 和 -q 一样
# docker images -aqhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219258-567588948.png
2.2 docker search 某个XXX镜像名字,从库当中查询某个镜像
仓库的官方地址:https://hub.docker.com 国外的网站,可能无法访问。
docker search 镜像名字
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219484-1274794840.png
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219523-170457901.png
OPTIONS说明:
[*]--limit :只列出N个镜像,默认25个
docker search --limit 5 redis2.3 docker pull 某个XXX镜像名字 ,下载/拉取某个镜像
docker pull 镜像名字[:TAG]
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219731-74755753.png
# docker pull ubuntuhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219507-1710059614.png
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219568-898311881.png
2.4 docker system df 查看镜像/容器/数据卷所占的空间
# docker system dfhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219462-550053978.png
2.5 docker rmi 某个XXX镜像名字ID
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219412-489135226.png
面试题:谈谈docker虚悬镜像是什么?
仓库名、标签都是 的镜像,俗称虚悬镜像 dangling image
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219557-377489220.png
3. Docker 容器命令
注意:有镜像才能创建容器,这是根本条件(下载一个CentOS或者ubuntu镜像演示)
3.1 新建+启动容器 docker run IMAGE
OPTIONS说明(常用):有些是一个减号,有些是两个减号
--name="容器新名字" 为容器指定一个名称;
-d: 背景运行容器并返回容器ID,也即启动保卫式容器(背景运行);
-i:以交互模式运行容器,通常与 -t 同时使用;
-t:为容器重新分配一个伪输入终端,通常与 -i 同时使用;也即启动交互式容器(前台有伪终端,等待交互);
-it : 表现启用一个控制台进行交互
-P:随机端口映射,大写P
-p:指定端口映射,小写p
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219413-1099014114.png
使用镜像centos:latest以交互模式启动一个容器,在容器内执行/bin/bash命令。
# docker run -it ubuntuhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219482-1291728036.png
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219556-1535388852.png
# docker run -it ubuntu /bin/bashhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219780-562032171.png
参数说明:
[*]-i: 交互式操作。
[*]-t: 终端。
[*]ubuntu: ubuntu镜像。
[*]/bin/bash:放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 /bin/bash。
[*]--name : 指明容器实例的名称。
[*]要退出终端,直接输入 exit:
# docker run -it --name="myu2" ubuntu bashhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219683-35457915.png
3.2 docker ps 列出当前全部正在运行的容器
# docker pshttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219258-154552495.png
OPTIONS说明(常用):
-a :列出当前全部正在运行的容器+汗青上运行过的
-l :显示最近创建的容器。
-n:显示最近n个创建的容器。
-q : 静默模式,只显示容器编号。
# docker ps -a
# docker ps -l
# docker ps -n 2
# docker ps -qhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219309-1341819184.png
3.3 退出容器(两种方式,两种方式都是本身已经进入到容器当中了)
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219737-1757434127.png
[*]exit :退出容器的条件是,本身已经已经进入到容器当中了。exit 方式退出了容器,容器本身也将会停止 。
root@31b5c8683200:/# exithttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219415-803325632.png
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219414-1926093480.png
[*]ctrl+p+q:run进去容器,ctrl+p+q退出,容器不会停止
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219422-1154154788.png
3.4 启动已停止运行的容器 docker start 容器ID或者容器名
# docker start 7ae682c779cbhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219586-1747376457.png
3.5 重启容器 docker restart 容器ID或者容器名
3.6 停止容器docker stop 容器ID或者容器名
3.7 逼迫停止容器docker kill 容器ID或容器名
3.8 删除已停止的容器docker rm 容器ID
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219729-796919495.png
# docker rm 357021879d41https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219461-209479.png
# docker rm -f compassionate_wilsonhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219488-108612885.png
3.9 容器重点:把握
条件:有镜像才能创建容器,这是根本条件(下载一个Redis6.0.8镜像演示)
# docker pull redis:6.0.8 https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219691-1553535665.png
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219470-966707129.png
3.9.1 启动保卫式容器(背景服务器)
在大部分的场景下,我们希望 docker 的服务是在背景运行的,我们可以过 -d 指定容器的背景运行模式。
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219517-2125340621.png
前台交互式启动:docker run -d 容器名
# docker run -d redis:6.0.8https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219268-606508379.png
使用镜像redis:6.0.8以背景模式启动一个容器
docker run -d redis:6.0.8
标题:然后docker ps -a 进行查看, 会发现容器已经退出很紧张的要说明的一点: Docker容器背景运行,就必须有一个前台进程,容器运行的命令假如不是那些一直挂起的命令(比如运行top,tail ),就是会自动退出的。
这个是docker的机制标题,比如你的web容器,我们以nginx为例,正常情况下,我们配置启动服务只须要启动相应的service即可。例如service nginx start 但是,这样做,nginx为背景进程模式运行,就导致docker前台没有运行的应用, 这样的容器背景启动后,会立刻自杀因为他觉得他没事可做了。
所以,最佳的解决方案是,将你要运行的程序以前台进程的形式运行,常见就是命令行模式,表现我还有交互操作,别中断,O(∩_∩)O哈哈~
背景保卫式启动: docker run -d redis:6.0.8
# docker run -t redis:6.0.8https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219781-1717538033.png
3.9.2 查看容器日志 docker logs 容器ID
# docker logs 3aa02dfe9eahttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219696-1034716914.png
3.9.3 查看容器内运行的进程 docker top 容器ID
# docker top 3aa02dfe9ea5https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219612-685590822.png
3.9.4 查看容器内部细节docker inspect 容器ID
# docker inspect 3aa02dfe9ea5https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219456-1391779033.png
3.9.5 进入“正在运行”的容器并以命令行交互exec和 attach
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219464-1807301302.png
# docker exec -it 7ae682c779cb /bin/bashhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219784-827213608.png
# docker attach 7ae682c779cbhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219288-1326661681.png
exec和 attach两者都是重新进入正在运行的容器实例,两个区别是:
[*]attach直接进入容器启动命令的终端,不会启动新的进程,用exit退出,会导致容器的停止。
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219583-815512867.png
[*]exec 是在容器中打开新的终端,并且可以启动新的进程用exit退出,不会导致容器的停止。
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219341-1300351023.png
推荐各人使用docker exec 命令,因为退出容器终端,不会导致容器的停止。
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219551-89160156.png
root@localhost docker]# docker exec -it 3aa02dfe9ea5 /bin/bashhttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219788-41786933.png
# docker exec -it 3aa02dfe9ea5 redis-clihttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219578-1057014116.png
一般先用docker run -d 容器ID 背景启动的程序,再用docker exec -it 容器ID /bin/bash 进入对应容器实例
3.9.6 从容器实例内拷贝文件到主机上—> docker cp容器ID:容器内路径 目标主机路径
公式:docker cp容器ID:容器内路径 目标主机路径
起首,进入到 ubuntu 实例当中。在 ubuntu 容器实例的 /tmp 路径当中创建一个 a.txt 文件。
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219685-616794730.png
注意:是在主机的位置上执行该命令,不是在容器实例当中执行的。最好是先创建文件夹,再执行该指令,存放的文件夹要先创建出来。
# docker cp 4b6b2842843b:/tmp/a.txt /home/linux/demo02https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219289-450950743.png
3.9.7 导入(import )和导出(export)容器(全部信息)
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219308-1141976942.png
注意:这是在主机当中执行的命令,不是在容器实例当中的。
[*]export 导出容器的内容留作为一个 tar 归档文件[对应import命令]
root@localhost demo02]# docker export 4b6b2842843b> temp02.tahttps://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219212-563109449.png
[*]import 从tar包中的内容创建一个新的文件体系再导入为镜像[对应export]
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219684-205336854.png
ubuntu 实例删除后,我们将根据我们上面导出的 temp02.tar 文件信息,创建一个新的含有上面我们刚刚删除的 ubuntu 容器实例的全部内容(在其中的tmp文件当中,存在一个我们创建的一个a.tx 文件)。
# cat temp02.tar | docker import - rainbowsea/ubuntu:3.7https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219321-38781192.png
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219512-1852521913.png
4. 总结:
[*]-- :两个横杠,表现匹配的是,全部单词的指令
[*]- : 单个横杠,表现匹配的是含糊匹配的指令
[*]同时注意:哪些指令是在容器实例当中执行的 ,哪些指令是在主机当中执行的指令 。
常用命令:
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219629-1296416708.png
[*]attach Attach to a running container # 当前 shell 下 attach 连接指定运行镜像
[*]build Build an image from a Dockerfile # 通过 Dockerfile 定制镜像
[*]commit Create a new image from a container changes # 提交当前容器为新的镜像
[*]cp Copy files/folders from the containers filesystem to the host path #从容器中拷贝指定文件或者目录到宿主机中
[*]create Create a new container # 创建一个新的容器,同 run,但不启动容器
[*]diff Inspect changes on a container's filesystem # 查看 docker 容器变化
[*]events Get real time events from the server # 从 docker 服务获取容器及时势件
[*]exec Run a command in an existing container # 在已存在的容器上运行命令
[*]export Stream the contents of a container as a tar archive # 导出容器的内容流作为一个 tar 归档文件[对应 import ]
[*]history Show the history of an image # 展示一个镜像形成汗青
[*]images List images # 列出体系当前镜像
[*]import Create a new filesystem image from the contents of a tarball # 从tar包中的内容创建一个新的文件体系映像[对应export]
[*]info Display system-wide information # 显示体系相关信息
[*]inspect Return low-level information on a container # 查看容器详细信息
[*]kill Kill a running container # kill 指定 docker 容器
[*]load Load an image from a tar archive # 从一个 tar 包中加载一个镜像[对应 save]
[*]login Register or Login to the docker registry server # 注册或者登陆一个 docker 源服务器
[*]logout Log out from a Docker registry server # 从当前 Docker registry 退出
[*]logs Fetch the logs of a container # 输出当前容器日志信息
[*]port Lookup the public-facing port which is NAT-ed to PRIVATE_PORT # 查看映射端口对应的容器内部源端口
[*]pause Pause all processes within a container # 停息容器
[*]ps List containers # 列出容器列表
[*]pull Pull an image or a repository from the docker registry server # 从docker镜像源服务器拉取指定镜像或者库镜像
[*]push Push an image or a repository to the docker registry server # 推送指定镜像或者库镜像至docker源服务器
[*]restart Restart a running container # 重启运行的容器
[*]rm Remove one or more containers # 移除一个或者多个容器
[*]rmi Remove one or more images # 移除一个或多个镜像[无容器使用该镜像才可删除,否则需删除相关容器才可继续或 -f 逼迫删除]
[*]run Run a command in a new container # 创建一个新的容器并运行一个命令
[*]save Save an image to a tar archive # 保存一个镜像为一个 tar 包[对应 load]
[*]search Search for an image on the Docker Hub # 在 docker hub 中搜索镜像
[*]start Start a stopped containers # 启动容器
[*]stop Stop a running containers # 停止容器
[*]tag Tag an image into a repository # 给源中镜像打标签
[*]top Lookup the running processes of a container # 查看容器中运行的进程信息
[*]unpause Unpause a paused container # 取消停息容器
[*]version Show the docker version information # 查看 docker 版本号
[*]wait Block until a container stops, then print its exit code # 截取容器停止时的退出状态值
最后:
“在这个最后的篇章中,我要表达我对每一位读者的感激之情。你们的关注和回复是我创作的动力源泉,我从你们身上吸取了无尽的灵感与勇气。我会将你们的鼓励留在心底,继续在其他的领域奋斗。感谢你们,我们总会在某个时候再次相遇。”
https://img2024.cnblogs.com/blog/3084824/202502/3084824-20250211091219661-889599610.gif
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]