Kubernetes、Docker 和 Docker Registry 关系是是什么?
Kubernetes(常简称为 k8s)、Docker 和 Docker Registry 是现代云原生应用中三个关键的组件,它们各自承担不同的职责,但在容器化部署和管理过程中紧密协作。以下是它们之间关系的详细解释:
一、核心概念简介
1. Docker
- 定义:Docker 是一个开源的容器化平台,允许开发者打包应用及其依赖项到一个轻量级、可移植的容器中。
- 主要组件:
- Docker Engine:运行和管理容器的核心引擎。
- Docker CLI:命令行工具,用于与 Docker Engine 交互。
- Docker Compose:用于定义和管理多容器 Docker 应用的工具。
2. Docker Registry
- 定义:Docker Registry 是一个存储和分发 Docker 镜像的服务。最常用的公共 Registry 是 Docker Hub,此外也可以搭建私有的 Docker Registry。
- 功能:
- 存储镜像:保存不同版本的 Docker 镜像。
- 分发镜像:允许用户从 Registry 拉取(下载)镜像或推送(上传)镜像。
- 常用类型:
- 公有 Registry:如 Docker Hub、Google Container Registry(GCR)、Amazon Elastic Container Registry(ECR)等。
- 私有 Registry:组织内部搭建的 Docker Registry,用于存储私有镜像,通常部署在内部网络中以确保安全性。
3. Kubernetes(k8s)
- 定义:Kubernetes 是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用。
- 核心组件:
- 控制平面(Control Plane):负责整个集群的管理和决策,包括 API Server、Scheduler、Controller Manager 等。
- 节点(Nodes):实际运行容器化应用的工作负载单元,包括 Master Node 和 Worker Node。
4. Node
- 定义:在 Kubernetes 中,Node 是集群中的一台物理或虚拟机,负责运行容器化的应用。每个 Node 都包含运行这些容器所需的服务和组件。
- 类型:
- Master Node(控制节点):负责管理和协调集群。运行控制平面组件,如 API Server、Scheduler、Controller Manager 等。
- Worker Node(工作节点):实际运行应用容器的节点。每个 Worker Node 都运行一些关键组件,如 Kubelet、Kube-proxy 以及容器运行时(如 Docker)。
二、Kubernetes、Docker、Registry 与 Node 的关系
1. 容器化应用的开发与构建
- 开发者使用 Docker:
- 开发者首先使用 Docker 创建应用的 Dockerfile,定义应用的运行环境、依赖和启动命令。
- 通过 Docker CLI 构建 Docker 镜像:
docker build -t your-image-name:tag .
- 构建完成后,将镜像推送到 Docker Registry:
docker push your-registry/your-image-name:tag
2. Kubernetes 部署与管理
- 定义 Kubernetes 配置文件:
- 在 Kubernetes 中,开发者创建如 Pod、Deployment、Service 等配置文件,指定使用的 Docker 镜像。
- 例如,一个简单的 Deployment 配置:
apiVersion: apps/v1 kind: Deployment metadata:name: my-app spec:replicas: 3selector:matchLabels:app: my-apptemplate:metadata:labels:app: my-appspec:containers:- name: my-app-containerimage: your-registry/your-image-name:tagports:- containerPort: 80
- 应用配置:
kubectl apply -f your-deployment.yaml
- Kubernetes 调度 Pod:
- Scheduler 根据资源需求、亲和性等策略将 Pod 调度到合适的 Worker Node 上。
- Kubelet 运行在每个 Worker Node 上,负责与 Docker Engine(或其他容器运行时)通信,拉取镜像并启动容器。
3. Node 在 Kubernetes 中的角色
-
Worker Node 组件:
- Kubelet:每个 Worker Node 上的主要代理,确保 Pod 规范中的容器按预期运行。
- Kube-proxy:负责节点上的网络代理和负载均衡。
- 容器运行时(例如 Docker):实际运行和管理容器。
-
Workflow:
- 拉取镜像:
- Kubelet 指示 Docker 从 Docker Registry 拉取所需的镜像。
- 例如,Docker Engine 在 Worker Node 上执行:
docker pull your-registry/your-image-name:tag
- 启动容器:
- Docker 启动容器,并根据 Kubernetes 的配置管理容器的生命周期。
- 资源管理和监控:
- Kubelet 监控容器的运行状态,报告给控制平面,确保 Pod 的稳定运行。
- 网络和服务发现:
- Kube-proxy 处理节点上的网络流量,确保服务请求能够正确路由到相应的容器。
- 拉取镜像:
4. Docker Registry 和 Node 的交互
-
镜像存储与分发:
- Docker Registry 作为镜像的存储中心,Worker Node 通过 Docker Engine 从 Registry 拉取所需的镜像。
- 私有 Registry 提供更高的安全性和控制,适用于内部应用和敏感数据。
-
认证与权限管理:
- 如果使用私有 Registry,Worker Node 需要相应的凭证来拉取镜像。这通常通过在 Kubernetes 中配置 ImagePull Secrets 实现。
kubectl create secret docker-registry my-registry-secret \--docker-server=your-registry \--docker-username=your-username \--docker-password=your-password \--docker-email=your-email
- 在 Pod 配置中引用 Secret:
spec:containers:- name: my-app-containerimage: your-registry/your-image-name:tagimagePullSecrets:- name: my-registry-secret
- 如果使用私有 Registry,Worker Node 需要相应的凭证来拉取镜像。这通常通过在 Kubernetes 中配置 ImagePull Secrets 实现。
三、具体关系示意
+--------------------+ Push +---------------------+
| Dockerfile (Code) | ------------------------> | Docker Engine |
+--------------------+ +---------------------+|| Buildsv+-------------------------------+| Docker Registry || (e.g., Docker Hub, Private Reg)|+-------------------------------+|| Kubernetes pullsv+----------------------------------------------+| Kubernetes || (Control Plane and Worker Nodes) |+----------------------------------------------+| || |+----------------------------------+ +----------------------------------+| |v v
+---------------------+ Uses Docker Engine +---------------------+
| Worker Node 1 | <------------------------------------------------------ | Widget-Server Pod |
| - Kubelet | | - Runs containers |
| - Kube-proxy | | - Managed by K8s |
| - Docker Engine | +---------------------+
+---------------------+
四、关键互动流程
1. 构建与推送镜像
- 编写 Dockerfile:定义应用的构建步骤和运行环境。
- 构建镜像:
docker build -t your-registry/your-image-name:tag .
- 推送镜像到 Registry:
docker push your-registry/your-image-name:tag
2. 在 Kubernetes 中部署应用
- 定义 Kubernetes 配置文件(如 Deployment、Service 等),指定使用的 Docker 镜像。
- 应用配置:
kubectl apply -f your-deployment.yaml
- Kubernetes 调度 Pod:
- Scheduler 将 Pod 分配到合适的 Worker Node。
- Kubelet 在 Worker Node 上拉取镜像并启动容器。
- 运行与管理:
- Kubernetes 监控容器的运行状态,进行必要的重启、扩展或滚动更新。
3. 镜像更新与滚动更新
- 更新应用代码,修改 Dockerfile。
- 重新构建并推送新的镜像:
docker build -t your-registry/your-image-name:new-tag . docker push your-registry/your-image-name:new-tag
- 更新 Kubernetes 配置,指向新的镜像标签:
image: your-registry/your-image-name:new-tag
- 应用更新:
kubectl apply -f your-deployment.yaml
- Kubernetes 执行滚动更新,逐步替换旧版本的容器为新版本,确保服务的持续可用性。
五、Node 的详细角色与关系
1. Master Node(控制节点)
-
功能:
- API Server:Kubernetes 的前端,所有 REST 操作都通过它进行。
- Scheduler:负责将 Pod 调度到合适的 Worker Node。
- Controller Manager:管理控制器,确保集群的期望状态与实际状态一致。
- etcd:分布式键值存储,保存集群的所有数据。
-
与 Docker 和 Registry 的关系:
- Master Node 本身不直接运行应用容器,但负责调度 Pod 到 Worker Node,间接影响 Docker Engine 的操作。
- 通过控制平面组件,Master Node 确保 Worker Node 能够从 Docker Registry 拉取正确的镜像并运行容器。
2. Worker Node(工作节点)
-
功能:
- 运行 Pod:实际承载和运行容器化的应用。
- Kubelet:与 Master Node 通信,接收任务并管理容器生命周期。
- Kube-proxy:处理网络代理和负载均衡,确保服务的网络访问。
- 容器运行时(如 Docker):负责实际拉取镜像、创建和管理容器。
-
与 Docker 和 Registry 的关系:
- Docker Engine:在 Worker Node 上运行,负责从 Docker Registry 拉取镜像并启动容器。
- 镜像拉取:
- Kubelet 向 Docker Engine 发送拉取镜像的请求,Docker Engine 从指定的 Registry 下载镜像。
- 如果是私有 Registry,需要相应的认证凭证(如 ImagePull Secrets)。
-
安全与隔离:
- Worker Node 使用网络策略和安全组来隔离和保护运行中的容器。
- 通过 Kubernetes 的角色和权限管理,确保只有授权的 Pod 能够访问特定的资源。
3. 容器与 Node 的交互
-
资源管理:
- Kubernetes 根据 Pod 的资源需求(如 CPU、内存)将其调度到具备足够资源的 Worker Node。
- Docker Engine 在 Node 上分配资源,确保容器按需运行。
-
扩展与自愈:
- Kubernetes 可以根据需求自动扩展 Pod 数量,将其分配到不同的 Worker Node。
- 当容器或 Node 出现故障时,Kubernetes 会重新调度 Pod 到健康的 Node 上。
六、实战示例
假设您有一个私有 Docker Registry,IP 为 192.168.0.180:5000
,并且 Kubernetes 集群由一个 Master Node 和多个 Worker Node 组成。
1. 构建并推送镜像到私有 Registry
# 在开发机上
docker build -t 192.168.0.180:5000/my-app:v1.0 .
docker push 192.168.0.180:5000/my-app:v1.0
2. 配置 Kubernetes 使用私有 Registry
kubectl create secret docker-registry my-registry-secret \--docker-server=192.168.0.180:5000 \--docker-username=my-username \--docker-password=my-password \--docker-email=my-email@example.com
3. 部署应用到 Kubernetes 集群
Deployment 配置文件(deployment.yaml):
apiVersion: apps/v1
kind: Deployment
metadata:name: my-app-deployment
spec:replicas: 3selector:matchLabels:app: my-apptemplate:metadata:labels:app: my-appspec:containers:- name: my-app-containerimage: 192.168.0.180:5000/my-app:v1.0ports:- containerPort: 80imagePullSecrets:- name: my-registry-secret
应用配置:
kubectl apply -f deployment.yaml
4. Kubernetes 调度与运行
- 调度 Pod:Scheduler 将
my-app-deployment
的 Pod 分配到 Worker Node 上。 - 拉取镜像:Worker Node 上的 Docker Engine 从
192.168.0.180:5000
拉取my-app:v1.0
镜像。 - 启动容器:Docker Engine 启动容器,Kubelet 监控容器状态。
七、总结
- Docker 是容器化应用的基础设施,负责构建和运行容器。
- Docker Registry 作为镜像存储和分发中心,连接开发过程与运行环境,支持镜像的共享和版本管理。
- Kubernetes 提供了强大的容器编排功能,通过调度和管理容器化应用,实现自动化部署、扩展和自愈。
- Node 是 Kubernetes 集群中的工作负载执行单元,运行实际的容器化应用。每个 Worker Node 上运行 Docker Engine(或其他容器运行时),负责从 Registry 拉取镜像并启动容器。
理解 Kubernetes 中 Node 的角色及其与 Docker 和 Registry 的互动,是有效管理和优化容器化应用的关键。通过协调使用这三者,您可以构建高效、可扩展和可靠的现代应用架构。
相关文章:

