一:docker服务

1: 启动

# 启动 

systemctl start docker 

# 开机自启 

systemctl enable docker

2: 停止

systemctl stop docker

3: 重启

systemctl restart docker

4: 查看docker状态

systemctl status docker


二:docker镜像

1: 查看镜像



docker images




docker images -a   列出本地所有的镜像,包含中间映像层


-a :列出本地所有的镜像,包含中间映像层



-q :只显示镜像ID。



--digests :显示镜像的摘要信息



--no-trunc :显示完整的镜像信息





2: 搜索镜




docker 引入 本地镜像 docker启动本地镜像_docker 引入 本地镜像



NAME:镜像名称


DESCRIPTION: 镜像服务


STARS:点赞数


OFFICIAL: 是否是官方版


docker search 镜像名称

--no-trunc : 显示完整的镜像描述

-s : 列出收藏数不小于指定值的镜像。

--automated : 只列出 automated build类型的镜像;


docker searech mysql

3 拉取镜像


docker pull 镜像名称:版本号


4 删除镜像


docker rmi 镜像名称:版本号



docker rmi -f  镜像名称:版本号(强制删除)




5:镜像信息



docker 引入 本地镜像 docker启动本地镜像_5e_02




vim /var/lib/docker/image/overlay2/repositories.json



{"Repositories":


   {"hello-world":{"hello-world:latest":"sha256:feb5d9fea6a5e9606aa995e879d862b825965ba48de054caab5ef356dc6b3412",


   "hello-world@sha256:37a0b92b08d4919615c3ee023f7ddb068d12b8387475d64c622ac30f45c29c51":"sha256:feb5d9fea6a5e9606aa995e879d862b825965ba48de054caab5ef356dc6b3412"},"portainer/portainer":{"portainer/portainer:latest":"sha256:580c0e4e98b06d258754cf28c55f21a6fa0dc386e6fe0bf67e453c3642de9b8b",


"portainer/portainer@sha256:fb45b43738646048a0a0cc74fcee2865b69efde857e710126084ee5de9be0f3f":"sha256:580c0e4e98b06d258754cf28c55f21a6fa0dc386e6fe0bf67e453c3642de9b8b"}}}






三:docker容器


1: 新建并启动容器



docker 引入 本地镜像 docker启动本地镜像_docker_03




docker run [OPTIONS] IMAGE [COMMAND] [ARG...]



OPTIONS说明(常用):有些是一个减号,有些是两个减号


--name="容器新名字": 为容器指定一个名称;


-d: 后台运行容器,并返回容器ID,也即启动守护式容器;


-i:以交互模式运行容器,通常与 -t 同时使用;


-t:为容器重新分配一个伪输入终端,通常与 -i 同时使用;


-P: 随机端口映射;


-p: 指定端口映射,有以下四种格式


      ip:hostPort:containerPort


      ip::containerPort


      hostPort:containerPort


      containerPort



docker run -it mysql   交互模式并返回命令终端




docker run -d mysql  


 后台运行容器,并返回容器ID,启动守护式容器  注意这个时候输入docker ps 是无法显示运行容器的实例 然后docker ps -a 进行查看, 会发现容器已经退出


原因:


很重要的要说明的一点: Docker容器后台运行,就必须有一个前台进程.


容器运行的命令如果不是那些一直挂起的命令(比如运行top,tail),就是会自动退出的。


这个是docker的机制问题,比如你的web容器,我们以nginx为例,正常情况下,我们配置启动服务只需要启动响应的service即可。例如


service nginx start


但是,这样做,nginx为后台进程模式运行,就导致docker前台没有运行的应用,


这样的容器后台启动后,会立即自杀因为他觉得他没事可做了.


所以,最佳的解决方案是,将你要运行的程序以前台进程的形式运行







2: 当前运行的容器



docker 引入 本地镜像 docker启动本地镜像_5e_04



docker ps [OPTIONS]       


OPTIONS说明(常用):


-a :列出当前所有正在运行的容器+历史上运行过的


-l :显示最近创建的容器。


-n:显示最近n个创建的容器。


-q :静默模式,只显示容器编号。


--no-trunc :不截断输出。


3: 容器启动


退出容器


exit      容器停止退出


ctrl+p+q     容器不停止退出




启动容器


docker start 容器 ID 或者容器名



重启容器


docker restart 容器 ID 或者容器名



停止容器


docker stop 容器 ID 或者容器名



强制停止容器


docker kill 容器 ID 或者容器名



删除已停止的容器


docker rm 容器 ID



一次性删除多个容器


docker rm -f $(docker ps -a -q)





4: 容器查询


查看容器日志


docker logs -f -t --tail 容器ID


*   -t 是加入时间戳


*   -f 跟随最新的日志打印


*   --tail 数字 显示最后多少条



查看容器内运行的进程


docker top 容器ID



查看容器内部细节


docker inspect 容器ID





进入正在运行的容器并以命令行交互



docker exec -it 容器ID    bashShell        直接进入容器启动命令的终端,不会启动新的进程


重新进入docker attach 容器ID              是在容器中打开新的终端,并且可以启动新的进程






从容器内拷贝文件到主机上



docker 引入 本地镜像 docker启动本地镜像_运维_05



docker cp  容器ID:容器内路径 目的主机路径