修改了Mqtt服务器启动不加载的问题

This commit is contained in:
2025-09-06 13:19:20 +08:00
parent 52f76e2377
commit 56130cd92a
9 changed files with 308 additions and 244 deletions

View File

@@ -8,20 +8,6 @@ namespace DMS.Application.DTOs.Events
/// </summary>
public class DataLoadCompletedEventArgs : System.EventArgs
{
/// <summary>
/// 加载的设备列表
/// </summary>
public List<DeviceDto> Devices { get; }
/// <summary>
/// 加载的变量表列表
/// </summary>
public List<VariableTableDto> VariableTables { get; }
/// <summary>
/// 加载的变量列表
/// </summary>
public List<VariableDto> Variables { get; }
/// <summary>
/// 加载是否成功
@@ -41,16 +27,10 @@ namespace DMS.Application.DTOs.Events
/// <summary>
/// 构造函数
/// </summary>
/// <param name="devices">设备列表</param>
/// <param name="variableTables">变量表列表</param>
/// <param name="variables">变量列表</param>
/// <param name="isSuccess">是否成功</param>
/// <param name="errorMessage">错误信息</param>
public DataLoadCompletedEventArgs(List<DeviceDto> devices, List<VariableTableDto> variableTables, List<VariableDto> variables, bool isSuccess, string errorMessage = null)
public DataLoadCompletedEventArgs(bool isSuccess, string errorMessage = null)
{
Devices = devices ?? new List<DeviceDto>();
VariableTables = variableTables ?? new List<VariableTableDto>();
Variables = variables ?? new List<VariableDto>();
IsSuccess = isSuccess;
ErrorMessage = errorMessage;
LoadTime = DateTime.Now;

View File

@@ -0,0 +1,37 @@
using System;
namespace DMS.Application.DTOs.Events
{
/// <summary>
/// MQTT服务器变更事件参数
/// </summary>
public class MqttServerChangedEventArgs : System.EventArgs
{
/// <summary>
/// 变更类型
/// </summary>
public DataChangeType ChangeType { get; }
/// <summary>
/// MQTT服务器DTO
/// </summary>
public MqttServerDto MqttServer { get; }
/// <summary>
/// 变更时间
/// </summary>
public DateTime ChangeTime { get; }
/// <summary>
/// 构造函数
/// </summary>
/// <param name="changeType">变更类型</param>
/// <param name="mqttServer">MQTT服务器DTO</param>
public MqttServerChangedEventArgs(DataChangeType changeType, MqttServerDto mqttServer)
{
ChangeType = changeType;
MqttServer = mqttServer;
ChangeTime = DateTime.Now;
}
}
}

View File

@@ -217,6 +217,50 @@ public interface IDataCenterService
#endregion
#region MQTT服务器管理
/// <summary>
/// 异步根据ID获取MQTT服务器DTO。
/// </summary>
Task<MqttServerDto> GetMqttServerByIdAsync(int id);
/// <summary>
/// 异步获取所有MQTT服务器DTO列表。
/// </summary>
Task<List<MqttServerDto>> GetAllMqttServersAsync();
/// <summary>
/// 异步创建一个新的MQTT服务器。
/// </summary>
Task<int> CreateMqttServerAsync(MqttServerDto mqttServerDto);
/// <summary>
/// 异步更新一个已存在的MQTT服务器。
/// </summary>
Task UpdateMqttServerAsync(MqttServerDto mqttServerDto);
/// <summary>
/// 异步删除一个MQTT服务器。
/// </summary>
Task DeleteMqttServerAsync(int id);
/// <summary>
/// 在内存中添加MQTT服务器
/// </summary>
void AddMqttServerToMemory(MqttServerDto mqttServerDto);
/// <summary>
/// 在内存中更新MQTT服务器
/// </summary>
void UpdateMqttServerInMemory(MqttServerDto mqttServerDto);
/// <summary>
/// 在内存中删除MQTT服务器
/// </summary>
void RemoveMqttServerFromMemory(int mqttServerId);
#endregion
#region 访
/// <summary>
@@ -243,6 +287,11 @@ public interface IDataCenterService
/// </summary>
ConcurrentDictionary<int, MenuBeanDto> MenuTrees { get; }
/// <summary>
/// 获取所有MQTT服务器的安全字典。
/// </summary>
ConcurrentDictionary<int, MqttServerDto> MqttServers { get; }
#endregion
#region
@@ -272,6 +321,11 @@ public interface IDataCenterService
/// </summary>
Task<List<MenuBeanDto>> LoadAllMenusAsync();
/// <summary>
/// 异步加载所有MQTT服务器数据。
/// </summary>
Task<List<MqttServerDto>> LoadAllMqttServersAsync();
#endregion
#region
@@ -302,9 +356,10 @@ public interface IDataCenterService
event EventHandler<MenuChangedEventArgs> MenuChanged;
/// <summary>
/// 当数据发生任何变化时触发
/// 当MQTT服务器数据发生变化时触发
/// </summary>
event EventHandler<DataChangedEventArgs> DataChanged;
event EventHandler<MqttServerChangedEventArgs> MqttServerChanged;
/// <summary>
/// 当变量值发生变化时触发

View File

@@ -26,6 +26,7 @@ public class DataCenterService : IDataCenterService
private readonly IVariableTableAppService _variableTableAppService;
private readonly IVariableAppService _variableAppService;
private readonly IMenuService _menuService;
private readonly IMqttAppService _mqttAppService;
/// <summary>
/// 安全字典,用于存储所有设备数据
@@ -52,6 +53,11 @@ public class DataCenterService : IDataCenterService
/// </summary>
public ConcurrentDictionary<int, MenuBeanDto> MenuTrees { get; } = new();
/// <summary>
/// 安全字典用于存储所有MQTT服务器数据
/// </summary>
public ConcurrentDictionary<int, MqttServerDto> MqttServers { get; } = new();
#region
/// <summary>
@@ -80,9 +86,11 @@ public class DataCenterService : IDataCenterService
public event EventHandler<MenuChangedEventArgs> MenuChanged;
/// <summary>
/// 当数据发生任何变化时触发
/// 当MQTT服务器数据发生变化时触发
/// </summary>
public event EventHandler<DataChangedEventArgs> DataChanged;
public event EventHandler<MqttServerChangedEventArgs> MqttServerChanged;
/// <summary>
/// 当变量值发生变化时触发
@@ -100,13 +108,15 @@ public class DataCenterService : IDataCenterService
/// <param name="variableTableAppService">变量表应用服务实例。</param>
/// <param name="variableAppService">变量应用服务实例。</param>
/// <param name="menuService">菜单服务实例。</param>
/// <param name="mqttAppService">MQTT应用服务实例。</param>
public DataCenterService(
IRepositoryManager repositoryManager,
IMapper mapper,
IDeviceAppService deviceAppService,
IVariableTableAppService variableTableAppService,
IVariableAppService variableAppService,
IMenuService menuService)
IMenuService menuService,
IMqttAppService mqttAppService)
{
_repositoryManager = repositoryManager;
_mapper = mapper;
@@ -114,6 +124,7 @@ public class DataCenterService : IDataCenterService
_variableTableAppService = variableTableAppService;
_variableAppService = variableAppService;
_menuService = menuService;
_mqttAppService = mqttAppService;
}
#region
@@ -545,65 +556,77 @@ public class DataCenterService : IDataCenterService
#endregion
#region
#region MQTT服务器管理
/// <summary>
/// 触发数据加载完成事件
/// 异步根据ID获取MQTT服务器DTO。
/// </summary>
/// <param name="e">事件参数</param>
protected virtual void OnDataLoadCompleted(DataLoadCompletedEventArgs e)
public async Task<MqttServerDto> GetMqttServerByIdAsync(int id)
{
DataLoadCompleted?.Invoke(this, e);
OnDataChanged(new DataChangedEventArgs(DataChangeType.Loaded));
return await _mqttAppService.GetMqttServerByIdAsync(id);
}
/// <summary>
/// 触发设备变更事件
/// 异步获取所有MQTT服务器DTO列表。
/// </summary>
/// <param name="e">事件参数</param>
protected virtual void OnDeviceChanged(DeviceChangedEventArgs e)
public async Task<List<MqttServerDto>> GetAllMqttServersAsync()
{
DeviceChanged?.Invoke(this, e);
OnDataChanged(new DataChangedEventArgs(e.ChangeType));
return await _mqttAppService.GetAllMqttServersAsync();
}
/// <summary>
/// 触发变量表变更事件
/// 异步创建一个新的MQTT服务器。
/// </summary>
/// <param name="e">事件参数</param>
protected virtual void OnVariableTableChanged(VariableTableChangedEventArgs e)
public async Task<int> CreateMqttServerAsync(MqttServerDto mqttServerDto)
{
VariableTableChanged?.Invoke(this, e);
OnDataChanged(new DataChangedEventArgs(e.ChangeType));
return await _mqttAppService.CreateMqttServerAsync(mqttServerDto);
}
/// <summary>
/// 触发变量变更事件
/// 异步更新一个已存在的MQTT服务器。
/// </summary>
/// <param name="e">事件参数</param>
protected virtual void OnVariableChanged(VariableChangedEventArgs e)
public async Task UpdateMqttServerAsync(MqttServerDto mqttServerDto)
{
VariableChanged?.Invoke(this, e);
OnDataChanged(new DataChangedEventArgs(e.ChangeType));
await _mqttAppService.UpdateMqttServerAsync(mqttServerDto);
}
/// <summary>
/// 触发菜单变更事件
/// 异步删除一个MQTT服务器。
/// </summary>
/// <param name="e">事件参数</param>
protected virtual void OnMenuChanged(MenuChangedEventArgs e)
public async Task DeleteMqttServerAsync(int id)
{
MenuChanged?.Invoke(this, e);
OnDataChanged(new DataChangedEventArgs(e.ChangeType));
await _mqttAppService.DeleteMqttServerAsync(id);
}
/// <summary>
/// 触发数据变更事件
/// 在内存中添加MQTT服务器
/// </summary>
/// <param name="e">事件参数</param>
protected virtual void OnDataChanged(DataChangedEventArgs e)
public void AddMqttServerToMemory(MqttServerDto mqttServerDto)
{
DataChanged?.Invoke(this, e);
if (MqttServers.TryAdd(mqttServerDto.Id, mqttServerDto))
{
OnMqttServerChanged(new MqttServerChangedEventArgs(DataChangeType.Added, mqttServerDto));
}
}
/// <summary>
/// 在内存中更新MQTT服务器
/// </summary>
public void UpdateMqttServerInMemory(MqttServerDto mqttServerDto)
{
MqttServers.AddOrUpdate(mqttServerDto.Id, mqttServerDto, (key, oldValue) => mqttServerDto);
OnMqttServerChanged(new MqttServerChangedEventArgs(DataChangeType.Updated, mqttServerDto));
}
/// <summary>
/// 在内存中删除MQTT服务器
/// </summary>
public void RemoveMqttServerFromMemory(int mqttServerId)
{
if (MqttServers.TryRemove(mqttServerId, out var mqttServerDto))
{
OnMqttServerChanged(new MqttServerChangedEventArgs(DataChangeType.Deleted, mqttServerDto));
}
}
#endregion
@@ -623,125 +646,55 @@ public class DataCenterService : IDataCenterService
Variables.Clear();
Menus.Clear();
MenuTrees.Clear();
MqttServers.Clear();
// 加载所有设备
var devices = await _repositoryManager.Devices.GetAllAsync();
var deviceDtos = _mapper.Map<List<DeviceDto>>(devices);
// 顺序加载所有数据,避免数据库连接并发问题
var devices = await LoadAllDevicesAsync();
var variableTables = await LoadAllVariableTablesAsync();
var variables = await LoadAllVariablesAsync();
var menus = await LoadAllMenusAsync();
var mqttServers = await LoadAllMqttServersAsync();
// 加载所有变量表
var variableTables = await _repositoryManager.VariableTables.GetAllAsync();
var variableTableDtos = _mapper.Map<List<VariableTableDto>>(variableTables);
// 加载所有变量
var variables = await _repositoryManager.Variables.GetAllAsync();
var variableDtos = _mapper.Map<List<VariableDto>>(variables);
// 加载所有菜单
var menus = await _repositoryManager.Menus.GetAllAsync();
var menuDtos = _mapper.Map<List<MenuBeanDto>>(menus);
// 建立设备与变量表的关联
foreach (var deviceDto in deviceDtos)
// 加载设备数据到内存
foreach (var device in devices)
{
deviceDto.VariableTables = variableTableDtos
.Where(vt => vt.DeviceId == deviceDto.Id)
.ToList();
// 将设备添加到安全字典
Devices.TryAdd(deviceDto.Id, deviceDto);
Devices.TryAdd(device.Id, device);
}
// 建立变量表与变量的关联
foreach (var variableTableDto in variableTableDtos)
// 加载变量表数据到内存
foreach (var variableTable in variableTables)
{
variableTableDto.Variables = variableDtos
.Where(v => v.VariableTableId == variableTableDto.Id)
.ToList();
if (Devices.TryGetValue(variableTableDto.DeviceId, out var deviceDto))
{
variableTableDto.Device = deviceDto;
}
// 将变量表添加到安全字典
VariableTables.TryAdd(variableTableDto.Id, variableTableDto);
VariableTables.TryAdd(variableTable.Id, variableTable);
}
// 将变量添加到安全字典
foreach (var variableDto in variableDtos)
// 加载变量数据到内存
foreach (var variable in variables)
{
if (VariableTables.TryGetValue(variableDto.VariableTableId, out var variableTable))
{
variableDto.VariableTable = variableTable;
}
Variables.TryAdd(variableDto.Id, variableDto);
Variables.TryAdd(variable.Id, variable);
}
// 将菜单添加到安全字典
foreach (var menuDto in menuDtos)
// 加载菜单数据到内存
foreach (var menu in menus)
{
Menus.TryAdd(menuDto.Id, menuDto);
Menus.TryAdd(menu.Id, menu);
}
BuildMenuTrees();
// 加载MQTT服务器数据到内存
foreach (var mqttServer in mqttServers)
{
MqttServers.TryAdd(mqttServer.Id, mqttServer);
}
// 构建菜单树
BuildMenuTree();
// 触发数据加载完成事件
OnDataLoadCompleted(new DataLoadCompletedEventArgs(
deviceDtos,
variableTableDtos,
variableDtos,
true));
OnDataLoadCompleted(new DataLoadCompletedEventArgs(true, "数据加载完成"));
}
catch (Exception ex)
{
// 触发数据加载失败事件
OnDataLoadCompleted(new DataLoadCompletedEventArgs(
new List<DeviceDto>(),
new List<VariableTableDto>(),
new List<VariableDto>(),
false,
ex.Message));
throw new ApplicationException($"加载所有数据到内存时发生错误,错误信息:{ex.Message}", ex);
}
}
private void BuildMenuTrees()
{
// 遍历所有菜单项,构建树形结构
foreach (var menu in Menus.Values)
{
// 检查是否有父ID并且父ID不为0通常0或null表示根节点
if (Menus.ContainsKey(menu.ParentId) && menu.ParentId != 0)
{
// 尝试从查找表中找到父菜单
if (Menus.TryGetValue(menu.ParentId, out var parentMenu))
{
// 将当前菜单添加到父菜单的Children列表中
parentMenu.Children.Add(menu);
}
// else: 如果找不到父菜单,这可能是一个数据完整性问题,可以根据需要处理
}
else
{
// 如果没有父ID则这是一个根菜单
MenuTrees.TryAdd(menu.Id, menu);
}
}
}
/// <summary>
/// 异步加载所有菜单数据。
/// </summary>
public async Task<List<MenuBeanDto>> LoadAllMenusAsync()
{
try
{
// 获取所有菜单
var menus = await _repositoryManager.Menus.GetAllAsync();
return _mapper.Map<List<MenuBeanDto>>(menus);
}
catch (Exception ex)
{
throw new ApplicationException($"加载所有菜单数据时发生错误,错误信息:{ex.Message}", ex);
OnDataLoadCompleted(new DataLoadCompletedEventArgs(false, $"数据加载失败: {ex.Message}"));
throw;
}
}
@@ -750,37 +703,7 @@ public class DataCenterService : IDataCenterService
/// </summary>
public async Task<List<DeviceDto>> LoadAllDevicesAsync()
{
try
{
// 获取所有设备
var devices = await _repositoryManager.Devices.GetAllAsync();
var deviceDtos = _mapper.Map<List<DeviceDto>>(devices);
// 为每个设备加载关联的变量表和变量
foreach (var deviceDto in deviceDtos)
{
// 获取设备的所有变量表
var variableTables = await _repositoryManager.VariableTables.GetAllAsync();
var deviceVariableTables = variableTables.Where(vt => vt.DeviceId == deviceDto.Id)
.ToList();
deviceDto.VariableTables = _mapper.Map<List<VariableTableDto>>(deviceVariableTables);
// 为每个变量表加载关联的变量
foreach (var variableTableDto in deviceDto.VariableTables)
{
var variables = await _repositoryManager.Variables.GetAllAsync();
var tableVariables = variables.Where(v => v.VariableTableId == variableTableDto.Id)
.ToList();
variableTableDto.Variables = _mapper.Map<List<VariableDto>>(tableVariables);
}
}
return deviceDtos;
}
catch (Exception ex)
{
throw new ApplicationException($"加载所有设备数据时发生错误,错误信息:{ex.Message}", ex);
}
return await _deviceAppService.GetAllDevicesAsync();
}
/// <summary>
@@ -788,27 +711,7 @@ public class DataCenterService : IDataCenterService
/// </summary>
public async Task<List<VariableTableDto>> LoadAllVariableTablesAsync()
{
try
{
// 获取所有变量表
var variableTables = await _repositoryManager.VariableTables.GetAllAsync();
var variableTableDtos = _mapper.Map<List<VariableTableDto>>(variableTables);
// 为每个变量表加载关联的变量
foreach (var variableTableDto in variableTableDtos)
{
var variables = await _repositoryManager.Variables.GetAllAsync();
var tableVariables = variables.Where(v => v.VariableTableId == variableTableDto.Id)
.ToList();
variableTableDto.Variables = _mapper.Map<List<VariableDto>>(tableVariables);
}
return variableTableDtos;
}
catch (Exception ex)
{
throw new ApplicationException($"加载所有变量表数据时发生错误,错误信息:{ex.Message}", ex);
}
return await _variableTableAppService.GetAllVariableTablesAsync();
}
/// <summary>
@@ -816,29 +719,107 @@ public class DataCenterService : IDataCenterService
/// </summary>
public async Task<List<VariableDto>> LoadAllVariablesAsync()
{
try
{
// 获取所有变量
var variables = await _repositoryManager.Variables.GetAllAsync();
return _mapper.Map<List<VariableDto>>(variables);
}
catch (Exception ex)
{
throw new ApplicationException($"加载所有变量数据时发生错误,错误信息:{ex.Message}", ex);
}
return await _variableAppService.GetAllVariablesAsync();
}
/// <summary>
/// 异步加载所有菜单数据。
/// </summary>
public async Task<List<MenuBeanDto>> LoadAllMenusAsync()
{
return await _menuService.GetAllMenusAsync();
}
/// <summary>
/// 异步加载所有MQTT服务器数据。
/// </summary>
public async Task<List<MqttServerDto>> LoadAllMqttServersAsync()
{
return await _mqttAppService.GetAllMqttServersAsync();
}
#endregion
#region
/// <summary>
/// 触发数据加载完成事件
/// </summary>
protected virtual void OnDataLoadCompleted(DataLoadCompletedEventArgs e)
{
DataLoadCompleted?.Invoke(this, e);
}
/// <summary>
/// 触发设备变更事件
/// </summary>
protected virtual void OnDeviceChanged(DeviceChangedEventArgs e)
{
DeviceChanged?.Invoke(this, e);
}
/// <summary>
/// 触发变量表变更事件
/// </summary>
protected virtual void OnVariableTableChanged(VariableTableChangedEventArgs e)
{
VariableTableChanged?.Invoke(this, e);
}
/// <summary>
/// 触发变量变更事件
/// </summary>
protected virtual void OnVariableChanged(VariableChangedEventArgs e)
{
VariableChanged?.Invoke(this, e);
}
/// <summary>
/// 触发菜单变更事件
/// </summary>
protected virtual void OnMenuChanged(MenuChangedEventArgs e)
{
MenuChanged?.Invoke(this, e);
}
/// <summary>
/// 触发MQTT服务器变更事件
/// </summary>
protected virtual void OnMqttServerChanged(MqttServerChangedEventArgs e)
{
MqttServerChanged?.Invoke(this, e);
}
/// <summary>
/// 触发变量值变更事件
/// </summary>
public virtual void OnVariableValueChanged(VariableValueChangedEventArgs e)
public void OnVariableValueChanged(VariableValueChangedEventArgs e)
{
VariableValueChanged?.Invoke(this, e);
}
#endregion
#region
/// <summary>
/// 构建菜单树结构
/// </summary>
private void BuildMenuTree()
{
// 清空现有菜单树
MenuTrees.Clear();
// 获取所有根菜单
var rootMenus = GetRootMenus();
// 将根菜单添加到菜单树中
foreach (var rootMenu in rootMenus)
{
MenuTrees.TryAdd(rootMenu.Id, rootMenu);
}
}
#endregion
}