1.新建并启动容器
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
①OPTIONS说明
有些是一个减号,有些是两个减号
--name="容器新名字" 为容器指定一个名称
-d: 后台运行容器并返回容器ID,也启动守护式容器(后台运行);
--i:以交互模式运行容器,通常与-t同时使用;
-t:为容器重新分配一个伪输入终端,通常与-i同时使用;也即启动交互式容器(前台有伪终端,等待交互);
-P:随机端口映射,大写P
-p:指定端口映射,小写p
②启动交互式容器
i interactive 交互 t tyy 伪终端 shell 交互命令的接口
#使用镜像centos:latest以交互模式启动一个容器,在容器内执行/bin/bash命令。
docker run -it ubuntu /bin/bash
docker run -it centos /bin/bash
参考说明:
-i:交互式操作。
-t:终端。
centos/ubuntu :centos/ubuntu镜像。
/bin/bash:放在镜像名后的是命令,这里我们希望有个交互式Shell,因此用的是/bin/bash。
要退出终端,直接输入exit
2.列出当前所有正在运行的容器
docker ps [OPTIONS]
只要能返回出容器id的编号,说明这个镜像又生成了第二个容器实例,docker这条鲸鱼背上就有两个集装箱,这两个集装箱都是来自于同一份镜像,我运行着两个ubuntu实例
我们再开一个终端
OPTIONS说明(常用):
-a:列出当前所有正在运行的容器+历史上运行过的。
-l:显示最近创建的容器。
-n:显示最近n个创建的容器。
-q:静默模式,只显示容器编号。
3.退出容器
有两种退出方式:
①exit
run进去容器,exit退出,容器停止
②ctrl+p+q
run进去容器,ctrl+p+q退出,容器不停止
为什么只有73M,因为它只加载Linux内核,其他一些用不到的统统去掉,要用到的话,自己再去装。
第二个容器用快捷键ctrl+p+q退出,容器不停止
4.启动已停止运行的容器
docker start 容器ID或者容器名
5.重启容器
docker restart 容器ID或者容器名
6.停止容器
docker stop 容器ID或者容器名
7.强制停止容器
docker kill 容器ID或者容器名
8.删除已停止的容器
docker rm 容器ID
无法删除正在运行的容器
如果非要删除正在运行的容器加上-f
一次性删除多个容器实例
docker rm -f $(docker ps -a -q)
docker ps -a -q | xargs docker rm
假设一个容器实例stop停止容器了,然后我又给它start启动了,又想重新回去,也就是反复进出容器进行干活
也就是说可退可进,不要把容器停止
我们如何重新进入活动状态下的容器?
9.重要
(1)有镜像才能创建容器,这是根本前提(下载一个Redis6.0.8镜像演示)
(2)什么叫启动守护式容器(后台服务器)?
在大部分的场景下,我们希望docker的服务是在后台运行的,我们可以通过-d指定容器的后台运行模式。
docker run -d 容器名
#使用镜像centos:latest以后台模式启动一个容器
docker run -d centos
问题:然后docker ps -a 进行查看,会发现容器已经退出
很重要的要说明一点:Docker容器后台运行,就必须有一个前台进程。
容器运行的命令如果不是那些一直挂起的命令(比如运行top,tail),就是会自动退出的。
这个是docker的机制问题,比如你的web容器,我们nginx为例,正常情况下,我们配置启动服务只需启动响应的service即可。例如service nginx start
但是,这样做,nginx为后台进程模式运行,就导致docker前台没有运行的应用,这样的容器后台启动后,会立即自杀因为他觉得他没事可做了。
所以,最佳的解决方案是,将你要运行的程序以前台进程的形式运行,常见就是命令行模式,表示我还有交互操作,别中断
所以,有些镜像-d是不可以的,你就得用-it
我们接下来用redis演示前台和后台的区别
redis前后台启动演示case
①前台交互式模式
docker run -it redis:6.0.8
一不小心我按个Ctrl+C马上就退出,我们这个docker ps这个服务就没了,你想想你的redis经常被别人这样关了,缓存没了,啥也没了,所以像redis这样的-it前台交互就找死,一般而言mysql、redis这样的后台默默地做个服务器启动着就行了
②后台守护式启动
docker run -d redis:6.0.8
回到刚刚的定义,-d:后台运行容器并返回容器ID,也即启动守护式容器(后台运行)
(3)查看容器的日志
docker logs 容器ID
现在的工作基本是:1.编码开发微服务 2.上线部署容器化 3.时时刻刻要监控 4.devops
(4)查看容器内运行的进程
docker top 容器ID
(5)查看容器内部细节
docker inspect 容器ID
(6)进入正在运行中的容器并以命令行交互
①docker exec -it 容器ID bashShell
②重新进入:docker attach 容器ID
上述两个区别:1. attach直接进入容器启动命令的终端,不会启动新的进程,用exit退出,会导致容器的停止
exec 是在容器中打开新的终端,并且可以启动新的进程,用exit退出,不会导致容器的停止。
推荐大家使用docker exec命令,因为退出容器终端,不会导致容器的停止。
用之前的redis容器实例进入试试
docker exec -it 容器ID /bin/bash
docker exec -it 容器ID redis-cli
一般用-d后台启动的程序,再用exec进入对应容器实例
(7)从容器内拷贝文件到主机上
假设启动了一个ubuntu容器,我当前是在ubuntu的根目录下面,进行一系列的操作
但是架不住发生意外,比如说:有个人,强制把这个容器给删了,那么在9a66容器实例里面,做的工作a.txt是不是就消失了,因为我的容器都被人删了,但是里面的数据资料很重要,以防万一,需要提前备份。需要把容器中的重要数据,重要内容拷贝到主机上,也就是说删了这个容器也不怕。输入下列命令:
docker cp 容器ID:容器内路径 目的的主机路径
实例:
(8)导入和导出容器
export导出容器的内容流作为一个tar归档文件[对应import命令]
import从tar包中的内容创建一个新的文件系统再导入为镜像[对应export]
案例:
①docker export 容器ID > 文件名.tar
②cat 文件名.tar | docker import - 镜像用户/镜像名:镜像版本号
把ubuntu容器实例删了
现在,我们要按照公式,看看我们能不能恢复过来呢?
文件依然还在,这种是镜像级的备份
(9)小总结
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]
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 to 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 untill a container stops, then print its exit code #截取容器停止时的退出状态值