gpt4 book ai didi

java - java应用程序和jax-ws Web服务之间的线程间通信

转载 作者:太空宇宙 更新时间:2023-11-04 08:09:26 25 4
gpt4 key购买 nike

我的 jax-ws Web 服务(在收到客户端请求后)向后端遗留平台发送请求(通过套接字),然后等待 20 秒响应。

在发出该请求之前,它会使用其唯一的交易编号更新表。

一个单独的监听器线程(独立的 Java 应用程序)正在该套接字上等待响应,每个响应中都将包含事务号,以识别与哪个请求(之前发送的)相关联。

这个独立的 Java 应用程序如何与 Web 服务中等待的线程进行通信,告知其响应已到达并且可以继续处理。

目前我认为监听器线程可以更新表(基于事务号)以指示响应已到达。 Web 服务线程可以不断轮询(每 2 秒检查一次)数据库是否有响应到达。

在这种情况下我正在寻找一些推送通知而不是轮询。当我的 Web 服务线程的响应到达时,如何才能收到通知。

最佳答案

假设服务请求并发出套接字请求的线程和接收套接字响应的线程都在同一个 jvm 中:
您可以使用标准的 Java 等待/通知模式。
http://docs.oracle.com/javase/tutorial/essential/concurrency/guardmeth.html

基本上,您的请求/套接字线程将在单例(或类似)映射中创建一个对象(“锁定”对象),关键是您的唯一交易号。然后该线程将等待该对象。这会阻塞该线程,直到另一个线程对该事务 ID 的锁对象进行通知。
请注意,锁定对象可以只是一个对象。
您还可以设置等待超时以避免永远等待。

然后,您的另一个线程将获取事务 ID 的锁对象并对其进行通知。然后,这将解除对第一个线程的阻塞。
如果第二个线程没有找到其事务 ID 的锁对象,则说明出现了问题,您必须记录错误或类似错误。

Ps 由于 map 是共享资源,因此您可能需要 ConcurrentHashMap。否则,您可能会遇到多个线程同时更新的问题。

关于java - java应用程序和jax-ws Web服务之间的线程间通信,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11478524/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com