当前位置:首页 > 科技  > 软件

Kubernetes Lease 及分布式选主

来源: 责编: 时间:2024-01-02 09:28:55 241观看
导读分布式选主在分布式系统中,应用服务常常会通过多个节点(或实例)的方式来保证高可用。然而在某些场景下,有些数据或者任务无法被并行操作,此时就需要由一个特定的节点来执行这些特殊的任务(或者进行协调及决策),这个特定的节点

分布式选主

在分布式系统中,应用服务常常会通过多个节点(或实例)的方式来保证高可用。然而在某些场景下,有些数据或者任务无法被并行操作,此时就需要由一个特定的节点来执行这些特殊的任务(或者进行协调及决策),这个特定的节点也就是领导者(Leader),而在多个节点中选择领导者的机制也就是分布式选主(Leader Election)。bik28资讯网——每日最新资讯28at.com

bik28资讯网——每日最新资讯28at.com

如今诸多知名项目也都使用了分布式选主,例如:bik28资讯网——每日最新资讯28at.com

  • Etcd
  • Kafka
  • Elasticsearch
  • Zookeeper

常用算法包括:bik28资讯网——每日最新资讯28at.com

  • Paxos:一种著名的分布式共识算法,原理和实现较为复杂(此算法基本就是共识理论的奠基之作,曾有人说:"世界上只有一种共识协议,就是 Paxos,其他所有共识算法都是 Paxos 的退化版本")。
  • Raft:目前最广泛使用的分布式共识算法之一,Etcd 使用的就是 Raft,Elasticsearch 和 Kafka 在后来的版本中也都抛弃了早期的算法并转向了 Raft。
  • ZAB(Zookeeper Atomic Broadcast):Zookeeper 使用的一致性协议,也包括选主机制。

Kubernetes Lease

在 Kubernetes 中,诸如 kube-scheduler 和 kube-controller-manager 等核心组件也需要使用分布式选主,因为其需要确保任一时刻只有一个调度器在做出调度决策,同一时间只有一个控制管理器在处理资源对象。bik28资讯网——每日最新资讯28at.com

然而,除了核心组件,用户的应用服务很可能也有类似分布式选主的需求,为了满足这种通用需求,kubernetes 提供了 Lease(翻译为“租约”)这样一个特殊的资源对象。bik28资讯网——每日最新资讯28at.com

bik28资讯网——每日最新资讯28at.com

如上图所示,在 k8s 中选主是通过争抢一个分布式锁(Lease)来实现的,抢到锁的实例成为 leader,为了确认自己持续存活,leader 需要不断的续签这个锁(Lease),一旦 leader 挂掉,则锁被释放,其他候选人便可以竞争成为新的 leader。bik28资讯网——每日最新资讯28at.com

Lease 的结构也很简单:bik28资讯网——每日最新资讯28at.com

apiVersion: coordination.k8s.io/v1kind: Leasemetadata:  # objectspec:  acquireTime: # 当前租约被获取的时间  holderIdentity: # 当前租约持有者的身份信息  leaseDurationSeconds: # 租约候选者需要等待才能强制获取它的持续时间  leaseTransitions: # 租约换了多少次持有者  renewTime: # 当前租约持有者最后一次更新租约的时间

Lease 本质上与其它资源并无区别,除了 Lease,其实也可以用 configmap 或者 endpoint 作为分布式锁,因为在底层都是 k8s 通过资源对象的 resourceVersion 字段进行 compare-and-swap,也就是通过这个字段实现的乐观锁。当然在实际使用中,建议还是用 Lease。bik28资讯网——每日最新资讯28at.com

使用示例

使用 Lease 进行分布式选主的示例如下:bik28资讯网——每日最新资讯28at.com

