Docker日常工作常用命令

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
日志服务 SLS,月写入数据量 50GB 1个月
简介: Docker日常工作常用命令

容器生命周期管理

Docker创建新容器并运行[run]

语法:docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

OPTIONS说明:

  • -a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
  • -d: 后台运行容器,并返回容器ID;
  • -i: 以交互模式运行容器,通常与 -t 同时使用;
  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
  • --name="nginx-lb": 为容器指定一个名称;
  • --dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
  • --dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
  • -h "mars": 指定容器的hostname;
  • -e username="ritchie": 设置环境变量;
  • --env-file=[]: 从指定文件读入环境变量;
  • --cpuset="0-2" or --cpuset="0,1,2": 绑定容器到指定CPU运行;
  • -m :设置容器使用内存最大值;
  • --net="bridge": 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
  • --link=[]: 添加链接到另一个容器;
  • --expose=[]: 开放一个端口或一组端口;

实例:

使用docker镜像nginx:latest以后台模式启动一个容器,并将容器命名为yyflightNginx:

docker run --name yyflightNginx -d nginx:latest
执行完后可使用docker ps验证容器是否成功运行

1336199-20220903175939584-654994773.png

Dcoker start/stop/restart

docker start 容器名:启动一个或多少已经被停止的容器

docker start yyflightNginx

docker stop 容器名:停止一个运行中的容器

docker stop yyflightNginx

 

docker restart 容器名:重启容器

docker restart yyflightNginx

Docker杀死运行中的容器[kill]

docker kill :杀掉一个运行中的容器。

实例:

杀死运行中的nginx容器yyflightNginx

docker kill yyflightNginx

Docker删除一个或者多个容器[rm]

语法:docker rm [OPTIONS] CONTAINER [CONTAINER...]

实例:

1、强制删除容器 yyflightNginx001、yyflightNginx02

docker rm -f  yyflightNginx001、yyflightNginx02

2、移除容器nginx01对容器db01的连接,连接名db

docker rm -l db

3、删除容器nginx01,并删除容器挂载的数据卷

docker rm -v nginx01

Docker创建新容器但不启用[create]

语法:docker create [OPTIONS] IMAGE [COMMAND] [ARG...]

实例:

使用docker镜像nginx:latest创建一个容器,并将容器命名为yyflightNginx001

docker create --name yyflightNginx001 nginx:latest

Docker容器暂停和恢复[pause/unpause]

docker pause :暂停容器中所有的进程

暂停数据库容器db01提供服务:

docker pause db01

docker unpause :恢复容器中所有的进程

恢复数据库容器db01提供服务:

docker unpause db01

容器操作

查看本地正在运行的容器[ps]

语法:docker ps [OPTIONS]

OPTIONS说明:

  • -a :显示所有的容器,包括未运行的。
  • -f :根据条件过滤显示的内容。
  • --format :指定返回值的模板文件。
  • -l :显示最近创建的容器。
  • -n :列出最近创建的n个容器。
  • --no-trunc :不截断输出。
  • -q :静默模式,只显示容器编号。
  • -s :显示总的文件大小。
docker ps

1336199-20220903180951151-1643747031.png

Docker查看容器中运行的进程信息[top]

docker top:查看容器中运行的进程信息,支持 ps 命令参数。

实例:

查看容器yyflightNginx的进程信息:

docker top yyflightNginx

1336199-20220903181044779-36050710.png

Dcoker获取容器的日志[logs]

语法: docker logs [OPTIONS] CONTAINER

OPTIONS说明:

  • -f : 跟踪日志输出
  • --since :显示某个开始时间的所有日志
  • -t : 显示时间戳
  • --tail :仅列出最新N条容器日志

实例:

跟踪查看容器yyflightNginx的日志输出(帮你查看这个容器在某个时间段被执行了什么操作):

docker logs -f yyflightNginx

1336199-20220903181244355-880185305.png

Docker列出指定的容器的端口映射[port]

docker port :列出指定的容器的端口映射,或者查找将PRIVATE_PORT NAT到面向公众的端口。

实例:

查看容器yyflightNginx的端口映射情况:

docker port yyflightNginx

Docker info|version|status

Docker版本信息查看[version]

语法:docker version [OPTIONS]

OPTIONS说明:

  • -f :指定返回值的模板文件。
docker version

1336199-20220903181705846-1095293461.png

查看Docker系统信息[info]

显示 Docker 系统信息,包括镜像和容器数。

docker info

1336199-20220903181742688-1199527817.png

Docker服务状态查看[systemctl status]

systemctl status docker

1336199-20220903181824661-254830212.png

Docker本地镜像管理

查看本地镜像列表[images]

语法:docker images [OPTIONS] [REPOSITORY[:TAG]]

OPTIONS说明:

  • -a :列出本地所有的镜像(含中间映像层,默认情况下,过滤掉中间映像层);
  • --digests :显示镜像的摘要信息;
  • -f :显示满足条件的镜像;
  • --format :指定返回值的模板文件;
  • --no-trunc :显示完整的镜像信息;
  • -q :只显示镜像ID。
docker images

1336199-20220903181851116-1611264947.png

Docker删除本地一个或多少镜像[rmi]

语法:docker rmi [OPTIONS] IMAGE [IMAGE...]

OPTIONS说明:

  • -f :强制删除;
  • --no-prune :不移除该镜像的过程镜像,默认移除;

实例:

强制删除本地镜像nginx/ubuntu

docker rmi -f nginx/ubuntu

Docker给本地镜像打标签[tag]

docker tag : 标记本地镜像,将其归入某一仓库。

语法:docker tag SOURCE_IMAGE[:TAG] TARGET_IMAGE[:TAG]

Docker镜像打标签在我们的实际开发中非常常用,比如说公司的项目每次开发都会发布一个版本然后我们通过打标签来区分不同版本,如果以后想要回滚版本就可以使用指定的标签的镜像来创建容器。

实例:

1、比如说我本地现在有一个nginx的镜像:

docker images

1336199-20220903182034239-1747165735.png

2、我对nginx进行了开发,发布第一个版本,我就可以通过对这个版本打标签,打完标签后生成新的镜像:

docker tag nginx nginx:v001

1336199-20220903182034239-1747165735.png

Docker使用Dockerfile创建镜像[build]

语法:docker build [OPTIONS] PATH | URL | -

OPTIONS说明:

  • --build-arg=[] :设置镜像创建时的变量;
  • --cpu-shares :设置 cpu 使用权重;
  • --cpu-period :限制 CPU CFS周期;
  • --cpu-quota :限制 CPU CFS配额;
  • --cpuset-cpus :指定使用的CPU id;
  • --cpuset-mems :指定使用的内存 id;
  • --disable-content-trust :忽略校验,默认开启;
  • -f :指定要使用的Dockerfile路径;
  • --force-rm :设置镜像过程中删除中间容器;
  • --isolation :使用容器隔离技术;
  • --label=[] :设置镜像使用的元数据;
  • -m :设置内存最大值;
  • --memory-swap :设置Swap的最大值为内存+swap,"-1"表示不限swap;
  • --no-cache :创建镜像的过程不使用缓存;
  • --pull :尝试去更新镜像的新版本;
  • -q :安静模式,成功后只输出镜像ID;
  • --rm :设置镜像成功后删除中间容器;
  • --shm-size :设置/dev/shm的大小,默认值是64M;
  • --ulimit :Ulimit配置。

实例:

使用当前目录的Dockerfile创建镜像:

docker build -t w3xue/ubuntu:v1 .

使用URL github.com/creack/docker-firefox 的 Dockerfile 创建镜像:

docker build github.com/creack/docker-firefox

Dcoker查看指定镜像的创建历史[history]

语法docker history [OPTIONS] IMAGE

OPTIONS说明:

  • -H :以可读的格式打印镜像大小和日期,默认为true;
  • --no-trunc :显示完整的提交记录;
  • -q :仅列出提交记录ID。

实列:

查看容器nginx的创建历史记录:

docker history nginx

1336199-20220903182144098-1710843720.png


镜像仓库相关

