我正在使用Eclipse Milo编写OPC UA客户端,遇到了以下问题:客户端如何处理失去连接的情况。
为了监视数据值,我使用SubscriptionManager创建订阅。
为了监视数据值,我使用SubscriptionManager创建订阅。
OpcUaClient client = myCreateClient();
List<MonitoredItemCreateRequest> items = myCreateMonitoredItems();
UaSubscription subscription = client.getSubscriptionManager().createSubscription(1_000.0).get();
List<UaMonitoredItem> result = subscription.createMonitoredItems(TimestampsToReturn.Both, items).get();
for (UaMonitoredItem item : result) {
if (!item.getStatusCode().isBad()) {
item.setValueConsumer(value -> System.out.println("Update: " + value));
}
}
现在当我重启我的OPC UA服务器时,它也是使用Eclipse Milo实现的,然后我确实看到客户端重新连接,但订阅不再收到更新。在日志中,我得到以下输出:
09:11:15.734 [ua-shared-pool-0] DEBUG o.e.m.o.s.c.s.OpcUaSubscriptionManager - Publish service failure: StatusCode{name=Bad_NoSubscription, value=0x80790000, quality=bad}
java.util.concurrent.CompletionException: UaServiceFaultException: status=Bad_NoSubscription, message=There is no subscription available for this session.
<stack-trace-omitted>
…
看起来OpcUaSubscriptionManager已经意识到了这种情况,但并不会尝试重新注册那些项目。需要手动完成吗?