Уважаемое сообщество OP C UA!
Я хочу разработать клиент OP C UA для нашего программного обеспечения, используя примеры из OP C Foundation и MS Azure. Я обеспокоен различием между этими примерами. В первом примере переподключение после сбоя KeepAlive выполняется с помощью ReconnectHandler:
private void Client_KeepAlive(Session sender, KeepAliveEventArgs e)
{
if (e.Status != null && ServiceResult.IsNotGood(e.Status))
{
Console.WriteLine("{0} {1}/{2}", e.Status, sender.OutstandingRequestCount, sender.DefunctRequestCount);
if (reconnectHandler == null)
{
Console.WriteLine("--- RECONNECTING ---");
reconnectHandler = new SessionReconnectHandler();
reconnectHandler.BeginReconnect(sender, ReconnectPeriod * 1000, Client_ReconnectComplete);
}
}
}
private void Client_ReconnectComplete(object sender, EventArgs e)
{
// ignore callbacks from discarded objects.
if (!Object.ReferenceEquals(sender, reconnectHandler))
{
return;
}
session = reconnectHandler.Session;
reconnectHandler.Dispose();
reconnectHandler = null;
Console.WriteLine("--- RECONNECTED ---");
}
Во втором сеанс отключается и создается заново:
private void StandardClient_KeepAlive(Session session, KeepAliveEventArgs e)
{
// ignore if we are shutting down
if (ShutdownTokenSource.IsCancellationRequested == true)
{
return;
}
if (e != null && session != null && session.ConfiguredEndpoint != null && OpcUaClientSession != null)
{
try
{
if (!ServiceResult.IsGood(e.Status))
{
Logger.Warning($"Session endpoint: {session.ConfiguredEndpoint.EndpointUrl} has Status: {e.Status}");
Logger.Information($"Outstanding requests: {session.OutstandingRequestCount}, Defunct requests: {session.DefunctRequestCount}");
Logger.Information($"Good publish requests: {session.GoodPublishRequestCount}, KeepAlive interval: {session.KeepAliveInterval}");
Logger.Information($"SessionId: {session.SessionId}");
if (State == SessionState.Connected)
{
MissedKeepAlives++;
Logger.Information($"Missed KeepAlives: {MissedKeepAlives}");
if (MissedKeepAlives >= OpcKeepAliveDisconnectThreshold)
{
Logger.Warning($"Hit configured missed keep alive threshold of {OpcKeepAliveDisconnectThreshold}. Disconnecting the session to endpoint {session.ConfiguredEndpoint.EndpointUrl}.");
session.KeepAlive -= StandardClient_KeepAlive;
Task t = Task.Run(async () => await DisconnectAsync());
}
}
}
else
{
if (MissedKeepAlives != 0)
{
// reset missed keep alive count
Logger.Information($"Session endpoint: {session.ConfiguredEndpoint.EndpointUrl} got a keep alive after {MissedKeepAlives} {(MissedKeepAlives == 1 ? "was" : "were")} missed.");
MissedKeepAlives = 0;
}
}
}
catch (Exception ex)
{
Logger.Error(ex, $"Error in keep alive handling for endpoint '{session.ConfiguredEndpoint.EndpointUrl}'. (message: '{ex.Message}'");
}
}
else
{
Logger.Warning("Keep alive arguments seems to be wrong.");
}
}
Какой пример верный ? Будет ли сервер отклонять подписку на элементы мониторинга для какой-либо из этих опций? Могу ли я использовать эти примеры для создания надежного клиента или что-то не хватает?
Спасибо за любую помощь!