搜索
首页后端开发Golanggolang 在 k8s 运算符上出现错误'对象已被修改”

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 服务器上的版本不匹配时,就会发生这种情况,表明其他人在此期间修改了该对象。

可以采取策略来处理它 -

  1. 乐观并发控制(OCC): - 更新之前的版本匹配。
  2. retry -
retryErr := retry.RetryOnConflict(retry.DefaultRetry, func() error {
        return r.Update(ctx, pod)
    })
    if retryErr != nil {
        return retryErr
    }

以上是golang 在 k8s 运算符上出现错误'对象已被修改”的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:stackoverflow。如有侵权,请联系admin@php.cn删除
GO的选择语句:多路复用并发操作GO的选择语句:多路复用并发操作Apr 24, 2025 pm 05:21 PM

go'SselectStatementTreamLinesConcurrentProgrambyMultiplexingOperations.1)itallowSwaitingOnMultipleChannEloperations,执行thefirstreadyone.2)theDefirstreadyone.2)thedefefcasepreventlocksbysbysbysbysbysbythoplocktrograpraproxrograpraprocrecrecectefnoopeready.3)

GO中的高级并发技术:上下文和候补组GO中的高级并发技术:上下文和候补组Apr 24, 2025 pm 05:09 PM

contextancandwaitgroupsarecrucialingoformanaginggoroutineseflect.1)context contextsallowsAllowsAllowsAllowsAllowsAllingCancellationAndDeadLinesAcrossapibiboundaries,确保GoroutinesCanbestoppedGrace.2)WaitGroupsSynChronizeGoroutines,确保Allimizegoroutines,确保AllizeNizeGoROutines,确保AllimizeGoroutines

使用微服务体系结构的好处使用微服务体系结构的好处Apr 24, 2025 pm 04:29 PM

goisbeneformervicesduetoitssimplicity,效率,androbustConcurrencySupport.1)go'sdesignemphasemphasizessimplicity and效率,Idealformicroservices.2))其ConcconcurnCurnInesSandChannelsOdinesSallessallessallessAlloSalosalOsalOsalOsalOndlingConconcConccompi.3)

Golang vs. Python:利弊Golang vs. Python:利弊Apr 21, 2025 am 12:17 AM

Golangisidealforbuildingscalablesystemsduetoitsefficiencyandconcurrency,whilePythonexcelsinquickscriptinganddataanalysisduetoitssimplicityandvastecosystem.Golang'sdesignencouragesclean,readablecodeanditsgoroutinesenableefficientconcurrentoperations,t

Golang和C:并发与原始速度Golang和C:并发与原始速度Apr 21, 2025 am 12:16 AM

Golang在并发性上优于C ,而C 在原始速度上优于Golang。1)Golang通过goroutine和channel实现高效并发,适合处理大量并发任务。2)C 通过编译器优化和标准库,提供接近硬件的高性能,适合需要极致优化的应用。

为什么要使用Golang?解释的好处和优势为什么要使用Golang?解释的好处和优势Apr 21, 2025 am 12:15 AM

选择Golang的原因包括:1)高并发性能,2)静态类型系统,3)垃圾回收机制,4)丰富的标准库和生态系统,这些特性使其成为开发高效、可靠软件的理想选择。

Golang vs.C:性能和速度比较Golang vs.C:性能和速度比较Apr 21, 2025 am 12:13 AM

Golang适合快速开发和并发场景,C 适用于需要极致性能和低级控制的场景。1)Golang通过垃圾回收和并发机制提升性能,适合高并发Web服务开发。2)C 通过手动内存管理和编译器优化达到极致性能,适用于嵌入式系统开发。

golang比C快吗?探索极限golang比C快吗?探索极限Apr 20, 2025 am 12:19 AM

Golang在编译时间和并发处理上表现更好,而C 在运行速度和内存管理上更具优势。1.Golang编译速度快,适合快速开发。2.C 运行速度快,适合性能关键应用。3.Golang并发处理简单高效,适用于并发编程。4.C 手动内存管理提供更高性能,但增加开发复杂度。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。