本篇针对在初步了解Docker基础知识之后对实操的进一步提升
一、帮助启动类命令
启动docker:systemctl start docker
停止docker:systemctl stop docker
重启docker:systemctl restart docker
查看docker状态:systemctl status docker
开机启动:systemctl enable docker
查看docker概要信息:docker info
查看docker总体帮助文档:docker--help(展示总体命令)
查看docker命令帮助文档:docker xx具体命令--help(xx用具体需要查询的命令代替)
如:docker cp --help
二、镜像命令
1、列出本地主机上的镜像: docker images
查询后的各字段说明:
REPOSITORY:表示镜像的仓库源
TAG:镜像的标签版本号
IMAGE ID:镜像ID
CREATED:镜像创建时间
SIZE:镜像大小
2、查询镜像: docker seacher [镜像名称]
NAME: 镜像名称
DESCRIPTION: 镜像说明
STARS: 点赞数量
OFFICIAL: 是否是官方的
AUTQMATED: 是否是自动构建的
一般作用于下载前的查询,一般选第一个
3、下载镜像: docker pull[镜像名称]
docker pull [镜像名称]:TAG (TAG代表版本号)//不加TAG时默认下载最新版本
4、查看镜像/容器/数据卷所占的空间
docker system df
5、通过ID删除镜像
docker rmi [IMAGE_ID或者镜像名称]
docker rmi -f [IMAGE_ID或者镜像名称] //强制删除
docker rmi -f $( docker images -qa)//删除全部,慎用!!!
面试谈谈虚悬镜像是什么:仓库名和标签都是none的镜像,建议删除一般是docker构建的时候弄出来的
三、容器命令
有镜像才能创建容器,此为根本前提,需要下载一个CentOS或者ubuntu镜像
以下以ubuntu为例
1、新建+启动容器
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
IMAGE 镜像名称
COMMAND 命令
OPTIONS说明(常用): 有些是一个减号,有些是两个减号
--name=“容器新名字”为容器指定一个名称;
-d: 后台运行容器并返回容器ID,也即启动守护式容器(后台运行);
-i: 以交互模式运行容器,通常与 -t同时使用:
-t: 为容器重新分配一个伪输入终端,通常与-i同时使用
-i:启动交互式容器(前台有伪终端,等待交互);
-P: 随机端口映射,大写P
-p: 指定端口映射,小写p
退出终端exit
操作实图:
2、列出当前所有正在运行的容器
docker ps [OPTIONS]
OPTIONS说明(常用):
-a:列出**当前所有正在运行的容器+历史上运行过的**
-l:显示最近创建的容器。
-n:显示最近n个创建的容器。
-q:静默模式,只显示容器编号。
3、退出容器
两种退出方式:
exit -run进去容器,exit退出**容器停止**
ctrl+p+q -run进去容器,按键ctrl+p+q退出**容器不停止**
docker exec-it [容器ID] [命令] 重新进入容器
3、启动已停止的容器
docker start [ID或者容器名]
4、重启容器
docker restart[ID或者容器名]
4、停止容器
docker stop [ID或者容器名]
docker kill [ID或者容器名]//强制停止
5、删除已停止的容器
docker rm [ID或者容器名] //先停止在删除
docker rm -f [ID或者容器名]//强制删除
四、针对容器命令重要补充
1、有镜像才能创建容器,镜像是容器的基本前提
2、采用守护式的方式启动容器(后台服务器)
-d:指定采用后台启动方式如:docker run -d [ID或者容器名]
容器运行的命令如果不是那些一直挂起的命令(比如运行top,tail),如果不是则会立即退出。
这是docker的机制问题,如我们以nginx这个web容器为例,正常情况下我们配置启动服务只需要启动响应的service即可。
例如service nginx start但是这样做,nginx为后台进程模式运行,就导致docker前台没有运行的应用,这样的容器后台启动后,会立即自杀因为他觉得他没事可做了。
所以最佳的解决方案是将你要运行的程序以前台进程的形式运行,常见就是命令行模式,表示我还有交互操作别中断。
以redis为例
前台交互式启动:docker run -it redis:6.0.8
后台守护式启动:docker run -d redis:6.0.8 //一般采用这种
3、查看容器日志
docker logs [容器ID]
3、查看容器内部细节
docker inspect[容器ID]
4、进入正在运行的容器并以命令行交互
1)docker exec-it [容器ID] [命令]
2)docker attach [容器ID]
**上述两种方式区别**
attach直接进入容器启动命令的终端,不会启动新的进程用**exit退出会导致容器的停止**
exec是在容器中打开新的终端,并且可以启动新的进程用**exit退出不会导致容器的停止**
**推荐使用exec因为退出不会导致容器停止**
5、从容器内部拷贝文件到主机
docker cp [容器ID]:容器内路径 目的主机路径
6、导入和导出容器
导出:
docker export [容器ID] >xxx.tar//默认在当前目录下导出tar文件
导入:
cat abcd.tar|docker import -镜像用户/镜像名:镜像版本号 //从tar包中的内容创建一个新的文件系统再导入为镜像
常用命令总结
attach Attach to a running container #当前shell下attach 连接指定运行镜像
build Build an image from a Dockerfile #通过Dockerfile定制镜像
commit Create anewimage from acontainer changes #提交当前容器为新的镜像
Cp Copy files/folders from the containers filesystem tothe 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 ofa tarball #从tar包中的内容创建一个新的文件系统映像[对应export]
info Display system-wide information #显示系统相关信息
inspect Return low-levelinformation on acontainer #查看容器详细信息
kill Kill a running container #kil指定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 whichis 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 ofacontainer #查看容器中运行的进程信息
unpause Unpause a paused container #取消暂停容器
version Show the docker version information #査看docker版本号
wait Block until a container stops, then print its exit code #截取容器停止时的退出状态值
标签:容器,container,tar,ID,常用命令,镜像,Docker,docker
From: https://www.cnblogs.com/Edehuag/p/18367505