我需要通过 STOMP 实现 RPC,其中客户端在浏览器中使用 javascript 运行,而服务器端使用 Spring 消息传递功能实现。
虽然使用@MessageMapping 对于正常的消息传递来说很好,但我发现使用@SendToUser 对实现RPC 有很大的限制,因为在从客户端发出多个同时请求的场景中,客户端很难理解哪个回复与哪个请求相关联。
当然,只发出一个请求,并且客户端等待其回复时没有问题,但是当客户端必须跟踪多个“打开”的 rpc 调用时,就会出现问题。
通过将 ID 与每个请求相关联,我已经设法使系统基本正常,即:客户端将一个 ID 与消息一起发送,服务器使用包含此 ID 的特殊消息包装器进行回复,因此客户端能够将异步回复与请求相关联。
这工作正常,但有几个限制:
我必须开发需要理解这种结构的代码,并且无法使用简单的带注释的方法
当服务器端代码生成异常时,会调用 Spring @MessageExceptionHandler 并将正确的异常返回给客户端,但请求 ID 会丢失,因为处理程序没有(简单的)方法可以访问它。
我知道,使用rabbitmq,我们可以将“reply-to”标头添加到需要与特殊回复(rpc 响应)关联的每个请求中,这是通过创建用户自动订阅的特殊临时队列来实现的,但是我如何在 Spring 中使用这个方案呢?此外,这将使我与一个特定的经纪人联系在一起。
如何在 Spring 中优雅地实现正确处理服务器端异常的正确 RPC 调用?
我发现这是一个普遍的问题,我认为 Spring 可以极大地受益于本机实现它。