Kubernetes、Docker 和 Docker Registry 关系是是什么?
Kubernetes(常简称为 k8s)、Docker 和 Docker Registry 是现代云原生应用中三个关键的组件,它们各自承担不同的职责,但在容器化部署和管理过程中紧密协作。以下是它们之间关系的详细解释: 一、核心概念简介 1. Docker…...

docker部署微信小程序自动构建发布和更新
通过 Jenkins 和 Docker 部署微信小程序,并实现自动构建、发布和版本更新,主要涉及以下几个步骤: 设置 Jenkins 环境配置 GitLab 与 Jenkins 的集成构建 Docker 镜像部署和发布微信小程序配置 Jenkins 自动构建 以下是详细的步骤说明&#…...

模仿elementui的Table,实现思路
vue2子组件使用render,给子子组件插槽传值 和elementui的Table一样使用render 在 Vue 2 中,子组件使用render函数向子子组件插槽传值可以通过以下步骤实现: 1、创建子组件 首先创建一个子组件,在子组件中使用render函数来渲染内容…...

Unity中使用环形缓冲区平滑抖动值
环形缓冲数据结构,就是如下图一样的一个收尾相接的列表 在index指针指到4时,再往里添加数据,index就会指向0,并覆盖已有数据。 如何绘制Sin函数,请看下面一篇文章 Unity中如何实现绘制Sin函数图像-CSDN博客 接下来要…...

