golang 在 k8s 运算符上出现错误'对象已被修改”
php小编草莓在探索使用golang开发kubernetes运算符时,遇到了一个常见的错误:“对象已被修改”。这个错误通常发生在多个goroutine同时修改同一个对象时,导致数据不一致或竞争条件。在本文中,我们将探讨这个错误的原因和解决方案,帮助开发者更好地理解和处理类似的问题。
问题内容
k8s 操作符上出现“对象已被修改”错误
import "sigs.k8s.io/controller-runtime"
关于这种错误有很多讨论。主要答案是“发生此问题是因为当我尝试更新时我有旧版本的对象。” 但我也有一些问题。在我的操作员中,对于某些场景,我需要在一次“协调”调用期间更新 pod 的注释 2 次。当然,我经常收到“对象已被修改”的错误。
问题:我想知道 'r.Get()' 和 'r.Update()' 在哪里获取/更新对象?来自本地缓存,还是 API 服务器?
1: 我认为 'r.Get()' 是从 'cache' 获取对象,而 'r.Update()' 是更新对象到缓存,对吗?如果是这样,为什么我会收到此错误?如果 pod 对象由于操作员以外的原因而更改,我将无法在当前“协调”期间永远更新我的 pod 对象?(由于缓存对象是本地的,它已经与 API 服务器不同步。)为什么要“重试”有的时候能获取到最新的对象吗?
import "sigs.k8s.io/controller-runtime" var pod corev1.Pod if err := r.Get(ctx, req.NamespacedName, &pod); err != nil { if !apierrors.IsNotFound(err) { log.Error(err, "unable to get pod") return ctrl.Result{}, err } } if err := r.Update(ctx, &pod); err != nil { log.Error(err, "unable to update chaosctl status") return ctrl.Result{}, err }
2:如果'r.Get()'是从API服务器获取对象,并且'r.Update()'也更新API服务器。为什么我需要重试更新对象?
解决方法
当您在 Kubernetes 控制器中使用 r.Get() 和 r.Update() 时,与 API 服务器的交互涉及本地缓存和 API 服务器本身。
r.Get()
:
r.Get() 函数从本地缓存中检索对象(如果存在);否则,它会从 API 服务器获取它。 如果该对象存在于本地缓存中,则立即返回。如果没有,则向API服务器请求获取该对象,并将获取到的对象存储在本地缓存中以供后续使用。 r.Update():
r.Update()
函数会更新本地缓存和 API 服务器中的对象。
如果该对象自最初检索以来已在本地缓存中被修改,则对 API 服务器的更新操作可能会失败并出现“冲突”错误。当缓存中对象的版本与 API 服务器上的版本不匹配时,就会发生这种情况,表明其他人在此期间修改了该对象。
可以采取策略来处理它 -
乐观并发控制(OCC):
- 更新之前的版本匹配。retry
-
retryErr := retry.RetryOnConflict(retry.DefaultRetry, func() error { return r.Update(ctx, pod) }) if retryErr != nil { return retryErr }
以上是golang 在 k8s 运算符上出现错误'对象已被修改”的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

利用Golang开发功能强大的桌面应用随着互联网的不断发展,人们已经离不开各种类型的桌面应用程序。而对于开发人员来说,如何利用高效的编程语言来开发功能强大的桌面应用至关重要。本文将介绍如何利用Golang(Go语言)来开发功能强大的桌面应用,并提供一些具体的代码示例。Golang是一种由Google开发的开源编程语言,它具有简洁、高效、并发性强等特点,非常适

Golang开发中的安全性挑战:如何避免被利用用于病毒制作?随着Golang在编程领域的广泛应用,越来越多的开发者选择使用Golang来开发各种类型的应用程序。然而,与其他编程语言一样,Golang开发中也存在着安全性挑战。特别是,Golang的强大功能和灵活性也使其成为潜在的病毒制作工具。本文将深入探讨Golang开发中的安全性问题,并提供一些方法来避免G

标题:在Mac上使用Golang编程的步骤与技巧在当前软件开发领域,Golang(也被称为Go)作为一种高效、简洁、并发性强的编程语言,受到越来越多开发者的关注和使用。在Mac平台上进行Golang编程,可以借助一些工具和技巧,提高开发效率。本文将介绍在Mac上使用Golang编程的步骤与技巧,并提供具体代码示例,帮助读者更好地理解和应用。步骤1:安装Gol

Golang(简称Go语言)作为一种编程语言在近年来逐渐在区块链领域崭露头角,其高效的并发处理能力和简洁的语法特点使其成为了区块链开发中备受青睐的一种选择。本文将探讨Golang如何助力区块链发展,并通过具体的代码示例展示其在区块链应用中的优越性。一、Golang在区块链领域的优势高效的并发处理能力:区块链系统中的节点需要同时处理大量的事务和数据,而Gola

Golang是一种由Google开发的开源编程语言,被广泛应用于后端服务开发、云计算、网络编程等领域。作为一种静态类型语言,Golang具有高效的并发模型和强大的标准库,因此备受开发者青睐。然而,在实际开发中,Golang开发者通常需要结合其他编程语言来进行项目开发,以满足不同场景的需求。PythonPython是一种面向对象的编程语言,以其简洁明了、易于学

Gokit是一个Golang微服务框架,通过优化、可扩展、可维护和测试友好功能,提升API性能。它提供一系列工具和模式,使用户能够快速构建高性能和可维护的API。实际生产中,它被广泛应用于Netflix、Spotify和Uber等大型平台的API构建,处理着海量的请求。

利用Golang开发手游的优势与劣势随着移动设备的普及和性能的不断提升,手游市场越来越火爆,吸引着越来越多的开发者投身其中。在选择开发语言时,Golang作为一种快速、高效且易于学习的语言,吸引着不少开发者的关注。本文将从利用Golang开发手游的优势与劣势两个方面进行探讨,并通过具体的代码示例来说明。优势:跨平台性强:Golang可以编译为不同平台的二进制

标题:Golang替换空格的实用技术分享随着互联网的普及和发展,程序设计和开发变得愈发重要。在编程过程中,数据处理是一个非常关键的部分。处理文本数据时,常常会遇到需要替换空格的情况,本文将分享如何在Golang中实现替换空格的技术,并提供具体的代码示例。为什么需要替换空格?空格是文本数据中常见的特殊字符之一,有时候我们需要将空格替换成其他字符,或者去除掉空格
