目录
问题内容
解决方法
tl;博士
问题描述
首页 后端开发 Golang 收到另一个请求后提供 HTTP 请求的响应

收到另一个请求后提供 HTTP 请求的响应

Feb 09, 2024 pm 01:06 PM
数据丢失

收到另一个请求后提供 HTTP 请求的响应

php小编草莓在开发Web应用程序时,我们经常需要处理HTTP请求并提供相应的响应。当我们收到一个请求时,我们需要根据请求的内容和目的,生成适当的响应。这可能涉及到查询数据库、处理表单数据、调用其他API等各种操作。在本文中,我们将探讨如何在PHP中处理HTTP请求并提供相应的响应,以便为用户提供更好的交互和用户体验。无论是构建一个简单的静态网页还是一个复杂的Web应用程序,了解如何处理HTTP请求和生成响应都是非常重要的。

问题内容

我的用例是在从单独的服务器接收到另一个请求后提供 HTTP 请求的响应。

  1. 我希望以尽可能最好的方式做到这一点,同时牢记扩展性。
  2. 我们使用 Golang 1.19 和 Gin 框架。
  3. 服务器将有多个 Pod,因此通道将无法工作。
  4. 所有请求都会超时,初始请求将在 60 秒后超时。

我当前的解决方案是使用共享缓存,其中每个 Pod 都会不断检查缓存。我相信,我可以通过通道来优化这一点,系统定期检查任何已完成的响应,而不是逐一检查缓存。

我还想知道如何用其他编程语言实现它。

PS:这是基于设计的查询,我在这里有一些分享赏金的声誉,因此在这里询问。如果问题不清楚,请随时编辑。

解决方法

tl;博士

问题描述

因此,假设您的服务器应用程序名为 server_app,例如有 3 个 pod:

+---------------------+
     |  server_app_service |
     +---------------------+
     |  server_app_pod_a   |
     |  server_app_pod_b   |
     |  server_app_pod_c   |
     +---------------------+
登录后复制

您的服务收到一个名为 "request a" 的请求,并决定将其传递给 server_app_pod_a。现在,您的 server_app_pod_a 将请求转发到某个网关,并等待某种"request a" 的请求,并决定将其传递给 server_app_pod_a。现在,您的 server_app_pod_a 将请求转发到某个网关,并等待某种通知,以继续处理客户端的响应。正如您所知,无法保证当网关执行 request b 时,服务会再次将其传递给 server_app_pod_a通知

,以继续处理客户端的响应。正如您所知,无法保证当网关执行 request b 时,服务会再次将其传递给 server_app_pod_a。即使这样做,应用程序的状态管理也将成为一项艰巨的任务。

消息传递

request“b”正如您可能已经注意到的,我在上一段中将“通知”一词加粗,这是因为如果您认真考虑一下,看起来更像是带有一些消息的通知

而不是对某些资源的请求。所以我的第一选择是像 kafka 这样的消息队列(正如你所知,有很多这样的消息队列)。这个想法是,如果您可以定义一种算法来计算请求的唯一键,那么您就可以在完全相同的 pod 中收到结果通知。这样,状态管理会更简单,而且在同一个 pod 中获得通知的机会也会更高(当然这取决于很多因素,比如消息队列的状态)。看看您的问题:
  1. 我希望以尽可能最好的方式做到这一点,同时牢记扩展性。

当然,您可以像 kafka 一样使用这些消息队列,以实现消息队列和应用程序的扩展并减少数据丢失。
  1. 所有请求都会超时,初始请求将在 60 秒后超时。

这取决于您如何管理代码库中的超时,使用上下文是一个好主意。

我还想知道如何用其他编程语言实现它。

scala 中,如果您使用一些名为 akka 的特定工具(它提供了 actor 模型编程范例),您可以使用所谓的 akka-cluster-sharding使用消息队列是一个通用的想法,它适用于几乎任何编程语言,但根据语言的编程范例以及特定于语言的库和工具,可能还有其他一些方法来解决此问题。例如在

