kubernetes 概览
kubernetes 核心数据 (存储于ETCD 有数据变化通知的功能(watch-dog))
kubernetes 设计综述 (中英文对照)(http://www.oschina.net/translate/kubernetes-design-overview?cmp)
先看设计综述 理解POD 的什么东西
/
/registry
/pods
/${PODID}->VALUE
/hosts
/${MACHINE}
/kubelet->VALUE
/controllers
/${CONTROL_ID}->VALUE
/services
/specs
/${SVR_ID}->VALUE
/endpoints
/${SVR_ID}->VALUE
/minions
/${ID}->VALUE
VALUE 对应 kubernetes/pkg/api/types.go 中定义
kubernetes 的系统中进程负责的功能
进程的入口main函数 对应 目录 kubernetes/cmd/ 中
api-server
kubernetes/pkg/registry/中 定义有 pods endpoints bindings controller service minion 这几个资源 提供POST PUT GET DELETE 作为动作 去操作 (熟悉REST API 设计应该理解的)
负责维护以上的树形结构 并提供了select 操作 (以 ETCD 作为一致性的KV存储)
kubecfg
用于控制用户输入( create -> pod service controller )
controller-manager
关注 /registry/controllers
读取 controllers controllers 有 POD 模版 以及 POD 运行数量
根据模版来创建 POD 分配POD (/registry/pods) --> 产生未分配的POD
定期检测 controllers POD 活动数量 少则增加启动 多则 停止删除 ( see scheduler )
关注 /registry/services/specs
读取 services
检测 services 标签下(看下面标签概念) 所有的POD
读取POD的ip和containers的port 生成 endpoints ( see proxy )
services 的作用就是生成代理 由 代理 转发数据到 对应标签下POD内部
scheduler
关注 /registry/pods/ (使用selector 只读取到未分配的POD)
获取未分配的POD
为POD分配机器
写入 /registry/pods/{ID}标记为分配过的。
同时/registry/hosts/{machine}/kubelet ( see kubelet )
kubelet
关注/registry/hosts/{machine}/kubelet
获取pods 并 启动Pod
proxy
关注 /registry/services/specs 变化
关注 /registry/services/endpoints 变化
获取services/specs 生成代理 代理到 specs.ID 对应的 endpoints.ID
( TCP 将每个连接负载均衡到 services ($SVR_ID} 下所有的 endpoints (pod address) )
specs 代表服务的外部PORT endpoints对应容器内部 address
4个进程都是通过apiserver来操作DB以及watch DB的变化 来达到通信的
流程
create POD
1. kubecfg 提交 create a pod
2. apiserver 将该pod 写入 /registry/pods 中 标记为 未分配
3. scheduler 由于关注了 /registry/pods 收到通知 读取未分配的 POD 然后从 kubernetes系统的节点中找到一台机器分配给POD 写入/registry/hosts/{machine}/kubelet 并写回到/registry/pods标记为分配的
4. kubelet 由于关注了/registry/hosts/{machine}/kubelet 读取到分配给自己的POD 然后 用docker 运行该POD中定义的所有容器 写回到 /registry/hosts/{machine}/kubelet 标记运行
create controller
1. kubecfg 提交 create a controller
2. apiserver 将该pod 写入 /registry/controllers
3. controller-manager 关注了 /registry/controllers 读取到新的 controllers
启动定时器定期检测 定期检测 controllers POD 活动数量 少了 会想apiserver 提交一个create pod 多了 则 stop pod
next create POD
services 的作用是分配代理 并不影响POD的启动运行
思考
proxy 的作用 考虑 如下情况
当你通过 kubercfg create a pod 这个Pod 运行在哪个服务器 你不知道 也就是说 你无法接入到你 服务
这个时候你创建一个service提交后 系统内部知道POD运行在那里 会根据service的PROT代理到你的POD中
之后你连接proxy对应的PORT后 proxy会为你转发数据到对应的POD proxy代理对POD来说是透明的(正向代理,但是你知道这事连接的PROXY);
关键概念:标签
pod用标签进行组织。每个pod具备一个key/value键值映射的标签。
通过“标签查询”,用户可以识别一系列的pod集合。这个简单的方法是services和replicationControllers如何工作的关键部分。一个service指向的pod集合由一个标签查询定义。类似的,由replicationController监听的pod的数量同样也是由标签查询定义。
标签查询通常会用于,我们讲,在一个应用程序层次上面识别和分组的pod。同样可以用来识别栈,例如dev、staging或者production。
kubernetes 概览的更多相关文章
- Kubernetes概览
Kuberbetes这个名字是什么意思?k8s又是什么?Kubernetes这个名字源自希腊语,意思是“舵手”,也是“管理者”,“治理者”等词的源头.k8s是 Kubernetes的简称(用数字『8』 ...
- Kubernetes 概念整理
注:以下大部分内容来自网上摘录,以便后期查阅. Kubernetes (通常称为 K8s) 是用于自动部署.扩展和管理容器化(containerized)应用程序的开源系统,是 Google 内部工具 ...
- 基于Docker本地运行Kubernetes
基于Docker本地运行Kubernetes 概览 下面的指引将高速你如何通过Docker创建一个单机.单节点的Kubernetes集群. 下图是最终的结果: 先决条件 \1. 你必须拥有一台安装有D ...
- kubernetes社区项目生态概览
原文 http://dockone.io/article/2075 作为容器集群管理技术的最流行的技术,kubernetes,自从2014在github上开源后,已经通过多个项目形成了一个生态,以下 ...
- 基于Python+Django的Kubernetes集群管理平台
➠更多技术干货请戳:听云博客 时至今日,接触kubernetes也有一段时间了,而我们的大部分业务也已经稳定地运行在不同规模的kubernetes集群上,不得不说,无论是从应用部署.迭代,还是从资源调 ...
- Kubernetes初步
Kubernetes是Google开源的容器集群管理系统.它构建于docker技术之上.为容器化的应用提供资源调度.部署执行.服务发现.扩容缩容等整一套功能.本质上可看作是基于容器技术的mini-Pa ...
- Docker 生态概览
Docker 和容器技术的发展可谓是日新月异,本文试图以全局的视角来梳理一下 docker 目前的生态圈.既然是概览,所以不会涉及具体的技术细节. Docker 自从发布以来发生了很多的变化,并且有些 ...
- 101 - kube-scheduler源码分析 - k8s源码组织结构概览
ps:本来应该先发这一篇,再开始讲cobra的,昨天不小心先把 cobra发出去了,今天补上源码概览~ 如上,我们下载好后切换到1.10版本的分支,项目目录结构是这样的(目录部分).有很多,我们先不纠 ...
- Kubernetes & Docker
Docker核心技术原理及其应用 Docker 概览 Docker版本与安装介绍 Docker 核心技术之镜像 Docker 核心技术之容器 Docker 核心技术之容器与镜像 Docker 核心技术 ...
随机推荐
- 微信小程序中在swiper-item中遍历循环添加多个数据内容(微信小程序交流群:604788754)
在小程序中为了实现一个<swiper-item>中添加多个内容重复的标签,那就需要使用wx:for循环.如果按小程序的简易教程,循环加在block中,而swiper-item放在里面.所有 ...
- 使用Angular 4、Bootstrap 4、TypeScript和ASP.NET Core开发的Apworks框架案例应用:Task List
最近我为我自己的应用开发框架Apworks设计了一套案例应用程序,并以Apache 2.0开源,开源地址是:https://github.com/daxnet/apworks-examples,目的是 ...
- Ajax与Pjax请求在服务端是如何识别的
我在后台处理ajax和一般的网页请求时,一般是需要额外加个参数进行区分的.比如使用get参数的is_ajax=1,后台判断有is_ajax=1成立时,表明该请求是ajax请求,遂可区分处理.我正在使用 ...
- 获取安卓的SH1安全码
用于获取手机联系人 信息 public static String sHA1(Context context) { try { PackageInfo info = context.getPac ...
- arm处理器
arm处理器 arm处理器相关 1.体系架构定义了指令集(ISA)和基于这一体系结构下处理器的编程模型. arm卖的是架构或者已经设计好的公版ip核 卖给苹果高通的是架构,需要苹果高通通过架构设计自己 ...
- find命令之xargs,exec
一,find命令之xargs: 在 使用 find命令的-exec选项处理匹配到的文件时, find命令将所有匹配到的文件一起传递给exec执行.但有些系统对能够传递给exec的命 令长度有限制,这样 ...
- RFM模型——构建数据库营销的商业战役!(转)
RFM模型:R(Recency)表示客户最近一次购买的时间有多远,F(Frequency)表示客户在最近一段时间内购买的次数,M (Monetary)表示客户在最近一段时间内购买的金额.一般原始数据为 ...
- 学习笔记TF016:CNN实现、数据集、TFRecord、加载图像、模型、训练、调试
AlexNet(Alex Krizhevsky,ILSVRC2012冠军)适合做图像分类.层自左向右.自上向下读取,关联层分为一组,高度.宽度减小,深度增加.深度增加减少网络计算量. 训练模型数据集 ...
- Python教程(2.1)——控制台输入
这一节,我们来学习如何写一个简单的Python程序. 我们知道,很多编程语言一开始就是学习怎么输出"Hello, world",对吧?那么,现在我们来学习怎么用Python输出&q ...
- js添加多个样式属性cssText
document.getElementById("box").style.cssText += ";color:red;font-size:20px"; 代码分 ...