[root@localhost ~]# systemctl start docker
[root@localhost ~]# systemctl stop docke
[root@localhost ~]# systemctl restart docker
[root@localhost ~]# systemctl status docker
[root@localhost ~]# systemctl enable docker
[root@localhost ~]# docker info
[root@localhost ~]# docker --help
[root@localhost ~]# docker cp --help
[root@localhost ~]# docker images
docker images 各个选项说明:
REPOSITORY:表示镜像的仓库源 TAG:镜像的标签版本号 IMAGE ID:镜像ID CREATED:镜像创建时间 SIZE: 镜像大小 对于同一仓库源可以有多个 TAG 版本,代表这个仓库源的不同个版本,我们使用 REPOSITORY:TAG 来定义不同的镜像,如果你不指定一个镜像的版本标签,例如:你只使用 ubuntu,docker 将默认使用 ubuntu:latest 镜像(latest 表示最新的版本)
OPTIONS 说明:
-a : 列出本地所有的镜像(含历史映像层) [root@localhost ~]# docker images -a
-q : 只显示镜像ID [root@localhost docker]# docker images -q
aq: 和 -q 一样 [root@localhost docker]# docker images -aq
仓库的官方地址:https://hub.docker.com 国外的网站,可能无法访问。
docker search [OPTIONS] 镜像名字
OPTIONS说明:
--limit : 只列出N个镜像,默认25个 docker search --limit 5 redis
docker pull 镜像名字[:TAG]
[root@localhost docker]# docker pull ubuntu
[root@localhost docker]# docker system df
面试题:谈谈docker虚悬镜像是什么?
仓库名、标签都是<none>的镜像,俗称虚悬镜像 dangling image
注意:有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)
OPTIONS说明(常用):有些是一个减号,有些是两个减号
--name="容器新名字" 为容器指定一个名称;
-d: 后台运行容器并返回容器ID,也即启动守护式容器(后台运行);
-i:以交互模式运行容器,通常与 -t 同时使用;
-t:为容器重新分配一个伪输入终端,通常与 -i 同时使用;也即启动交互式容器(前台有伪终端,等待交互);
-it : 表示启用一个控制台进行交互
-P: 随机端口映射,大写P
-p: 指定端口映射,小写p
使用镜像centos:latest以交互模式启动一个容器,在容器内执行/bin/bash命令。
[root@localhost docker]# docker run -it ubuntu
[root@localhost docker]# docker run -it ubuntu /bin/bash
参数说明:
-i: 交互式操作。 -t: 终端。 ubuntu:ubuntu镜像。 /bin/bash:放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 /bin/bash。 --name : 指明容器实例的名称。
[root@localhost ~]# docker run -it --name="myu2" ubuntu bash
[root@localhost ~]# docker ps
OPTIONS说明(常用):
-a :列出当前所有正在运行的容器+历史上运行过的
-l :显示最近创建的容器。
-n:显示最近n个创建的容器。
-q : 静默模式,只显示容器编号。
[root@localhost ~]# docker ps -a
[root@localhost ~]# docker ps -l
[root@localhost ~]# docker ps -n 2
[root@localhost ~]# docker ps -q
root@31b5c8683200:/# exit
[root@localhost ~]# docker start 7ae682c779cb
[root@localhost ~]# docker rm 357021879d41
[root@localhost ~]# docker rm -f compassionate_wilson
前提:有镜像才能创建容器,这是根本前提(下载一个Redis6.0.8镜像演示)
[root@localhost ~]# docker pull redis:6.0.8
在大部分的场景下,我们希望 docker 的服务是在后台运行的,我们可以过-d 指定容器的后台运行模式。
前台交互式启动:docker run -d 容器名
[root@localhost ~]# docker run -d redis:6.0.8
使用镜像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
[root@localhost ~]# docker run -t redis:6.0.8
[root@localhost ~]# docker logs 3aa02dfe9ea
[root@localhost ~]# docker top 3aa02dfe9ea5
[root@localhost ~]# docker inspect 3aa02dfe9ea5
[root@localhost docker]# docker exec -it 7ae682c779cb /bin/bash
[root@localhost docker]# docker attach 7ae682c779cb
exec 和 attach 两者都是重新进入正在运行的容器实例,两个区别是:
attach 直接进入容器启动命令的终端,不会启动新的进程,用exit退出,会导致容器的停止。
exec 是在容器中打开新的终端,并且可以启动新的进程用exit退出,不会导致容器的停止。 推荐大家使用 docker exec 命令,因为退出容器终端,不会导致容器的停止。
root@localhost docker]# docker exec -it 3aa02dfe9ea5 /bin/bash
[root@localhost ~]# docker exec -it 3aa02dfe9ea5 redis-cli
一般先用docker run -d 容器ID后台启动的程序,再用docker exec -it 容器ID /bin/bash进入对应容器实例
公式:docker cp 容器ID:容器内路径 目的主机路径
首先,进入到 ubuntu 实例当中。在 ubuntu 容器实例的 /tmp 路径当中创建一个a.txt 文件。
注意:是在主机的位置上执行该命令,不是在容器实例当中执行的。最好是先创建文件夹,再执行该指令,存放的文件夹要先创建出来。
[root@localhost demo02]# docker cp 4b6b2842843b:/tmp/a.txt /home/linux/demo02
import )和导出(export)容器(全部信息)
注意:这是在主机当中执行的命令,不是在容器实例当中的。
tar 归档文件[对应import命令] root@localhost demo02]# docker export 4b6b2842843b > temp02.ta
ubuntu 实例删除后,我们将根据我们上面导出的 temp02.tar 文件信息,创建一个新的含有上面我们刚刚删除的 ubuntu 容器实例的全部内容(在其中的tmp文件当中,存在一个我们创建的一个a.tx 文件)。
[root@localhost demo02]# cat temp02.tar | docker import - rainbowsea/ubuntu:3.7
-- :两个横杠,表示匹配的是,全部单词的指令 - : 单个横杠,表示匹配的是模糊匹配的指令 常用命令: