【Docker 系列】docker 学习 二,docker 常用命令,镜像命令,容器命令,其他命令

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 【Docker 系列】docker 学习 二,Docker 的常用命令


基本帮助命令



# 查看 docker 的基本版本信息
docker version
# 查看 docker 的系统信息,如镜像和容器数量
docker info
# 查看某个命令的帮助
docker xx命令 --help

咱们可以看官方的帮助文档:docs.docker.com/reference/

image.png


镜像命令


docker images 查看镜像

Usage:  docker images [OPTIONS] [REPOSITORY[:TAG]]

查看本机上的镜像

# docker images
REPOSITORY        TAG       IMAGE ID       CREATED        SIZE
ubuntu            latest    1318b700e415   5 days ago     72.8MB
hello-world       latest    d1165f221234   4 months ago   13.3k
关键字 解释
REPOSITORY 仓库源
TAG 镜像标签
IMAGE ID 镜像 ID
CREATED 创建时间
SIZE 镜像大小

可选参数:

Options:
  -a, --all             显示所有的镜像
  -q, --quiet           只显示镜像ID


docker search 搜索镜像


搜索 redis 为例

grokzen/redis-cluster            Redis cluster 3.0, 3.2, 4.0, 5.0, 6.0, 6.2      78
rediscommander/redis-commander   Alpine image for redis-commander - Redis man…   63                   [OK]
rediscommander/redis-commander   Alpine image for redis-commander - R

加上参数

过滤 STARS 大于 2000 的 镜像


# docker search redis -f STARS=2000
NAME      DESCRIPTION                                     STARS     O
FFICIAL   AUTOMATEDredis     Redis is an open source key-value store that…   9734      [OK]

我们也可以在 dockerhub 上面直接在页面上搜索镜像

image.png

搜索到的结果和使用命令搜索的结果一致

image.png


docker pull 下载镜像


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

下载 redis 镜像为例


# docker pull redis
Using default tag: latest     # 默认拉最新版本
latest: Pulling from library/redis  # redis 的库
33847f680f63: Pull complete     # 分层下载
26a746039521: Pull complete
18d87da94363: Pull complete
5e118a708802: Pull complete
ecf0dbe7c357: Pull complete
46f280ba52da: Pull complete
Digest: sha256:cd0c68c5479f2db4b9e2c5fbfdb7a8acb77625322dd5b474578515422d3ddb59                 # 签名
Status: Downloaded newer image for redis:latest
docker.io/library/redis:latest    # redis 真实下载地址

因此上述的下载操作 docker pull redis  与 docker pull docker.io/library/redis:latest 一致

dockerhub 上面 可以查看到 redis 支持的版本

image.png

我们下载一个 6 版本的 redis

# docker pull redis:6
6: Pulling from library/redis
Digest: sha256:cd0c68c5479f2db4b9e2c5fbfdb7a8acb77625322dd5b474578515422d3ddb59
Status: Downloaded newer image for redis:6
docker.io/library/redis:6

可以看到 下载 版本 6 的 redis 的时候,没有分层下载了,说明在上述看到的分层下载他们是共用的

查看刚才的安装的镜像


docker images
REPOSITORY        TAG       IMAGE ID       CREATED        SIZE
redis             6         aa4d65e670d6   8 days ago     105MB
redis             latest    aa4d65e670d6   8 days ago     105MB
hello-world       latest    d1165f221234   4 months ago   13.3kB


docker rmi 删除镜像


  • 删除单个镜像


docker rmi -f 容器ID
  • 删除多个镜像


docker rmi -f 容器ID 容器ID 容器ID
  • 删除全部镜像


docker rmi -f 容器ID 容器ID 容器ID


容器命令


容器是基于镜像创建的,我们来下载一个 ubuntu 镜像


docker pull ubuntu


docker run 新建并启动容器


docker run [参数] 镜像名字 [指令] [参数]

常用参数说明:


--name="xxx"  # 运行容器的名字
-d        # 后台方式运行
-it       # 交互的方式运行
-p        # 指定容器的端口号 例如 -p 6379:6380
        常用的操作有 -p 主机端口:容器端口
-P        # 随机指定端口号

启动 容器里面的 ubuntu,通过主机名字,我们已经可以看出来主机切换了


root@iZuf66y3tuzn4wp3h02t7pZ:~# docker run -it ubuntu /bin/bash
root@87fb04e2a6e7:/#


退出容器


  • 键入 exit 命令,容器会退出
  • 使用快捷键 Ctrl + P + Q ,回到主机,容器不会退出


docker ps 查看容器


docker ps [OPTIONS]


# docker ps -a
CONTAINER ID   IMAGE          COMMAND           CREATED          STATUS                      PORTS                     NAMES
73f951b70438   ubuntu         "/bin/bash"       2 minutes ago    Up 2 minutes                                          vigorous_buck
87fb04e2a6e7   ubuntu         "/bin/bash"       7 minutes ago    d (0) 3 minutes ago                              flamboyant_tu

可选参数:


# 查看正在运行的容器
-a      # 查看运行过的容器
-n=xx   # 查看运行过的前 xx 个容器
-s      # 查看容器运行的 大小
-q      # 查看容器 ID


docker rm 删除容器


docker rm 容器ID    # 删除未运行的容器
docker rm -f 容器ID # 强制删除正在运行的容器
docker rm -f $(docker ps -aq)   # 删除所有容器
docker ps -aq | xargs docker rm   # 删除所有容器


start,restart,stop,kill 开启,重启,停止,强制停止容器


docker start 容器ID
docker restart 容器ID
docker stop 容器ID
docker kill 容器ID


常用其他命令


docker run -d  后台启动容器


