首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏TA码字

    K8s源码分析(10)-资源的schema

    versionPriority map[string][]string observedVersions []schema.GroupVersion schemeName string } 从上面的图解以及源码来看 从上面的图解以及源码来看 schema 实现接口主要有以下关键点: 实现 runtime.ObjectCreater 接口定义的方法完成资源的创建。

    1.7K20发布于 2021-11-18
  • 来自专栏k8s源码解析

    k8s源码-源码编译及目录详解

    源码下载及编译(本文以1.16.0-alpha.3为例) k8s github地址: https://github.com/kubernetes/kubernetes k8s的编译有两种方式: 1: /build/run.sh hack/build-go.sh cmd/kubelet单独编译某个组件 目录概览 k8s源码采用 go module(go 1.11rc1开始支持)管理包,go module

    8K53发布于 2019-11-17
  • 来自专栏luozhiyun的技术学习

    10.深入k8s:调度的优先级及抢占机制源码分析

    转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com 源码版本是1.19 ? 上一篇我们将了获取node成功的情况,如果是一个优先pod获取node失败,那么就会进入到抢占环节中,那么抢占环节k8s会做什么呢,抢占是如何发生的,哪些资源会被抢占这些都是我们这篇要研究的内容。 源码解析 这里我依旧拿出这张图来进行讲解,上一篇我们将了获取node成功的情况,如果是一个优先pod获取node失败,那么就会进入到抢占环节中。 ? pod.Name, err) } return nil, nil } if klog.V(5).Enabled() { var sample []string for i := 0; i < 10 到这里整个抢占过程就讲解完毕了~ 总结 看完这一篇我们对k8s的抢占可以说有一个全局的了解,心里应该非常清楚k8s在抢占的时候会发生什么,例如什么时候时候哪些pod会执行抢占,以及为什么执行抢占,以及抢占了哪些

    2K51发布于 2020-09-16
  • 来自专栏全栈程序员必看

    k8s 开源_openstack源码

    Create->CreateWithOptions->createResource

    33510编辑于 2022-09-22
  • 来自专栏Java架构师必看

    spring源码分析10

    spring源码分析10 强烈推介IDEA2020.2破解激活,IntelliJ

    34730发布于 2021-04-13
  • 来自专栏才浅coding攻略

    图解K8s源码 - 序章 - K8s组件架构

    概念上来讲,K8S 集群的服务,其实就是负载均衡或反向代理。

    1.1K10编辑于 2022-12-12
  • 来自专栏CSDN搜“看,未来”

    再战 k8s10):job

    K8S支持以下几种方式: 非并行Job: 通常只运行一个Pod,Pod成功结束Job就退出。

    68830编辑于 2022-05-06
  • 来自专栏云原生工具箱

    图解 K8S 源码 - QoS 篇

    这里就引出了 QoS 的概念,本篇文章就会从源码的角度介绍 QoS 的分类、打分机制,并简单介绍不同 QoS 的本质区别。看看这个机制是如何保证运行在 Kubernetes 中服务质量的。 这里附上源码: // github/kubernetes/pkg/kubelet/qos/policy.goconst ( // KubeletOOMScoreAdj is the OOM score

    1.2K10发布于 2020-12-30
  • 来自专栏波波烤鸭

    10】Spring源码-分析篇-AOP源码分析

    Spring源码-AOP分析 一、手写AOP回顾   本文我们开始讲解Spring中的AOP原理和源码,我们前面手写了AOP的实现,了解和自己实现AOP应该要具备的内容,我们先回顾下,这对我们理解Spring

    1.1K50编辑于 2022-10-28
  • 来自专栏才浅coding攻略

    图解K8s源码 - kubelet 篇

    我们在之前的文章中介绍了 Master 控制平面中的三大组件:kube-apiserver、kube-controller-manager、kube-scheduler,它们分别负责 k8s 集群的资源访问入口 protobuf:"bytes,9,opt,name=type"` EventTime metav1.MicroTime `json:"eventTime,omitempty" protobuf:"bytes,10 另外,k8s 中 events 目前只有两种类型:"Normal" 和 "Warning"。 系列往期文章列表: Kubernetes微服务常见概念及应用 图解K8s源码 - 序章 - K8s组件架构 图解K8s源码 - k8s核心数据结构 图解K8s源码 - kube-apiserver篇 图解K8s源码 - kube-apiserver下的RBAC鉴权机制 图解K8s源码 - kube-controller-manager篇 图解K8s源码 - kube-scheduler篇

    1.5K20编辑于 2022-12-12
  • 来自专栏kinnylee钻研技术

    k8s源码分析- Informer机制

    最近加入云原生社区组织的k8s源码研习社,开始学习k8s底层源码,并整理成笔记。欢迎感兴趣的同学一起加入,共同学习进步。群里和社区里有各种大佬,随时可以帮你答疑解惑。 先放一张调用关系图 高清地址 由于Informer这部分的源码比较复杂,调用链路也很长,后面的源码分析,都会围绕这一张图展开。 ? 概述 k8s中,组件之间通过http通讯,在不依赖任何中间件的情况下,需要保证消息的可靠性、实时性、顺序性等?k8s是如何做到的呢?--- 答案就是Informer。 k8s的其他组件都是通过informer与api-server通讯的。 Informer运行原理 ? 中占据重要的角色,它的源码也是非常的复杂。

    5.9K118发布于 2020-10-15
  • 来自专栏golang算法架构leetcode技术php

    golang源码分析(10)slice

    // maxSliceCap returns the maximum capacity for a slice.

    30820编辑于 2022-08-02
  • 来自专栏golang算法架构leetcode技术php

    golang源码分析:etcd(10)

    tp.Run() for { in, err := tp.Listener.Accept() go tp.serve(in) proxy的实现是一个标准的tcp代理,源码位于

    41520编辑于 2023-09-09
  • golang源码分析:langchaingo(10

    除了RAG,我们也可以定义agentTool交给大模型调用,下面我们看一个调用的例子

    10110编辑于 2026-03-18
  • 来自专栏Postgresql源码分析

    Postgresql源码10)Xlog组装

    (继续Postgresql技术内幕学习) 前面几节已经把XLOG所需的数据注册到内存中了,下面开始组装XLOG。 XLogRecordAssemble完成日志组装,处理页面数据Block部分,把registered_buffers中的数据进行二次加工。 /* * Assemble a WAL record from the registered data and buffers into an * XLogRecData chain, ready for insertion with XLogInser

    64020编辑于 2022-07-16
  • golang源码分析 :gopls(10

    它们的作用是将编辑器对源码的操作接口进行标准化,它的核心接口如下:‌ ‌文本同步‌ textDocument/didOpen、textDocument/didChange、textDocument/didClose

    9410编辑于 2026-03-18
  • 来自专栏才浅coding攻略

    图解K8s源码 - k8s核心数据结构

    阿巩 期待同大家一起学习和交流~ 在上一章中阿巩和大家分享了k8s组件之一kube-apiserver,在我自己阅读代码时发现k8s整体结构复杂,而且由于参与的开发者众多代码结构不免有些混乱,我往往容易陷入到某个细节而无法从整体视角梳理流程 在查阅官网文档及相关书籍后,我决定换个思路,先理解k8s核心数据结构设计,这样能够在阅读源码时做到事半功倍。好的,日拱一卒,我们开始吧! K8s系统虽然功能众多且复杂,但它本质上是一个资源控制系统,即资源是k8s最重要的概念,它包括注册、管理、调度资源并维护资源状态。 name=categories"` StorageVersionHash string `json:"storageVersionHash,omitempty" protobuf:"bytes,10 文章最后附上k8s Project Layout结构图: 参考: 《kubernetes源码剖析》 https://blog.51cto.com/daixuan/4976182 END

    1.3K20编辑于 2022-12-12
  • 来自专栏TA码字

    K8s源码分析(2)-Resource Meta

    "` APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,2,opt,name=apiVersion"` } 由上述源码我们发现字段 DeletionGracePeriodSeconds *int64 `json:"deletionGracePeriodSeconds,omitempty" protobuf:"varint,10 ManagedFieldsEntry `json:"managedFields,omitempty" protobuf:"bytes,17,rep,name=managedFields"` } 由上述源码我们发现里面定义的都是资源本身的各个属性

    66010发布于 2021-09-14
  • 来自专栏TA码字

    K8s源码分析(3)-Resource Version

    接下来我们来看一下不同 version 的 resource 都定义在什么地方: 对于各个资源组外部版本的定义在如下源码位置: 我们以 apps group 资源组为例,对于其外部版本的 resource 定义如下: 对于各个资源组 internal version 的定义在如下源码位置: 同样我们还是以 apps 资源组为例,其 internal version 的 resource 定义如下 : 从源码的角度来看,我们以 apps group 中的 v1 version 的 deployment resource 为例,它在 staging/src/k8s.io/api/apps/v1/ metav1.ObjectMeta Spec DeploymentSpec Status DeploymentStatus } 从上面例子中 deployment 资源的外部版本和内部版本的定义源码

    1.2K10发布于 2021-09-14
  • 来自专栏TA码字

    K8s源码分析(4)-Resource Model

    另外也从源码的角度分析了其中各个资源 group 的对外 version 和 internal version 都定义在哪些源文件之中,在这里我们主要介绍 kubernetes 中各种 resource 从源码的角度来看 kubernetes resource 的 group version kind (即 GVK) 的属性被定义在 staging/src/k8s.io/apimachinery/pkg 由上述源码分析可以总结: TypeMeta 和 ObjectMeta 两种结构体分别定义了 kubernetes 各种资源的类型属性和实例属性。

    70840发布于 2021-10-08
领券