几句话明白什么是Kubernetes Operator?

一、Operator的意思

Operator翻译过来叫操作员, 这是一个基于人的概念,

那么基于机器的概念就是软件的操作员。

二、为什么有这个软件的操作员的概念?

1、先思考一个问题,什么时候需要操作员?

1、当Kubernetes自动化无法完成的工作是不是就需要人工的干预,这类人称之为操作员。

2、比如一个3副本的Mysql Cluster,一个副本挂了,Kubernetes知道不知道Mysql集群内部的状态是否正常?数据是否同步成功?答案肯定是不知道的,这个时候就需要人工干预,这个人就是操作员,也就是Operator。

3、那么Kubernetes设计之初就说我们是一个自动化、减少人工干预的、自动修复平台,是不是优点问题。

4、这个时候就设计出了一个概念叫Operator,意思就是软件的操作员。

三、什么应用需要Operator?

1、有状态应用,比如数据库、复杂的集群系统(ELK),本身有选举、同步等机制的应用程序。

四、Operator怎么实现的?

1、要实现软件Operator层面,Kubernetes本身的api是不能够完成这类任务的,因为Kubernetes不可能存储所有应用的控制生命周期的知识。

2、CRD就出现的,自定义资源。

3、这些被单独定义的CRD就是Operator的具体控制生命周期的"知识"。

4、那么也可以说存在Operator必然是有状态应用且必须有扩展的CRD资源存在。

五、谁来负责开发Operator?

1、一般是应用程序的厂商或者具备这类专业知识的人员开发。

相关推荐
-小末1 小时前
使用docker manifest制作本地多架构镜像
docker·容器·多架构镜像
掘金安东尼4 小时前
Amazon Polly :让文字开口说话的云端实践
人工智能·云原生
照物华6 小时前
K8s概念之进程、容器与 Pod 的终极指南
云原生·容器·kubernetes
vvilkim11 小时前
Java主流框架全解析:从企业级开发到云原生
java·运维·云原生
JohnYan18 小时前
工作笔记 - CentOS7环境运行Bun应用
javascript·后端·容器
ezreal_pan18 小时前
Kubernetes 负载均衡现象解析:为何同一批次请求集中于单个 Pod
运维·云原生·k8s·traefik
小猿姐18 小时前
KubeBlocks AI:AI时代的云原生数据库运维探索
数据库·人工智能·云原生·kubeblocks
曼岛_19 小时前
[系统架构设计师]云原生架构设计理论与实践(十四)
云原生·系统架构·系统架构设计师
科大饭桶19 小时前
C++入门自学Day14-- Stack和Queue的自实现(适配器)
c语言·开发语言·数据结构·c++·容器
城管不管20 小时前
Docker核心---数据卷(堵门秘籍)
运维·docker·容器