登录/退出Docker镜像仓库[login/logout]

docker login : 登录到一个Docker镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub

docker logout : 登出一个Docker镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub

语法:

docker login [OPTIONS] [SERVER]

docker logout [OPTIONS] [SERVER]

OPTIONS说明:

  • -u :登陆的用户名
  • -p :登陆的密码

实例:

登陆到Docker Hub:

docker login -u 用户名 -p 密码

登出Docker Hub:

docker logout

Docker从镜像仓库中拉取或者更新指定镜像[pull]

语法:docker pull [OPTIONS] NAME[:TAG|@DIGEST]

OPTIONS说明:

  • -a :拉取所有 tagged 镜像
  • --disable-content-trust :忽略镜像的校验,默认开启

实列:

从Docker Hub下载最新的ubuntu镜像

docker pull ubuntu

从Docker Hub下载repository为ubuntu的所有镜像

docker pull -a ubuntu

Docker将本地的镜像上传到镜像仓库[push]

docker push : 将本地的镜像上传到镜像仓库,要先登陆到镜像仓库

语法:docker push [OPTIONS] NAME[:TAG]

OPTIONS说明:

  • --disable-content-trust :忽略镜像的校验,默认开启

实例:

上传本地镜像nginx:v001到镜像仓库中:

docker push nginx:v001

查询Docker Hub镜像[search]

语法:docker search [OPTIONS] TERM

OPTIONS说明:

  • --automated:弃用,只列出自动构建类型的镜像。
  • --filter , -f:基于给定条件过滤输出。
  • --format:使用模板格式化显示输出。
  • --limit:Max number of search results ,默认值25。
  • --no-trunc:禁止截断输出。
  • --stars , -s:弃用,只显示收藏数不小于几颗星的镜像,移到--filter中使用。

从Docker Hub查找所有镜像名包含redis,并且收藏星数大于10的镜像

docker search --filter stars=10 redis

1336199-20220903182534783-1802558878.png

从Docker Hub查找所有镜像名包含redis的镜像

docker search redis

1336199-20220903182602518-1972172455.png


相关实践学习
通过容器镜像仓库与容器服务快速部署spring-hello应用
本教程主要讲述如何将本地Java代码程序上传并在云端以容器化的构建、传输和运行。
Kubernetes极速入门
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 本课程从Kubernetes的简介、功能、架构,集群的概念、工具及部署等各个方面进行了详细的讲解及展示,通过对本课程的学习,可以对Kubernetes有一个较为全面的认识,并初步掌握Kubernetes相关的安装部署及使用技巧。本课程由黑马程序员提供。   相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
19天前
|
安全 Docker 容器
|
19天前
|
网络安全 数据安全/隐私保护 Docker
|
6天前
|
Java 应用服务中间件 Linux
【Docker容器化技术】docker安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库
本文主要讲解了Docker的安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库以及Docker容器虚拟化与传统虚拟机比较。
141 6
【Docker容器化技术】docker安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库
|
18天前
|
存储 监控 安全
|
2月前
|
Linux Docker 容器
Docker操作 :容器命令
Docker操作 (四)
|
18天前
|
存储 关系型数据库 MySQL
|
26天前
|
网络协议 Docker 容器
docker pull命令拉取镜像失败的解决方案
docker pull命令拉取镜像失败的解决方案
611 1
|
28天前
|
安全 网络安全 开发者
Docker学习笔记(一):Docker命令总结
本文介绍了Docker的基本概念、优点以及常用命令。Docker是一个开源的应用容器引擎,它通过容器打包应用程序及其依赖项,实现快速部署和迁移。主要优点包括轻量级、可移植性、易于管理、安全性和开源性。文章还区分了镜像和容器的概念,并提供了构建镜像、查看容器、运行容器、停止和删除容器等常用Docker命令的示例。
124 0
|
1月前
|
Linux 网络安全 Docker
安装后无法使用 Docker 命令
【10月更文挑战第3天】
143 2
|
1月前
|
安全 Shell Linux
docker进入容器命令
docker进入容器命令
下一篇
无影云桌面