【Yonghong 企业日常问题 06】上传的文件不在白名单,修改allow.jar.digest属性添加允许上传的文件SH256值?
文章目录 前言问题描述问题分析问题解决1.允许所有用户上传驱动文件2.如果是想只上传白名单的驱动 前言 该方法适合永洪BI系列产品,包括不限于vividime desktop,vividime z-suit,vividime x-suit产品。 问题描述 当我们连接数据源的时候&a…...

SpringBoot使用 AOP 实现自定义日志记录并保存在Mysql
本文主要介绍在 Spring Boot 中使用 AOP 实现自定义日志记录并保存在 Mysql 的方法。先阐述记录日志的重要性及传统方式的弊端,提出新方式,即通过创建自定义注解、切面类等,将重要日志存到数据库,还给出了创建日志表、注解类、切面…...

谷歌开源最强天气预报AI模型 GenCast
谷歌 DeepMind 开源新一代天气预测 AI 模型 GenCast,GenCast 以最先进的精度预测天气和极端条件的风险 天气预报对人们生活和决策至关重要,但传统 NWP 模型存在不确定性,且计算资源需求大、运行慢。机器学习在天气预报中虽有进展,…...

C++打造局域网聊天室第十课: 客户端编程及数据发送
文章目录 前言一、补充内容,设置显示框换行二、客户端编程三、封装消息发送函数四、所处的身份状态总结 前言 C打造局域网聊天室第十课: 客户端编程及数据发送 一、补充内容,设置显示框换行 编辑框的显示内容默认是不会换行的,这…...