来处理这个问题。这个想法非常简单,我们知道必须有某种监督者,它知道自己的订阅者的确切位置和状态。因此,当它收到一些消息时,它只知道将请求转发到何处以及哪个参与者(我们正在讨论参与者模型编程)。换句话说,它可用于在集群上生成的参与者之间共享状态,无论是否在同一台机器上。但作为个人偏好,我不会选择特定语言的交流,而是会坚持一般的想法,因为这可能会在未来引起问题。

总结

足够长的解释:)。为了理解我所说的内容,让我们跟踪完全相同的场景,但通信模型有所不同:🎜
  1. 客户端向 server_app 服务发送请求“a”。
  2. 服务选择其中一个 pod(例如 server_app_pod_b)来处理请求。
  3. 然后,pod 尝试为请求定义一些密钥,并将其与请求一起传递到网关,并等待带有该密钥的消息在队列中发布。
  4. 网关执行其应有的操作,并使用密钥发送消息到消息队列。
  5. 完全相同的 pod serer_app_pod_b 接收带有密钥的消息,获取消息的数据,并继续处理客户端的请求。

可能还有其他方法可以解决这个问题,但这就是我想要的。希望对您有帮助!

以上是收到另一个请求后提供 HTTP 请求的响应的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

gateio交易所app老版本 gateio交易所app老版本下载渠道 gateio交易所app老版本 gateio交易所app老版本下载渠道 Mar 04, 2025 pm 11:36 PM

Gateio 交易所 app 老版本下载渠道,涵盖官方、第三方应用市场、论坛社区等途径,还给出下载注意事项,帮你轻松获取老版本,解决新版本使用不适或设备兼容问题。

char在C语言中如何进行类型转换 char在C语言中如何进行类型转换 Apr 03, 2025 pm 03:21 PM

在 C 语言中,char 类型转换可以通过:强制类型转换:使用强制类型转换符将一种类型的数据直接转换为另一种类型。自动类型转换:当一种类型的数据可以容纳另一种类型的值时,编译器自动进行转换。

MongoDB在Debian上的高可用性如何保障 MongoDB在Debian上的高可用性如何保障 Apr 02, 2025 am 07:21 AM

本文介绍如何在Debian系统上构建高可用性的MongoDB数据库。我们将探讨多种方法,确保数据安全和服务持续运行。关键策略:副本集(ReplicaSet):利用副本集实现数据冗余和自动故障转移。当主节点出现故障时,副本集会自动选举新的主节点,保证服务的持续可用性。数据备份与恢复:定期使用mongodump命令进行数据库备份,并制定有效的恢复策略,以应对数据丢失风险。监控与报警:部署监控工具(如Prometheus、Grafana)实时监控MongoDB的运行状态,并

xml格式化工具推荐 xml格式化工具推荐 Apr 02, 2025 pm 09:03 PM

XML格式化工具可以将代码按照规则排版,提高可读性和理解性。选择工具时,要注意自定义能力、对特殊情况的处理、性能和易用性。常用的工具类型包括在线工具、IDE插件和命令行工具。

Laravel多租户扩展stancl/tenancy:如何自定义租户数据库连接的主机地址? Laravel多租户扩展stancl/tenancy:如何自定义租户数据库连接的主机地址? Apr 01, 2025 am 09:09 AM

在Laravel多租户扩展包stancl/tenancy中自定义租户数据库连接使用Laravel多租户扩展包stancl/tenancy构建多租户应用时,...

多进程日志写入如何保证并发安全又高效? 多进程日志写入如何保证并发安全又高效? Apr 02, 2025 pm 03:51 PM

高效处理多进程日志写入的并发安全问题多进程同时写入同一个日志文件,如何保证并发安全且高效?这是一个...

Redis队列与MySQL稳定性对比:为什么Redis容易丢数据? Redis队列与MySQL稳定性对比:为什么Redis容易丢数据? Apr 01, 2025 pm 02:24 PM

Redis队列与MySQL稳定性对比:为什么Redis容易丢数据?在开发环境中,使用PHP7.2和ThinkPHP框架,我们常面临选择合�...

See all articles