# 后台启动一个 ubuntu
docker run -d ubuntu
# 查看 运行的容器
docker ps 
CONTAINER ID   IMAGE     COMMAND                  CREATED         STATUS         PORTS     NAMES

发现没有容器正在运行

原因如下:

  • docker 后台启动服务,需要有一个前台的进程,否则docker 发现没有应用,则会将该服务停止

我们主动加一个前台进程,看看效果

# 临时加上一个前台进程
docker run -d ubuntu /bin/bash -c "while true;do echo xiaozhupeiqi;sleep 2;done"
# 查看正在运行的容器
docker ps
CONTAINER ID   IMAGE     COMMAND
10ba0e687434   ubuntu    "/bin/bash -c 'while…" 
可以看出,docker ps  命令已经可以查看到正在运行的容器了,OK


docker logs 查看日志


docker logs [参数] 容器ID


Options:
  -f    # 和输出保持一致
  -n    # 输出最近的几行
  -t    # 打印时间戳

查看上述容器的日志


# docker logs -tf -n 5 10ba0e687434
2021-08-01T08:02:51.380512218Z xiaozhupeiqi
2021-08-01T08:02:53.381606198Z xiaozhupeiqi
2021-08-01T08:02:55.382780869Z xiaozhupeiqi
2021-08-01T08:02:57.383890580Z xiaozhupeiqi
2021-08-01T08:02:59.384977473Z xiaozhupeiqi
2021-08-01T08:03:01.386430484Z xiaozhupeiqi


docker top 查看容器中进程信息


docker top 容器ID


# docker top 10ba0e68743
UID                 PID                 PPID      CMD
root                11101               11073     bin/bash -c while true;do echo xiaozhupeiqi;sleep 2;done
root                11504               11101


docker inspect 查看镜像元数据


docker inspect 容器 ID

输出信息中省略了大量信息


[
  {
        "Id": "10ba0e6874341b2e2f002c22613a71223ca981dc36df0d1ea4ed3bb5a7a6c58e",
        "Created": "2021-08-01T07:57:52.725305443Z",
        "Path": "/bin/bash",
        "Args": [
            "-c",
            "while true;do echo xiaozhupeiqi;sleep 2;done"
        ],
        "State": {
            ...
        },
       ...
        "GraphDriver": {
      ...
        },
        "Mounts": [],
        "Config": {
            "Hostname": "10ba0e687434",
            ...
            "Env": [
                "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
            ],
            "Cmd": [
                "/bin/bash",
                "-c",
                "while true;do echo xiaozhupeiqi;sleep 2;done"
            ],
            "Image": "ubuntu",
            ...
        },
        "NetworkSettings": {
            ...
                }
    }
]

docker exec 进入当前运行的容器


docker exec [参数]  容器 ID 指令[指令的参数]


# docker exec -it 10ba0e687434 /bin/bash
root@10ba0e687434:/# ps -ef
UID        PID  PPID  C STIME TTY          TIME CMD
root         1     0  0 08:04 ?        00:00:00 /bin/bash -c while true;do echo xiaozhupeiqi;sleep 2;done
root       922     0  0 08:34 pts/0    00:00:00 /bin/bash
root       963     0  0 08:35 pts/1    00:00:00 /bin/bash
root       972     1  0 08:35 ?        00:00:00 sleep 2
root       973   963  0 08:35 pts/1    00:00:00 ps -ef


docker attach 进入容器中正在执行的程序


docker attach 容器ID


docker attach 10ba0e687434
docker exec 和 docker attach 的区别
• docker exec
进入容器,会新开一个终端,可以正常操作
• docker attach
进入容器正在执行的终端,不会启动新的终端


docker cp 将容器内文件拷贝到主机内


docker  cp  容器ID:容器文件路径  主机路径


# 进入容器,在容器的/home 目录下 建一个文件 xiaomotong.go
 docker exec -it 10ba0e687434 /bin/bash
 cd /home/
 touch xiaomotong.go
# Ctrl + P + Q 退出容器
# 将容器内文件拷贝到主机内
docker cp 10ba0e687434:/home/xiaomotong.go ./


docker stats 查看 docker 内服务内存状态


# docker stats
CONTAINER ID   NAME          CPU %     MEM USAGE / LIMIT    MEM %     NET I/O           BLOCK I/O     PIDS
2772a4050157   nginx1        0.00%     3.02MiB / 1.946GiB   0.15%     25.8kB / 33.1kB   0B / 8.19kB   3
#


总结


关于 docker 的命令还是非常的多,大家可以尝试按照下面的图梳理了一下常用的命令列表,便于查询,如下图片来源于网络,仅供学习使用

image.png

欢迎点赞,关注,收藏

朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力

image.png

好了,本次就到这里

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是阿兵云原生,欢迎点赞关注收藏,下次见~


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2月前
|
NoSQL 关系型数据库 MySQL
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
202 56
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
|
2月前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
307 78
|
1月前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
165 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
2月前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
153 24
|
2月前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
205 6
|
7天前
|
Ubuntu API 网络虚拟化
ubuntu22 编译安装docker,和docker容器方式安装 deepseek
本脚本适用于Ubuntu 22.04,主要功能包括编译安装Docker和安装DeepSeek模型。首先通过Apt源配置安装Docker,确保网络稳定(建议使用VPN)。接着下载并配置Docker二进制文件,创建Docker用户组并设置守护进程。随后拉取Debian 12镜像,安装系统必备工具,配置Ollama模型管理器,并最终部署和运行DeepSeek模型,提供API接口进行交互测试。
144 15
|
2月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
2月前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
97 8
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
2月前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
179 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
1月前
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
213 11