镜像相关命令

查看镜像

docker images
注:
REPOSITORY:镜像名称
TAG:镜像标签
IMAGE ID:镜像ID
CREATED:镜像的创建日期(不是获取该镜像的日期)
SIZE:镜像大小
这些镜像都是存储在Docker宿主机的/var/lib/docker目录下

搜索镜像

docker search 镜像名称
注:
NAME:仓库名称
DESCRIPTION:镜像描述
STARS:用户评价,反应一个镜像的受欢迎程度
OFFICIAL:是否官方
AUTOMATED:自动构建,表示该镜像由Docker Hub自动构建流程创建的

拉取镜像
拉取镜像就是从中央仓库中下载镜像到本地

docker pull 镜像名称
注:
例如,我要下载centos7镜像
docker pull centos:7

删除镜像
按镜像ID删除镜像

docker rmi 镜像ID
注:
可以加 -f 参数强制删除

删除所有镜像

docker rmi `docker images -q`

打包镜像

docker save -o images.tar $(docker images --format "{{.Repository}}")
注:
如果打包单个镜像 
docker save -o images.tar 容器名称1 (或者容器ID)  容器名称2 (或者容器ID) 容器名称n (或者容器ID)
另外 docker save -o images.tar $(docker images -q)  也可以打包镜像
这两个命令的区别在于保存的镜像的详细程度和完整性。
使用docker images --format "{{.Repository}}"将包含完整的镜像,包括所有的元数据和历史记录。
而使用docker images -q会生成更轻量级的镜像,省略一些元数据和历史记录,但保留用于运行容器或构建新镜像所必需的核心组件。

导入镜像

docker load -i images.tar

构建镜像

docker build -t 镜像名 Dockerfile路径
注:
 docker build -t java11 .

推送镜像

docker push 镜像名


容器相关命令

查看容器
查看正在运行的容器

docker ps

查看所有容器的ID

docker ps -q

查看所有容器

docker ps –a

查看最后一次运行的容器

docker ps -l

查看停止的容器

docker ps -f status=exited

创建与启动容器
创建容器常用的参数说明:

创建容器命令:docker run
 -i:表示运行容器
 -t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。
 --name :为创建的容器命名。
 -v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。
 -d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。
 -p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

1.交互式方式创建容器

docker run -it --name=容器名称 镜像名称:标签 /bin/bash
这时我们通过ps命令查看,发现可以看到启动的容器,状态为启动状态
退出当前容器
exit

2.守护式方式创建容器

docker run -id --name=容器名称 镜像名称:标签

登录守护式容器方式

docker exec -it 容器名称 (或者容器ID)  /bin/bash

检查容器输出的日志

docker logs 容器名称 (或者容器ID) 
注:
docker logs -f 容器名称 (或者容器ID)
 -f: 用于以实时查看容器的日志输出

停止容器

docker stop 容器名称(或者容器ID)

启动容器

docker start 容器名称(或者容器ID)

重启容器

docker restart 容器名称(或者容器ID)

容器自启动

docker update --restart=always 容器名称

文件拷贝
将文件拷贝到容器内

docker cp 需要拷贝的文件或目录 容器名称:容器目录

将文件从容器内拷贝出来

docker cp 容器名称:容器目录 需要拷贝的文件或目录

目录挂载
我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器。
创建容器 添加-v参数 后边为 宿主机目录:容器目录,例如:

docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos3 centos:7

如果你共享的是多级的目录,可能会出现权限不足的提示。
这是因为CentOS7中的安全模块selinux把权限禁掉了,我们需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题
删除容器
删除指定的容器:

docker rm 容器名称(容器ID)
注:
可以加 -f 参数强制删除


网络命令

查看容器的详细信息

docker inspect 容器名称(容器ID)

也可以直接执行下面的命令查看输出IP地址

docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称(容器ID)

列出Docker网络

docker network ls:

创建一个自定义的Docker网络

docker network create 网络名称

将容器连接到指定的网络

docker network connect 网络名称 容器名称

断开容器与指定网络的连接

docker network disconnect 网络名称 容器名称

数据管理命令

列出Docker卷

docker volume ls

创建一个Docker卷

docker volume create 卷名称

查看卷的详细信息

docker volume inspect 卷名称

其他常用命令

docker version:显示Docker客户端和服务器的版本信息
docker info:显示Docker系统的信息和配置
docker login:登录到Docker仓库
docker logout:注销Docker仓库的登录状态
docker system prune:清理无用的镜像、容器和卷

最后修改:2023 年 07 月 06 日
如果觉得我的文章对你有用,请随意赞赏