【Docker】微服务学习笔记五:Docker常用命令解析

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 【Docker】微服务学习笔记五:Docker常用命令解析

一:引入

  在介绍Docker镜像相关命令之前我们先认识一下镜像的名称组成,镜像名称组成一般分为两部分:[repository]:[tag],前面代表镜像名称,后面代表镜像版本,比如MySqk:5.7,在没有指定tag时候,默认是lastest,代表最新版本。

Docker镜像常用命令有以下6个(参考下图):

  • docker images
  • docker rmi
  • docker pull
  • docker push
  • docker save
  • docker load

这6个命令的功能见下图

Docker容器相关命令主要有以下9个:

  • docker run
  • docker pause
  • docker unpause
  • docker stop
  • docker start
  • docker exec
  • docker logs
  • docker ps
  • docker rm

这9个命令的功能见下图

二:Docker镜像常用命令演示

1.镜像拉取

  通常我们都会去DockerHub官网进行镜像的拉取,进入官网之后,比如说我要拉取nginx的镜像,我就可以在上方搜索nginx

选择官方镜像

  点击进去之后在右边会出现一个命令docker pull nginx,执行这个命令拉去的是最新版,当然我们也可以自定义版本,也就是执行docker pull nginx:xx,下面我演示的是拉取最新版本:

查看系统中的镜像(docker images)

可以看到拉取到的是最新版本

2.保存&加载镜像

  我们可以从本地镜像仓库中将镜像保存下来打包发送,这里说明一下,假如你不知道某个命令如何使用,那么你就可以查看帮助文档,命令为docker xx --help,这里演示如何通过帮助文档查看docker save的介绍:

可以看到save命令的格式为docker save [OPTIONS] IMAGE [IMAGE…],下面执行这个命令

可以看到成功将nginx镜像下载到本地

那么如何将本地镜像加载到镜像仓库呢?首先我先将原来的镜像卸载(docker rmi image:tag)

可以看到成功将本地镜像仓库中的nginx镜像卸载了,接下来进行镜像加载

可以看到镜像成功加载

三:Docker容器常用命令

1.启动容器

docker run --name containerName -p 80:80 -d nginx

命令解读:

  • docker run:创建并运行一个容器
  • –name:给容器起一个名字,比如叫做ng
  • -p:将宿主机端口与容器端口进行映射,冒号左边是宿主机端口,冒号右边是容器端口
  • -d:后台运行容器
  • nginx:镜像名称

补充:

  为什么需要端口映射呢?因为假如你直接去访问容器时访问不了的,因为前面说过容器是被隔绝起来的,要想访问就必须通过端口进行映射,所谓端口映射通俗来说就是当我们想要访问容器的80端口时候你就可以通过访问宿主机的80端口然后宿主机再将该请求映射到容器的80端口达到让用户可以访问。

-d的意思就是当我们关闭窗口后容器的服务程序仍还在运行中的,相当于在后台运行。

执行docker run

返回的是容器的唯一id

2.查看容器状态及日志

可以看到有一个容器正在运行,下面尝试访问nginx

可以看到成功访问到nginx

输入命令docker logs -f ng

可以看到输出一堆日志信息,假如你要持续输出日志,你可以执行这个命令docker logs -f ng,当然后面那个参数是你的容器名字。

3.进入容器修改文件

  通过Docker的exec命令可以进入到容器里面对容器的文件进行修改,以我上面创建的ngnix为例,可执行docker exec -it ng bash进入该容器内部,命令解读:

  • docker exec:进入容器内部,执行一个命令
  • -it:给当前进入容器创建一个标准输入、输出终端,允许我们与容器进行交互
  • ng:要进入的容器的名称
  • bash:进入容器后执行的命令,bash是一个linux终端交互命令

  但是不建议通过这样去修改容器文件,因为这样做首先很麻烦,因为容器中只包含必要的函数库和文件,因此进入容器后不能通过vi或者vim命令对文件进行修改;而且通过这样的方式对容器文件进行修改是没有记录的。

4.数据卷操作

  前面提到不建议通过进入容器内部的形式对文件进行修改,那么是否还有更佳的方案呢?答案是肯定的,即通过数据卷来完成这一功能,数据卷可以理解为数据的双向绑定,即将你宿主机的文件和容器中的文件绑定起来,其中一个发生改变另一个都会跟着发生改变。数据卷能够将容器与数据分离,解耦合,方便操作容器内部数据,保证数据安全。

(1)基本语法

数据卷的基本语法如下:

docker volume [COMMAND],常用command命令有:

  • create:创建一个volume
  • inspect:显示一个或多个volume的信息
  • ls:列出所有的volume
  • prune:删除未使用的volume
  • rm:删除一个或多个指定volume

(2)挂载操作

我们在创建容器时候,可以通过-v参数来挂载一个数据卷到某个容器目录,举例如下:

docker run \ //创建容器并运行容器

–name ng \ //给容器起名为ng

-v html:/root/html \ //将html数据卷挂载到容器内部/root/html这个目录中

-p 8080:8080 \ //将宿主机的8080端口映射到容器内的8080端口

nginx //镜像名称

需要注意的是,假如我们没有提前创建好数据卷,那么执行docker run -v时候docker会自动帮我们创建。

相关文章
|
21天前
|
NoSQL Java Linux
《docker高级篇(大厂进阶):2.DockerFile解析》包括:是什么、DockerFile构建过程解析、DockerFile常用保留字指令、案例、小总结
《docker高级篇(大厂进阶):2.DockerFile解析》包括:是什么、DockerFile构建过程解析、DockerFile常用保留字指令、案例、小总结
193 75
|
28天前
|
NoSQL 关系型数据库 MySQL
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
159 56
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
|
1月前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
236 77
|
5天前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
52 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
5天前
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
43 10
|
1月前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
102 24
|
1月前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
139 6
|
1月前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
90 3
|
关系型数据库 MySQL 应用服务中间件
docker 常用命令总结
docker 常用命令总结
|
Docker 容器
docker常用命令总结大全
docker常用命令总结大全
166 0