Nginx整合Lua脚本
Nginx-Lua Nginx整合Lua脚本 Lua环境搭建 下载地址 linux环境下 yum install lua安装后验证 lua -vLua脚本执行 lua xxx.luaNginx整合Lua nginx需要添加lua模块 嵌入内容 示例如下 修改nginx.conf如下 location /lua {default_type text/plain;content_by_lua ngx.sa…...

【C++】C++11 STL容器emplace方法原理剖析
在 C 11 STL 容器中,push/insert > emplace 新的方法,push 和 emplace 的区别在于: 1. push push 通常用于将一个元素添加到容器的末尾(在 std::vector、std::deque 等序列容器中),或者在关联容器中插入…...

QT-简单视觉框架代码
文章目录 简介1. 整体架构2. 关键类功能概述3. 详细代码实现hikcameraworker.h 和 hikcameraworker.cpp(海康相机工作线程类)imageviewerwidget.h 和 imageviewerwidget.cpp(图像查看部件类)构造函数 ImageViewerWidget析构函数 ~…...

AI新书推荐:深度学习和大模型原理与实践(清华社)
本书简介 在这个信息爆炸、技术革新日新月异的时代,深度学习作为人工智能领域的重要分支,正引领着新一轮的技术革命。《深度学习和大模型原理与实践》一书,旨在为读者提供深度学习及其大模型技术的全面知识和实践应用的指南。 本书特色在于…...

[spring]处理器
我们可以通过spring来管理我们的类,之后我们可以通过spring的容器来获取我们所需要的Bean类对象。Spring的处理器是Spring对外开发的重要扩展点,它允许我们介入到Bean的整个实例化流程中来,可以动态添加、修改BeanDefinition、动态修改Bean 首…...

重温设计模式--中介者模式
中介者模式介绍 定义:中介者模式是一种行为设计模式,它通过引入一个中介者对象来封装一系列对象之间的交互。中介者使得各个对象之间不需要显式地相互引用,从而降低了它们之间的耦合度,并且可以更方便地对它们的交互进行管理和协调…...

重温设计模式--设计模式七大原则
文章目录 1、开闭原则(Open - Closed Principle,OCP)定义:示例:好处: 2、里氏替换原则(Liskov Substitution Principle,LSP)定义:示例:好处&#…...

LeetCode429周赛T4
最小化二进制字符串中最长相同子字符串的长度 在处理二进制字符串问题时,优化字符串结构以满足特定条件是一项常见的挑战。本文将探讨一个具体的问题:给定一个长度为 n 的二进制字符串 s 和一个整数 numOps,通过最多 numOps 次位翻转操作&am…...

详解MySQL在Windows上的安装
目录 查看电脑上是否安装了MySQL 下载安装MySQL 打开MySQL官网,找到DOWNLOADS 然后往下翻,找到MySQL Community(GPL) Downloads>> 然后找到MySQL Community Server 然后下载,选择No thanks,just start my download. 然后双击进行…...

【Python使用】嘿马python高级进阶全体系教程第10篇:静态Web服务器-返回固定页面数据,1. 开发自己的静态Web服务器【附代码文档】
本教程的知识点为:操作系统 1. 常见的操作系统 4. 小结 ls命令选项 2. 小结 mkdir和rm命令选项 1. mkdir命令选项 压缩和解压缩命令 1. 压缩格式的介绍 2. tar命令及选项的使用 3. zip和unzip命令及选项的使用 4. 小结 编辑器 vim 1. vim 的介绍 2. vim 的工作模式 …...

软件测试面试题和简历模板(面试前准备篇)
一、问题预测 1、让简单介绍下自己(这个不用说了每次面试开场) 面试官,你好,我叫xxx,xx年本科毕业,从事软件测试将近3年的时间。在此期间做过一些项目也积累过一些经验,能够独立地完成软件测试…...

Linux 基本使用和程序部署
1. Linux 环境搭建 1.1 环境搭建方式 主要有 4 种: 直接安装在物理机上。但是Linux桌面使用起来非常不友好,所以不建议。[不推荐]。使用虚拟机软件,将Linux搭建在虚拟机上。但是由于当前的虚拟机软件(如VMWare之类的)存在一些bugÿ…...

uniapp微信小程序,使用fastadmin完成一个一键获取微信手机号的功能
前端部分 点击按钮,获取手机号 <button open-type"getPhoneNumber" getphonenumber"bindGetPhoneNumber" hover-class"none"class"btn-purity">一键获取</button> 传入openid和code bindGetPhoneNumber(e) …...

CSS系列(27)- 图形与滤镜详解
前端技术探索系列:CSS 图形与滤镜详解 🎨 致读者:探索CSS的艺术表现力 👋 前端开发者们, 今天我们将深入探讨 CSS 图形和滤镜效果,学习如何创建引人注目的视觉效果。 基础图形 🚀 几何形状…...

Docker 技术系列之安装多版本Mysql5.6和Mysql5.7
image 大家好,后面的就不是关于MAC专有的内容,基本是跟Java环境,基础技术方面有关。所以这个教程对于在linux系统还是macOS都是通用的,不用担心。 上一篇,我们安装好对应的Docker之后,感受到了它的便利。接…...

理解并使用Linux 内核中的 Tracepoint
理解并使用Linux 内核中的 Tracepoint 1. 引言 1.1 为什么需要 Tracepoint? 在内核调试与性能分析中,传统的 printk 方法虽然简单直接,但存在几个显著的局限性: 日志噪音:printk 会将所有输出无差别地记录到系统日…...

centos7中Gbase8s数据库安装,以及数据导入遇到的一系列问题
centos7中Gbase8s数据库安装,以及遇到的一系列问题 以下是我在centos7上安装gbase8s数据库遇到的一系列问题,包括数据库安装,数据导入,数据连接,不能完全作为标准,只可作为类似问题参考,有问题…...

AW36518芯片手册解读(3)
接前一篇文章:AW36518芯片手册解读(2) 二、详述 3. 功能描述 (1)上电复位 当电源电压VIN降至预定义电压VPOR(典型值为2.0V)以下时,该设备会产生复位信号以执行上电复位操作&#x…...

MySQL的REPEATABLE READ事务隔离级别
本文隔离级别: T1内读T2的update数据 首先开两个事务(左二) 事务1修改成李四,提交 事务2再读还是张三,也就是说,记录的数据从事务开始时一直到结束,读的都是同一个版本,读不到T2未提交的此条记录修改&…...

sqoop的参数有哪些?
Sqoop 是一款用于在 Hadoop 与关系型数据库之间进行数据传输的工具,它有很多参数,可分为通用参数、导入参数和导出参数等,以下是一些常见的参数介绍: 通用参数 --connect 说明:指定要连接的关系型数据库的 JDBC URL。…...

动态规划<四> 回文串问题(含对应LeetcodeOJ题)
目录 引例 其余经典OJ题 1.第一题 2.第二题 3.第三题 4.第四题 5.第五题 引例 OJ 传送门Leetcode<647>回文子串 画图分析: 使用动态规划解决 原理:能够将所有子串是否是回文的信息保存在dp表中 在使用暴力方法枚举出所有子串,是…...

跨模态知识迁移:基于预训练语言模型的时序数据建模
在NLP和CV领域,通常通过在统一的预训练模型上进行微调,能够在各自领域的下游任务中实现SOTA(最先进)的结果。然而,在时序预测领域,由于数据量相对较少,难以训练出一个统一的预训练模型来覆盖所有…...