RobotBackgroundService.cs
1.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
namespace AutomaticGrooveCalculationTool.Services
{
public class RobotBackgroundService : BackgroundService
{
private readonly ILogger<RobotBackgroundService> _logger;
private readonly SiemensPLCService _siemensPLC;
public RobotBackgroundService(ILogger<RobotBackgroundService> logger, SiemensPLCService siemensPLC)
{
_logger = logger;
_siemensPLC = siemensPLC;
}
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
while (!stoppingToken.IsCancellationRequested)
{
foreach (var item in _siemensPLC.Equipments.GroupBy(x => x.IP))
{
var plcIP = item.Key;
try
{
var plc = _siemensPLC.Plcs.First(x => x.IP == plcIP);
if (!plc.IsConnected)
{
await plc.OpenAsync(stoppingToken);
}
if (!plc.IsConnected)
{
_logger.LogWarning($"PLC[{plcIP}]连接失败");
continue;
}
_siemensPLC.Read(item.SelectMany(x => x.EquipmentProps));
}
catch (Exception ex)
{
_logger.LogError($"设备{item.Key}执行线程出现异常,{ex.Message}");
}
}
await Task.Delay(500, stoppingToken);
}
}
}
}