将主协程上下文的副本传递给子例程上下文
在PHP中,协程是一种强大的编程工具,可以提高代码的执行效率。而在协程中,将主协程上下文的副本传递给子例程上下文是一种常用的操作。通过这种方式,可以在子例程中访问主协程的上下文数据,实现数据的共享和传递。这一过程在PHP中非常简单,只需要使用yield关键字即可实现。在本文中,我们将由php小编小新为您详细介绍如何将主协程上下文的副本传递给子例程上下文,并给出一些实例代码,帮助您更好地理解和应用这一特性。
问题内容
我有一个 golang API 端点及其关联的上下文。
端点需要在幕后执行一些繁重的工作,因此我在主端点内创建一个新的子例程,然后返回响应本身。
为了处理上下文取消,我创建了一个后台上下文并将其作为新上下文传递给子例程。
问题是通过这样做,是的,我可以执行后台子例程,但是主上下文中的值,例如请求ID,跨度ID等(大多数键我都不知道),这些值被用于追踪将会丢失。
即使在响应发送到客户端后,如何将父上下文传递给子例程而不取消执行。
编辑
我没有将任何值传递到上下文中。 但最初我们传递的是跟踪所需的 request-id、span-id 等。 这些信息都在上下文中。 这是一个内部库,上下文是我们保存它的地方。
我知道这是使用上下文传递值的反模式,除了请求 ID 和其他对库而不是业务逻辑重要的值之外,不会传递任何值
解决方法
当您取消父上下文时,从其派生的所有上下文也将取消。因此,您为请求处理程序生成的 goroutine 创建新上下文是正确的。
当您创建新上下文时,您应该将您感兴趣的所有值从原始上下文复制到新上下文。然而,你说你不知道所有的钥匙。因此,您仍然可以保留对父上下文的引用,以便可以查询它的值。像这样的事情:
type nestedContext struct { context.Context parent context.Context } func (n nestedContext) Value(key any) any { return n.parent.Value(key) } ... newContext := nestedContext{ Context:context.Background(), parent: parentContext, }
这将从 context.background()
创建一个新上下文,该上下文将从取消的父上下文中查找值。
将 newcontext
作为上下文传递给从处理程序创建的 goroutine。
以上是将主协程上下文的副本传递给子例程上下文的详细内容。更多信息请关注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)

热门话题

OpenSSL,作为广泛应用于安全通信的开源库,提供了加密算法、密钥和证书管理等功能。然而,其历史版本中存在一些已知安全漏洞,其中一些危害极大。本文将重点介绍Debian系统中OpenSSL的常见漏洞及应对措施。DebianOpenSSL已知漏洞:OpenSSL曾出现过多个严重漏洞,例如:心脏出血漏洞(CVE-2014-0160):该漏洞影响OpenSSL1.0.1至1.0.1f以及1.0.2至1.0.2beta版本。攻击者可利用此漏洞未经授权读取服务器上的敏感信息,包括加密密钥等。

Go爬虫Colly中的Queue线程问题探讨在使用Go语言的Colly爬虫库时,开发者常常会遇到关于线程和请求队列的问题。�...

Go语言中用于浮点数运算的库介绍在Go语言(也称为Golang)中,进行浮点数的加减乘除运算时,如何确保精度是�...

后端学习路径:从前端转型到后端的探索之旅作为一名从前端开发转型的后端初学者,你已经有了nodejs的基础,...

本文讨论了通过go.mod,涵盖规范,更新和冲突解决方案管理GO模块依赖关系。它强调了最佳实践,例如语义版本控制和定期更新。

本文介绍在Debian系统下监控PostgreSQL数据库的多种方法和工具,助您全面掌握数据库性能监控。一、利用PostgreSQL内置监控视图PostgreSQL自身提供多个视图用于监控数据库活动:pg_stat_activity:实时展现数据库活动,包括连接、查询和事务等信息。pg_stat_replication:监控复制状态,尤其适用于流复制集群。pg_stat_database:提供数据库统计信息,例如数据库大小、事务提交/回滚次数等关键指标。二、借助日志分析工具pgBadg