import (    "context"    "time"    "k8s.io/client-go/kubernetes"    "k8s.io/client-go/rest"    "k8s.io/client-go/tools/leaderelection"    "k8s.io/client-go/tools/leaderelection/resourcelock")func main() {    config, err := rest.InClusterConfig()    if err != nil {        panic(err.Error())    }    clientset, err := kubernetes.NewForConfig(config)    if err != nil {        panic(err.Error())    }    // 配置 Lease 参数    leaseLock := &resourcelock.LeaseLock{        LeaseMeta: metav1.ObjectMeta{            Name:      "my-lease",            Namespace: "default",        },        Client: clientset.CoordinationV1(),        LockConfig: resourcelock.ResourceLockConfig{            Identity: "my-identity",        },    }    // 配置 Leader Election    leaderElectionConfig := leaderelection.LeaderElectionConfig{        Lock:          leaseLock,        LeaseDuration: 15 * time.Second,        RenewDeadline: 10 * time.Second,        RetryPeriod:   2 * time.Second,        Callbacks: leaderelection.LeaderCallbacks{            OnStartedLeading: func(ctx context.Context) {                // 当前实例成为 Leader                // 在这里执行 Leader 专属的逻辑            },            OnStoppedLeading: func() {                // 当前实例失去 Leader 地位                // 可以在这里执行清理工作            },            OnNewLeader: func(identity string) {                // 有新的 Leader 产生            }        },    }    leaderElector, err := leaderelection.NewLeaderElector(leaderElectionConfig)    if err != nil {        panic(err.Error())    }    // 开始 Leader Election    ctx := context.Background()    leaderElector.Run(ctx)}

参考资料:bik28资讯网——每日最新资讯28at.com

  • https://kubernetes.io/docs/concepts/architecture/leases/
  • https://kubernetes.io/docs/reference/kubernetes-api/cluster-resources/lease-v1/
  • https://pkg.go.dev/k8s.io/client-go@v0.29.0/tools/leaderelection

bik28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-55040-0.htmlKubernetes Lease 及分布式选主

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 五个用于构建Web应用程序的Go Web框架

下一篇: 我们一起聊聊如何使用Docker来编排Web应用

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 小米官宣:2023年上半年出货量中国第一!

    今日早间,小米电视官方微博带来消息,称2023年小米电视上半年出货量达到了中国第一,同时还表示小米电视的巨屏风暴即将开始。“公布一个好消息2023年#小米电视上半年出货量中国
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • 微信语音大揭秘:为什么禁止转发?

    大家好,我是你们的小米。今天,我要和大家聊一个有趣的话题:为什么微信语音不可以转发?这是一个我们经常在日常使用中遇到的问题,也是一个让很多人好奇的问题。让我们一起来揭开这
  • 一文掌握 Golang 模糊测试(Fuzz Testing)

    模糊测试(Fuzz Testing)模糊测试(Fuzz Testing)是通过向目标系统提供非预期的输入并监视异常结果来发现软件漏洞的方法。可以用来发现应用程序、操作系统和网络协议等中的漏洞或
  • 小红书1周涨粉49W+,我总结了小白可以用的N条涨粉笔记

    作者:黄河懂运营一条性教育视频,被54万人“珍藏”是什么体验?最近,情感博主@公主是用鲜花做的,火了!仅仅凭借一条视频,光小红书就有超过128万人,为她疯狂点赞!更疯狂的是,这
  • 10天营收超1亿美元,《星铁》比《原神》差在哪?

    来源:伯虎财经作者:陈平安即便你没玩过《原神》,你一定听说过的它的大名。恨它的人把《原神》开服那天称作是中国游戏史上最黑暗的一天,有粉丝因为索尼在PS平台上线《原神》,怒而
  • AI芯片初创公司Tenstorrent获三星和现代1亿美元投资

    Tenstorrent是一家由芯片行业资深人士Jim Keller领导的加拿大初创公司,专注于开发人工智能芯片,该公司周三表示,已经从现代汽车集团和三星投资基金等
  • iQOO 11S或7月上市:搭载“鸡血版”骁龙8Gen2 史上最强5G Soc

    去年底,iQOO推出了“电竞旗舰”iQOO 11系列,作为一款性能强机,iQOO 11不仅全球首发2K 144Hz E6全感屏,搭载了第二代骁龙8平台及144Hz电竞屏,同时在快充
Top