资源模板以及资源策略模块方法和接口。

This commit is contained in:
gaoyutao
2025-09-11 17:57:51 +08:00
parent df7ed79fcb
commit 3dc8b2c2c6
59 changed files with 3523 additions and 184 deletions

View File

@@ -3,16 +3,16 @@ package com.ruoyi.system.api;
import com.ruoyi.common.core.constant.SecurityConstants; import com.ruoyi.common.core.constant.SecurityConstants;
import com.ruoyi.common.core.constant.ServiceNameConstants; import com.ruoyi.common.core.constant.ServiceNameConstants;
import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.domain.R;
import com.ruoyi.system.api.domain.AllInterfaceNameRemote; import com.ruoyi.system.api.domain.*;
import com.ruoyi.system.api.domain.EpsInitialTrafficDataRemote;
import com.ruoyi.system.api.domain.InitialSwitchInfoDetailsRemote;
import com.ruoyi.system.api.domain.RmResourceRegistrationRemote;
import com.ruoyi.system.api.factory.RemoteRevenueConfigFallbackFactory; import com.ruoyi.system.api.factory.RemoteRevenueConfigFallbackFactory;
import org.springframework.cloud.openfeign.FeignClient; import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestHeader; import org.springframework.web.bind.annotation.RequestHeader;
import java.util.List;
/** /**
* 用户服务 * 用户服务
* *
@@ -36,9 +36,39 @@ public interface RemoteRevenueConfigService
@PostMapping("/switchInfoDetails/autoSaveSwitchTraffic") @PostMapping("/switchInfoDetails/autoSaveSwitchTraffic")
public R<String> autoSaveSwitchTraffic(@RequestBody InitialSwitchInfoDetailsRemote queryParam, @RequestHeader(SecurityConstants.FROM_SOURCE) String source); public R<String> autoSaveSwitchTraffic(@RequestBody InitialSwitchInfoDetailsRemote queryParam, @RequestHeader(SecurityConstants.FROM_SOURCE) String source);
/**
* 监控资源信息,如果检测到心跳异常,修改资源表在线状态
* @param queryParam
* @param source
* @return
*/
@PostMapping("/registration/updateStatusByResource") @PostMapping("/registration/updateStatusByResource")
public R<String> updateStatusByResource(@RequestBody RmResourceRegistrationRemote queryParam, @RequestHeader(SecurityConstants.FROM_SOURCE) String source); public R<String> updateStatusByResource(@RequestBody RmResourceRegistrationRemote queryParam, @RequestHeader(SecurityConstants.FROM_SOURCE) String source);
/**
* 根据客户端id查询设备其他信息
* @param queryParam
* @param source
* @return
*/
@PostMapping("/interfaceName/getMsgByClientId") @PostMapping("/interfaceName/getMsgByClientId")
public R<AllInterfaceNameRemote> getMsgByClientId(@RequestBody AllInterfaceNameRemote queryParam, @RequestHeader(SecurityConstants.FROM_SOURCE) String source); public R<AllInterfaceNameRemote> getMsgByClientId(@RequestBody AllInterfaceNameRemote queryParam, @RequestHeader(SecurityConstants.FROM_SOURCE) String source);
/**
* 根据资源组id查询资源组名称
* @param id
* @param source
* @return
*/
@GetMapping("/group/getResourceGroupMsgById")
public R<RmResourceGroupRemote> getResourceGroupMsgById(Long id, @RequestHeader(SecurityConstants.FROM_SOURCE) String source);
/**
* 根据id查询资源信息
* @param ids
* @param source
* @return
*/
@PostMapping("/registration/getRegistrationByIds")
public R<List<RmResourceRegistrationRemote>> getRegistrationByIds(String[] ids, @RequestHeader(SecurityConstants.FROM_SOURCE) String source);
} }

View File

@@ -0,0 +1,19 @@
package com.ruoyi.system.api;
import com.ruoyi.common.core.constant.SecurityConstants;
import com.ruoyi.common.core.constant.ServiceNameConstants;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.system.api.factory.RemoteRocketMqFallbackFactory;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestHeader;
import org.springframework.web.bind.annotation.RequestParam;
import java.util.Map;
@FeignClient(contextId = "remoteRocketMqService", value = ServiceNameConstants.ROCKETMQ_SERVICE, fallbackFactory = RemoteRocketMqFallbackFactory.class)
public interface RemoteRocketMqService {
@PostMapping("/api/rocketMessage/sendAsyncProducerMessage")
public R<Map> sendAsyncProducerMessage(@RequestParam("topic") String topic, @RequestParam("tag") String tag, @RequestParam("key") String key, @RequestParam("value") String value, @RequestHeader(SecurityConstants.FROM_SOURCE) String source);
}

View File

@@ -0,0 +1,60 @@
package com.ruoyi.system.api.domain;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity;
import lombok.Data;
import java.util.Date;
/**
* 资源分组对象 rm_resource_group
*
* @author gyt
* @date 2025-08-12
*/
@Data
public class RmResourceGroupRemote extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** id */
private Long id;
/** 组名 */
@Excel(name = "组名")
private String groupName;
/** 描述 */
@Excel(name = "描述")
private String description;
/** 包含设备id */
private String includedDevicesId;
/** 包含设备名称 */
@Excel(name = "包含设备")
private String includedDevicesName;
/** 创建时间 */
@Excel(name = "创建时间",dateFormat = "yyyy-MM-dd HH:mm:ss")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date createTime;
/** 修改时间 */
@Excel(name = "修改时间",dateFormat = "yyyy-MM-dd HH:mm:ss")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date updateTime;
/** 创建人id */
private Long creatorId;
/** 创建人名称 */
private String creatorName;
/** 修改人id */
private Long updaterId;
/** 修改人名称 */
private String updaterName;
}

View File

@@ -2,15 +2,14 @@ package com.ruoyi.system.api.factory;
import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.domain.R;
import com.ruoyi.system.api.RemoteRevenueConfigService; import com.ruoyi.system.api.RemoteRevenueConfigService;
import com.ruoyi.system.api.domain.AllInterfaceNameRemote; import com.ruoyi.system.api.domain.*;
import com.ruoyi.system.api.domain.EpsInitialTrafficDataRemote;
import com.ruoyi.system.api.domain.InitialSwitchInfoDetailsRemote;
import com.ruoyi.system.api.domain.RmResourceRegistrationRemote;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.cloud.openfeign.FallbackFactory; import org.springframework.cloud.openfeign.FallbackFactory;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import java.util.List;
/** /**
* 用户服务降级处理 * 用户服务降级处理
* *
@@ -46,6 +45,16 @@ public class RemoteRevenueConfigFallbackFactory implements FallbackFactory<Remot
public R<AllInterfaceNameRemote> getMsgByClientId(AllInterfaceNameRemote queryParam, String source) { public R<AllInterfaceNameRemote> getMsgByClientId(AllInterfaceNameRemote queryParam, String source) {
return R.fail("获取服务器信息失败:" + throwable.getMessage()); return R.fail("获取服务器信息失败:" + throwable.getMessage());
} }
@Override
public R<RmResourceGroupRemote> getResourceGroupMsgById(Long id, String source) {
return R.fail("获取资源组信息失败:" + throwable.getMessage());
}
@Override
public R<List<RmResourceRegistrationRemote>> getRegistrationByIds(String[] ids, String source) {
return R.fail("获取资源注册信息失败:" + throwable.getMessage());
}
}; };
} }
} }

View File

@@ -0,0 +1,38 @@
package com.ruoyi.system.api.factory;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.system.api.RemoteRocketMqService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.cloud.openfeign.FallbackFactory;
import org.springframework.stereotype.Component;
import java.util.HashMap;
import java.util.Map;
/**
* 用户服务降级处理
*
* @author ruoyi
*/
@Component
public class RemoteRocketMqFallbackFactory implements FallbackFactory<RemoteRocketMqService>
{
private static final Logger log = LoggerFactory.getLogger(RemoteRocketMqFallbackFactory.class);
@Override
public RemoteRocketMqService create(Throwable throwable)
{
log.error("rocketMq服务调用失败:{}", throwable.getMessage());
return new RemoteRocketMqService()
{
@Override
public R<Map> sendAsyncProducerMessage(String topic, String tag, String key, String value, String source) {
Map<String, Object> errorMap = new HashMap<>();
errorMap.put("msg", "生产者发送消息失败");
errorMap.put("error", throwable.getMessage());
return R.fail(errorMap);
}
};
}
}

View File

@@ -2,3 +2,4 @@ com.ruoyi.system.api.factory.RemoteUserFallbackFactory
com.ruoyi.system.api.factory.RemoteLogFallbackFactory com.ruoyi.system.api.factory.RemoteLogFallbackFactory
com.ruoyi.system.api.factory.RemoteFileFallbackFactory com.ruoyi.system.api.factory.RemoteFileFallbackFactory
com.ruoyi.system.api.factory.RemoteRevenueConfigFallbackFactory com.ruoyi.system.api.factory.RemoteRevenueConfigFallbackFactory
com.ruoyi.system.api.factory.RemoteRocketMqFallbackFactory

View File

@@ -21,4 +21,9 @@ public class ServiceNameConstants
* 文件服务的serviceid * 文件服务的serviceid
*/ */
public static final String FILE_SERVICE = "ruoyi-file"; public static final String FILE_SERVICE = "ruoyi-file";
/**
* rocketMq的serviceid
*/
public static final String ROCKETMQ_SERVICE = "ruoyi-rocketmq";
} }

View File

@@ -244,7 +244,7 @@ public class EpsNodeBandwidthController extends BaseController
{ {
// 设置时间 // 设置时间
DateUtil.setTimeDay(epsNodeBandwidth); DateUtil.setTimeDay(epsNodeBandwidth);
Map list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "1", ChronoUnit.DAYS); List<Map> list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "1", ChronoUnit.DAYS);
return success(list); return success(list);
} }
/** /**
@@ -256,7 +256,7 @@ public class EpsNodeBandwidthController extends BaseController
{ {
// 设置时间 // 设置时间
DateUtil.setTimeMonth(epsNodeBandwidth); DateUtil.setTimeMonth(epsNodeBandwidth);
Map list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "2", ChronoUnit.MONTHS); List<Map> list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "2", ChronoUnit.MONTHS);
return success(list); return success(list);
} }
/** /**
@@ -268,7 +268,7 @@ public class EpsNodeBandwidthController extends BaseController
{ {
// 设置时间 // 设置时间
DateUtil.setTimeDay(epsNodeBandwidth); DateUtil.setTimeDay(epsNodeBandwidth);
Map list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "3", ChronoUnit.DAYS); List<Map> list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "3", ChronoUnit.DAYS);
return success(list); return success(list);
} }
/** /**
@@ -280,7 +280,7 @@ public class EpsNodeBandwidthController extends BaseController
{ {
// 设置时间 // 设置时间
DateUtil.setTimeMonth(epsNodeBandwidth); DateUtil.setTimeMonth(epsNodeBandwidth);
Map list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "4", ChronoUnit.MONTHS); List<Map> list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "4", ChronoUnit.MONTHS);
return success(list); return success(list);
} }
/** /**
@@ -292,7 +292,7 @@ public class EpsNodeBandwidthController extends BaseController
{ {
// 设置时间 // 设置时间
DateUtil.setTimeDay(epsNodeBandwidth); DateUtil.setTimeDay(epsNodeBandwidth);
Map list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "5", ChronoUnit.DAYS); List<Map> list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "5", ChronoUnit.DAYS);
return success(list); return success(list);
} }
/** /**
@@ -304,7 +304,7 @@ public class EpsNodeBandwidthController extends BaseController
{ {
// 设置时间 // 设置时间
DateUtil.setTimeMonth(epsNodeBandwidth); DateUtil.setTimeMonth(epsNodeBandwidth);
Map list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "6", ChronoUnit.MONTHS); List<Map> list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "6", ChronoUnit.MONTHS);
return success(list); return success(list);
} }
/** /**
@@ -316,7 +316,7 @@ public class EpsNodeBandwidthController extends BaseController
{ {
// 设置时间 // 设置时间
DateUtil.setTimeMonth(epsNodeBandwidth); DateUtil.setTimeMonth(epsNodeBandwidth);
Map list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "7", ChronoUnit.MONTHS); List<Map> list = epsNodeBandwidthService.graphicalAnalysis(epsNodeBandwidth, "7", ChronoUnit.MONTHS);
return success(list); return success(list);
} }
} }

View File

@@ -1,5 +1,6 @@
package com.ruoyi.system.controller; package com.ruoyi.system.controller;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.common.core.utils.poi.ExcelUtil; import com.ruoyi.common.core.utils.poi.ExcelUtil;
import com.ruoyi.common.core.web.controller.BaseController; import com.ruoyi.common.core.web.controller.BaseController;
import com.ruoyi.common.core.web.domain.AjaxResult; import com.ruoyi.common.core.web.domain.AjaxResult;
@@ -7,6 +8,7 @@ import com.ruoyi.common.core.web.page.PageDomain;
import com.ruoyi.common.core.web.page.TableDataInfo; import com.ruoyi.common.core.web.page.TableDataInfo;
import com.ruoyi.common.log.annotation.Log; import com.ruoyi.common.log.annotation.Log;
import com.ruoyi.common.log.enums.BusinessType; import com.ruoyi.common.log.enums.BusinessType;
import com.ruoyi.common.security.annotation.InnerAuth;
import com.ruoyi.common.security.annotation.RequiresPermissions; import com.ruoyi.common.security.annotation.RequiresPermissions;
import com.ruoyi.system.domain.RmResourceGroup; import com.ruoyi.system.domain.RmResourceGroup;
import com.ruoyi.system.service.IRmResourceGroupService; import com.ruoyi.system.service.IRmResourceGroupService;
@@ -100,4 +102,14 @@ public class RmResourceGroupController extends BaseController
{ {
return toAjax(rmResourceGroupService.deleteRmResourceGroupByIds(ids)); return toAjax(rmResourceGroupService.deleteRmResourceGroupByIds(ids));
} }
/**
* 获取资源分组详细信息
*/
@InnerAuth
@GetMapping(value = "/getResourceGroupMsgById")
public R<RmResourceGroup> getResourceGroupMsgById(Long id)
{
return R.ok(rmResourceGroupService.selectRmResourceGroupById(id));
}
} }

View File

@@ -144,5 +144,17 @@ public class RmResourceRegistrationController extends BaseController
return rows; return rows;
} }
/**
* 根据id查询资源信息
* @param ids
* @return
*/
@GetMapping("/getRegistrationByIds")
public R<List<RmResourceRegistration>> getRegistrationByIds(String[] ids)
{
List<RmResourceRegistration> list = rmResourceRegistrationService.getRegistrationByIds(ids);
return R.ok(list);
}
} }

View File

@@ -3,8 +3,7 @@ package com.ruoyi.system.domain;
import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.annotation.JsonFormat;
import com.ruoyi.common.core.annotation.Excel; import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity; import com.ruoyi.common.core.web.domain.BaseEntity;
import org.apache.commons.lang3.builder.ToStringBuilder; import lombok.Data;
import org.apache.commons.lang3.builder.ToStringStyle;
import java.util.Date; import java.util.Date;
@@ -14,6 +13,7 @@ import java.util.Date;
* @author gyt * @author gyt
* @date 2025-08-12 * @date 2025-08-12
*/ */
@Data
public class RmResourceGroup extends BaseEntity public class RmResourceGroup extends BaseEntity
{ {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
@@ -29,9 +29,11 @@ public class RmResourceGroup extends BaseEntity
@Excel(name = "描述") @Excel(name = "描述")
private String description; private String description;
/** 包含设备 */ /** 包含设备id */
private String includedDevicesId;
/** 包含设备名称 */
@Excel(name = "包含设备") @Excel(name = "包含设备")
private String includedDevices; private String includedDevicesName;
/** 创建时间 */ /** 创建时间 */
@Excel(name = "创建时间",dateFormat = "yyyy-MM-dd HH:mm:ss") @Excel(name = "创建时间",dateFormat = "yyyy-MM-dd HH:mm:ss")
@@ -55,119 +57,4 @@ public class RmResourceGroup extends BaseEntity
/** 修改人名称 */ /** 修改人名称 */
private String updaterName; private String updaterName;
@Override
public Date getCreateTime() {
return createTime;
}
@Override
public void setCreateTime(Date createTime) {
this.createTime = createTime;
}
@Override
public Date getUpdateTime() {
return updateTime;
}
@Override
public void setUpdateTime(Date updateTime) {
this.updateTime = updateTime;
}
public void setId(Long id)
{
this.id = id;
}
public Long getId()
{
return id;
}
public void setGroupName(String groupName)
{
this.groupName = groupName;
}
public String getGroupName()
{
return groupName;
}
public void setDescription(String description)
{
this.description = description;
}
public String getDescription()
{
return description;
}
public void setIncludedDevices(String includedDevices)
{
this.includedDevices = includedDevices;
}
public String getIncludedDevices()
{
return includedDevices;
}
public void setCreatorId(Long creatorId)
{
this.creatorId = creatorId;
}
public Long getCreatorId()
{
return creatorId;
}
public void setCreatorName(String creatorName)
{
this.creatorName = creatorName;
}
public String getCreatorName()
{
return creatorName;
}
public void setUpdaterId(Long updaterId)
{
this.updaterId = updaterId;
}
public Long getUpdaterId()
{
return updaterId;
}
public void setUpdaterName(String updaterName)
{
this.updaterName = updaterName;
}
public String getUpdaterName()
{
return updaterName;
}
@Override
public String toString() {
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)
.append("id", getId())
.append("groupName", getGroupName())
.append("description", getDescription())
.append("includedDevices", getIncludedDevices())
.append("createTime", getCreateTime())
.append("updateTime", getUpdateTime())
.append("creatorId", getCreatorId())
.append("creatorName", getCreatorName())
.append("updaterId", getUpdaterId())
.append("updaterName", getUpdaterName())
.toString();
}
} }

View File

@@ -0,0 +1,13 @@
package com.ruoyi.system.domain.vo;
import lombok.Data;
@Data
public class MessageVo {
private String clientId;
private String dataType;
private String data;
}

View File

@@ -0,0 +1,17 @@
package com.ruoyi.system.domain.vo;
import lombok.Data;
import java.time.Instant;
@Data
public class ResourceVo {
private String clientIp;
private Integer clientPort;
private String switchBoard;
private Long timestamp = Instant.now().getEpochSecond();
}

View File

@@ -84,4 +84,6 @@ public interface RmResourceRegistrationMapper
* @return * @return
*/ */
Integer updateStatusByResource(RmResourceRegistration rmResourceRegistration); Integer updateStatusByResource(RmResourceRegistration rmResourceRegistration);
List<RmResourceRegistration> getRegistrationByIds(String[] ids);
} }

View File

@@ -86,5 +86,5 @@ public interface IEpsNodeBandwidthService
* @param epsNodeBandwidth * @param epsNodeBandwidth
* @return * @return
*/ */
Map graphicalAnalysis(EpsNodeBandwidth epsNodeBandwidth, String bandwidthType, ChronoUnit timeUnit); List<Map> graphicalAnalysis(EpsNodeBandwidth epsNodeBandwidth, String bandwidthType, ChronoUnit timeUnit);
} }

View File

@@ -88,4 +88,6 @@ public interface IRmResourceRegistrationService
R<String> updateStatusByResource(RmResourceRegistration rmResourceRegistration); R<String> updateStatusByResource(RmResourceRegistration rmResourceRegistration);
AjaxResult getServerOnlineRate(); AjaxResult getServerOnlineRate();
List<RmResourceRegistration> getRegistrationByIds(String[] ids);
} }

View File

@@ -296,8 +296,8 @@ public class EpsNodeBandwidthServiceImpl implements IEpsNodeBandwidthService
return pageInfo; return pageInfo;
} }
@Override @Override
public Map graphicalAnalysis(EpsNodeBandwidth epsNodeBandwidth, String bandwidthType, ChronoUnit timeUnit){ public List<Map> graphicalAnalysis(EpsNodeBandwidth epsNodeBandwidth, String bandwidthType, ChronoUnit timeUnit){
Map<String, Object> nodeData = new HashMap<>(); List<Map> mapList = new ArrayList<>();
// 拿到列表 // 拿到列表
List<EpsNodeBandwidth> nodeBandwidthList = epsNodeBandwidthMapper.selectEpsNodeBandwidthList(epsNodeBandwidth); List<EpsNodeBandwidth> nodeBandwidthList = epsNodeBandwidthMapper.selectEpsNodeBandwidthList(epsNodeBandwidth);
Map<String, EpsNodeBandwidth> uniqueNodes = nodeBandwidthList.stream() Map<String, EpsNodeBandwidth> uniqueNodes = nodeBandwidthList.stream()
@@ -310,6 +310,7 @@ public class EpsNodeBandwidthServiceImpl implements IEpsNodeBandwidthService
(existing, replacement) -> existing (existing, replacement) -> existing
)); ));
uniqueNodes.values().forEach(node -> { uniqueNodes.values().forEach(node -> {
Map<String, Object> nodeData = new HashMap<>();
// 基础信息 // 基础信息
nodeData.put("nodeName", node.getNodeName()); nodeData.put("nodeName", node.getNodeName());
@@ -326,8 +327,9 @@ public class EpsNodeBandwidthServiceImpl implements IEpsNodeBandwidthService
epsNodeBandwidth.getEndTime(), epsNodeBandwidth.getEndTime(),
timeUnit timeUnit
)); ));
mapList.add(nodeData);
}); });
return nodeData; return mapList;
} }
// 动态生成复合键 // 动态生成复合键

View File

@@ -1,13 +1,18 @@
package com.ruoyi.system.service.impl; package com.ruoyi.system.service.impl;
import com.alibaba.fastjson.JSONObject;
import com.ruoyi.common.core.constant.SecurityConstants;
import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.domain.R;
import com.ruoyi.common.core.utils.DateUtils; import com.ruoyi.common.core.utils.DateUtils;
import com.ruoyi.common.core.web.domain.AjaxResult; import com.ruoyi.common.core.web.domain.AjaxResult;
import com.ruoyi.common.security.utils.SecurityUtils; import com.ruoyi.common.security.utils.SecurityUtils;
import com.ruoyi.system.api.RemoteRocketMqService;
import com.ruoyi.system.domain.EpsNodeBandwidth; import com.ruoyi.system.domain.EpsNodeBandwidth;
import com.ruoyi.system.domain.EpsServerRevenueConfig; import com.ruoyi.system.domain.EpsServerRevenueConfig;
import com.ruoyi.system.domain.RmEpsTopologyManagement; import com.ruoyi.system.domain.RmEpsTopologyManagement;
import com.ruoyi.system.domain.RmResourceRegistration; import com.ruoyi.system.domain.RmResourceRegistration;
import com.ruoyi.system.domain.vo.MessageVo;
import com.ruoyi.system.domain.vo.ResourceVo;
import com.ruoyi.system.mapper.EpsNodeBandwidthMapper; import com.ruoyi.system.mapper.EpsNodeBandwidthMapper;
import com.ruoyi.system.mapper.EpsServerRevenueConfigMapper; import com.ruoyi.system.mapper.EpsServerRevenueConfigMapper;
import com.ruoyi.system.mapper.RmEpsTopologyManagementMapper; import com.ruoyi.system.mapper.RmEpsTopologyManagementMapper;
@@ -18,6 +23,7 @@ import org.springframework.stereotype.Service;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.math.RoundingMode; import java.math.RoundingMode;
import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@@ -38,6 +44,8 @@ public class RmResourceRegistrationServiceImpl implements IRmResourceRegistratio
private RmEpsTopologyManagementMapper rmEpsTopologyManagementMapper; private RmEpsTopologyManagementMapper rmEpsTopologyManagementMapper;
@Autowired @Autowired
private EpsNodeBandwidthMapper epsNodeBandwidthMapper; private EpsNodeBandwidthMapper epsNodeBandwidthMapper;
@Autowired
private RemoteRocketMqService remoteRocketMqService;
/** /**
* 查询资源注册 * 查询资源注册
@@ -169,35 +177,87 @@ public class RmResourceRegistrationServiceImpl implements IRmResourceRegistratio
* @return 结果 * @return 结果
*/ */
@Override @Override
public int register(RmResourceRegistration rmResourceRegistration) public int register(RmResourceRegistration rmResourceRegistration) {
{ // 设置更新信息
rmResourceRegistration.setUpdateTime(DateUtils.getNowDate()); rmResourceRegistration.setUpdateTime(DateUtils.getNowDate());
rmResourceRegistration.setUpdaterId(SecurityUtils.getUserId()); rmResourceRegistration.setUpdaterId(SecurityUtils.getUserId());
rmResourceRegistration.setUpdaterName(SecurityUtils.getUsername()); rmResourceRegistration.setUpdaterName(SecurityUtils.getUsername());
if("1".equals(rmResourceRegistration.getResourceType())){
// 注册服务器 添加到服务器收益配置表 // 处理服务器资源注册
EpsServerRevenueConfig epsServerRevenueConfig = new EpsServerRevenueConfig(); if ("1".equals(rmResourceRegistration.getResourceType())) {
epsServerRevenueConfig.setHardwareSn(rmResourceRegistration.getHardwareSn()); handleServerRegistration(rmResourceRegistration);
epsServerRevenueConfig.setNodeName(rmResourceRegistration.getResourceName()); }
epsServerRevenueConfig.setCreateTime(DateUtils.getNowDate());
epsServerRevenueConfig.setRegistrationStatus(rmResourceRegistration.getRegistrationStatus()); // 发送消息通知
epsServerRevenueConfig.setServerIp(rmResourceRegistration.getIpAddress()); sendRegistrationMessage(rmResourceRegistration);
// 新增前判断是否存在
EpsServerRevenueConfig exits = epsServerRevenueConfigMapper.countBySn(epsServerRevenueConfig.getHardwareSn()); // 更新注册状态
if(exits != null){ return updateRegistrationStatus(rmResourceRegistration);
// 存在 修改 }
epsServerRevenueConfig.setId(exits.getId());
epsServerRevenueConfigMapper.updateEpsServerRevenueConfig(epsServerRevenueConfig); /**
}else{ * 处理服务器资源注册
// 不存在 新增 */
epsServerRevenueConfigMapper.insertEpsServerRevenueConfig(epsServerRevenueConfig); private void handleServerRegistration(RmResourceRegistration registration) {
EpsServerRevenueConfig config = new EpsServerRevenueConfig();
config.setHardwareSn(registration.getHardwareSn());
config.setNodeName(registration.getResourceName());
config.setCreateTime(DateUtils.getNowDate());
config.setRegistrationStatus(registration.getRegistrationStatus());
config.setServerIp(registration.getIpAddress());
EpsServerRevenueConfig existing = epsServerRevenueConfigMapper.countBySn(config.getHardwareSn());
if (existing != null) {
config.setId(existing.getId());
epsServerRevenueConfigMapper.updateEpsServerRevenueConfig(config);
} else {
epsServerRevenueConfigMapper.insertEpsServerRevenueConfig(config);
} }
} }
// 仅注册
RmResourceRegistration resourceRegistration = new RmResourceRegistration(); /**
resourceRegistration.setId(rmResourceRegistration.getId()); * 发送注册/断开连接消息
resourceRegistration.setRegistrationStatus(rmResourceRegistration.getRegistrationStatus()); */
return rmResourceRegistrationMapper.updateRmResourceRegistration(resourceRegistration); private void sendRegistrationMessage(RmResourceRegistration registration) {
String messageType = "1".equals(registration.getRegistrationStatus()) ? "REGISTER" : "DISCONNECT";
ResourceVo resourceVo = createResourceVo(registration);
MessageVo messageVo = new MessageVo();
messageVo.setClientId(registration.getHardwareSn());
messageVo.setDataType(messageType);
messageVo.setData(JSONObject.toJSONString(resourceVo));
remoteRocketMqService.sendAsyncProducerMessage(
"tongran_agent_down", "", "", JSONObject.toJSONString(messageVo), SecurityConstants.INNER);
}
/**
* 创建资源VO对象
*/
private ResourceVo createResourceVo(RmResourceRegistration registration) {
ResourceVo resourceVo = new ResourceVo();
resourceVo.setClientIp(registration.getIpAddress());
resourceVo.setClientPort(Integer.valueOf(registration.getResourcePort()));
if (!"1".equals(registration.getResourceType())) {
Map<String, String> switchMap = new HashMap<>();
switchMap.put("community", registration.getTeamName());
switchMap.put("ip", registration.getIpAddress());
switchMap.put("port", registration.getResourcePort());
resourceVo.setSwitchBoard(JSONObject.toJSONString(switchMap));
}
return resourceVo;
}
/**
* 更新注册状态
*/
private int updateRegistrationStatus(RmResourceRegistration registration) {
RmResourceRegistration updateParam = new RmResourceRegistration();
updateParam.setId(registration.getId());
updateParam.setRegistrationStatus(registration.getRegistrationStatus());
return rmResourceRegistrationMapper.updateRmResourceRegistration(updateParam);
} }
/** /**
* 批量删除资源注册 * 批量删除资源注册
@@ -280,5 +340,15 @@ public class RmResourceRegistrationServiceImpl implements IRmResourceRegistratio
.put("onlineRate", onlineRate); .put("onlineRate", onlineRate);
} }
/**
* 根据id查询资源注册信息
* @param ids
* @return
*/
@Override
public List<RmResourceRegistration> getRegistrationByIds(String[] ids) {
return rmResourceRegistrationMapper.getRegistrationByIds(ids);
}
} }

View File

@@ -1,14 +1,15 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper <!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.system.mapper.RmResourceGroupMapper"> <mapper namespace="com.ruoyi.system.mapper.RmResourceGroupMapper">
<resultMap type="RmResourceGroup" id="RmResourceGroupResult"> <resultMap type="RmResourceGroup" id="RmResourceGroupResult">
<result property="id" column="id" /> <result property="id" column="id" />
<result property="groupName" column="group_name" /> <result property="groupName" column="group_name" />
<result property="description" column="description" /> <result property="description" column="description" />
<result property="includedDevices" column="included_devices" /> <result property="includedDevicesId" column="included_devices_id" />
<result property="includedDevicesName" column="included_devices_name" />
<result property="createTime" column="create_time" /> <result property="createTime" column="create_time" />
<result property="updateTime" column="update_time" /> <result property="updateTime" column="update_time" />
<result property="creatorId" column="creator_id" /> <result property="creatorId" column="creator_id" />
@@ -18,7 +19,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</resultMap> </resultMap>
<sql id="selectRmResourceGroupVo"> <sql id="selectRmResourceGroupVo">
select id, group_name, description, included_devices, create_time, update_time, creator_id, creator_name, updater_id, updater_name from rm_resource_group select id, group_name, description, included_devices_id, included_devices_name, create_time, update_time, creator_id, creator_name, updater_id, updater_name from rm_resource_group
</sql> </sql>
<select id="selectRmResourceGroupList" parameterType="RmResourceGroup" resultMap="RmResourceGroupResult"> <select id="selectRmResourceGroupList" parameterType="RmResourceGroup" resultMap="RmResourceGroupResult">
@@ -26,7 +27,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<where> <where>
<if test="groupName != null and groupName != ''"> and group_name like concat('%', #{groupName}, '%')</if> <if test="groupName != null and groupName != ''"> and group_name like concat('%', #{groupName}, '%')</if>
<if test="description != null and description != ''"> and description = #{description}</if> <if test="description != null and description != ''"> and description = #{description}</if>
<if test="includedDevices != null and includedDevices != ''"> and included_devices = #{includedDevices}</if> <if test="includedDevicesId != null and includedDevicesId != ''"> and included_devices_id = #{includedDevicesId}</if>
<if test="includedDevicesName != null and includedDevicesName != ''"> and included_devices_name like concat('%', #{includedDevicesName}, '%')</if>
<if test="creatorId != null "> and creator_id = #{creatorId}</if> <if test="creatorId != null "> and creator_id = #{creatorId}</if>
<if test="creatorName != null and creatorName != ''"> and creator_name like concat('%', #{creatorName}, '%')</if> <if test="creatorName != null and creatorName != ''"> and creator_name like concat('%', #{creatorName}, '%')</if>
<if test="updaterId != null "> and updater_id = #{updaterId}</if> <if test="updaterId != null "> and updater_id = #{updaterId}</if>
@@ -44,7 +46,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<trim prefix="(" suffix=")" suffixOverrides=","> <trim prefix="(" suffix=")" suffixOverrides=",">
<if test="groupName != null">group_name,</if> <if test="groupName != null">group_name,</if>
<if test="description != null">description,</if> <if test="description != null">description,</if>
<if test="includedDevices != null">included_devices,</if> <if test="includedDevicesId != null">included_devices_id,</if>
<if test="includedDevicesName != null">included_devices_name,</if>
<if test="createTime != null">create_time,</if> <if test="createTime != null">create_time,</if>
<if test="updateTime != null">update_time,</if> <if test="updateTime != null">update_time,</if>
<if test="creatorId != null">creator_id,</if> <if test="creatorId != null">creator_id,</if>
@@ -55,7 +58,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<trim prefix="values (" suffix=")" suffixOverrides=","> <trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="groupName != null">#{groupName},</if> <if test="groupName != null">#{groupName},</if>
<if test="description != null">#{description},</if> <if test="description != null">#{description},</if>
<if test="includedDevices != null">#{includedDevices},</if> <if test="includedDevicesId != null">#{includedDevicesId},</if>
<if test="includedDevicesName != null">#{includedDevicesName},</if>
<if test="createTime != null">#{createTime},</if> <if test="createTime != null">#{createTime},</if>
<if test="updateTime != null">#{updateTime},</if> <if test="updateTime != null">#{updateTime},</if>
<if test="creatorId != null">#{creatorId},</if> <if test="creatorId != null">#{creatorId},</if>
@@ -70,7 +74,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<trim prefix="SET" suffixOverrides=","> <trim prefix="SET" suffixOverrides=",">
<if test="groupName != null">group_name = #{groupName},</if> <if test="groupName != null">group_name = #{groupName},</if>
<if test="description != null">description = #{description},</if> <if test="description != null">description = #{description},</if>
<if test="includedDevices != null">included_devices = #{includedDevices},</if> <if test="includedDevicesId != null">included_devices_id = #{includedDevicesId},</if>
<if test="includedDevicesName != null">included_devices_name = #{includedDevicesName},</if>
<if test="createTime != null">create_time = #{createTime},</if> <if test="createTime != null">create_time = #{createTime},</if>
<if test="updateTime != null">update_time = #{updateTime},</if> <if test="updateTime != null">update_time = #{updateTime},</if>
<if test="creatorId != null">creator_id = #{creatorId},</if> <if test="creatorId != null">creator_id = #{creatorId},</if>

View File

@@ -193,11 +193,11 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</delete> </delete>
<!-- 查询所有资源名称(包含设备使用)--> <!-- 查询所有资源名称(包含设备使用)-->
<select id="selectAllResourceName" resultType="java.util.Map"> <select id="selectAllResourceName" resultType="java.util.Map">
select resource_name resourceName from rm_resource_registration select id id,resource_name resourceName from rm_resource_registration
<where> <where>
and registration_status = 1 and registration_status = 1
</where> </where>
group by resource_name group by id
</select> </select>
<!-- 查询所有资源名称--> <!-- 查询所有资源名称-->
<select id="selectAllResourceNameByType" parameterType="RmResourceRegistration" resultType="java.util.Map"> <select id="selectAllResourceNameByType" parameterType="RmResourceRegistration" resultType="java.util.Map">
@@ -269,4 +269,11 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</trim> </trim>
where ip_address = #{ipAddress} where ip_address = #{ipAddress}
</update> </update>
<select id="getRegistrationByIds" parameterType="String" resultMap="RmResourceRegistrationResult">
<include refid="selectRmResourceRegistrationVo"/>
where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</select>
</mapper> </mapper>

View File

@@ -0,0 +1,42 @@
package com.ruoyi.rocketmq.controller;
import com.ruoyi.common.core.web.controller.BaseController;
import com.ruoyi.common.core.web.domain.AjaxResult;
import com.ruoyi.common.security.annotation.RequiresPermissions;
import com.ruoyi.rocketmq.domain.RmInitialMonitorItem;
import com.ruoyi.rocketmq.service.IRmInitialMonitorItemService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
import java.util.Map;
/**
* 基础监控项Controller
*
* @author gyt
* @date 2025-09-10
*/
@RestController
@RequestMapping("/initialMonitorItem")
public class RmInitialMonitorItemController extends BaseController
{
@Autowired
private IRmInitialMonitorItemService rmInitialMonitorItemService;
/**
* 查询监控项列表
*/
@RequiresPermissions("rocketmq:item:list")
@PostMapping("/list")
public AjaxResult list(@RequestBody RmInitialMonitorItem rmInitialMonitorItem)
{
Map<String, List<RmInitialMonitorItem>> map = rmInitialMonitorItemService.selectAllMsgList(rmInitialMonitorItem);
return success(map);
}
}

View File

@@ -0,0 +1,98 @@
package com.ruoyi.rocketmq.controller;
import com.ruoyi.common.core.utils.poi.ExcelUtil;
import com.ruoyi.common.core.web.controller.BaseController;
import com.ruoyi.common.core.web.domain.AjaxResult;
import com.ruoyi.common.core.web.page.TableDataInfo;
import com.ruoyi.common.log.annotation.Log;
import com.ruoyi.common.log.enums.BusinessType;
import com.ruoyi.common.security.annotation.RequiresPermissions;
import com.ruoyi.rocketmq.domain.RmMonitorPolicy;
import com.ruoyi.rocketmq.service.IRmMonitorPolicyService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletResponse;
import java.util.List;
/**
* 资源监控策略Controller
*
* @author gyt
* @date 2025-09-10
*/
@RestController
@RequestMapping("/policy")
public class RmMonitorPolicyController extends BaseController
{
@Autowired
private IRmMonitorPolicyService rmMonitorPolicyService;
/**
* 查询资源监控策略列表
*/
@RequiresPermissions("rocketmq:policy:list")
@GetMapping("/list")
public TableDataInfo list(RmMonitorPolicy rmMonitorPolicy)
{
startPage();
List<RmMonitorPolicy> list = rmMonitorPolicyService.selectRmMonitorPolicyList(rmMonitorPolicy);
return getDataTable(list);
}
/**
* 导出资源监控策略列表
*/
@RequiresPermissions("rocketmq:policy:export")
@Log(title = "资源监控策略", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, RmMonitorPolicy rmMonitorPolicy)
{
List<RmMonitorPolicy> list = rmMonitorPolicyService.selectRmMonitorPolicyList(rmMonitorPolicy);
ExcelUtil<RmMonitorPolicy> util = new ExcelUtil<RmMonitorPolicy>(RmMonitorPolicy.class);
util.exportExcel(response, list, "资源监控策略数据");
}
/**
* 获取资源监控策略详细信息
*/
@RequiresPermissions("rocketmq:policy:query")
@GetMapping(value = "/{id}")
public AjaxResult getInfo(@PathVariable("id") Long id)
{
return success(rmMonitorPolicyService.getRmMonitorPolicyMsgById(id));
}
/**
* 新增资源监控策略
*/
@RequiresPermissions("rocketmq:policy:add")
@Log(title = "资源监控策略", businessType = BusinessType.INSERT)
@PostMapping
public AjaxResult add(@RequestBody RmMonitorPolicy rmMonitorPolicy)
{
return toAjax(rmMonitorPolicyService.addRmMonitorPolicy(rmMonitorPolicy));
}
/**
* 修改资源监控策略
*/
@RequiresPermissions("rocketmq:policy:edit")
@Log(title = "资源监控策略", businessType = BusinessType.UPDATE)
@PutMapping
public AjaxResult edit(@RequestBody RmMonitorPolicy rmMonitorPolicy)
{
return toAjax(rmMonitorPolicyService.updateRmMonitorPolicy(rmMonitorPolicy));
}
/**
* 资源监控策略下发
*/
@RequiresPermissions("rocketmq:policy:edit")
@Log(title = "资源监控策略下发", businessType = BusinessType.UPDATE)
@GetMapping("/issuePolicy")
public AjaxResult issuePolicy(Long id)
{
return toAjax(rmMonitorPolicyService.issuePolicy(id));
}
}

View File

@@ -0,0 +1,103 @@
package com.ruoyi.rocketmq.controller;
import com.ruoyi.common.core.utils.poi.ExcelUtil;
import com.ruoyi.common.core.web.controller.BaseController;
import com.ruoyi.common.core.web.domain.AjaxResult;
import com.ruoyi.common.core.web.page.PageDomain;
import com.ruoyi.common.core.web.page.TableDataInfo;
import com.ruoyi.common.log.annotation.Log;
import com.ruoyi.common.log.enums.BusinessType;
import com.ruoyi.common.security.annotation.RequiresPermissions;
import com.ruoyi.rocketmq.domain.RmMonitorTemplate;
import com.ruoyi.rocketmq.domain.vo.RmMonitorTemplateVo;
import com.ruoyi.rocketmq.service.IRmMonitorTemplateService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletResponse;
import java.util.List;
/**
* 监控模板Controller
*
* @author gyt
* @date 2025-09-09
*/
@RestController
@RequestMapping("/template")
public class RmMonitorTemplateController extends BaseController
{
@Autowired
private IRmMonitorTemplateService rmMonitorTemplateService;
/**
* 查询监控模板列表
*/
@RequiresPermissions("rocketmq:template:list")
@PostMapping("/list")
public TableDataInfo list(@RequestBody RmMonitorTemplate rmMonitorTemplate)
{
PageDomain pageDomain = new PageDomain();
pageDomain.setPageNum(rmMonitorTemplate.getPageNum());
pageDomain.setPageSize(rmMonitorTemplate.getPageSize());
startPage(pageDomain);
List<RmMonitorTemplate> list = rmMonitorTemplateService.selectRmMonitorTemplateList(rmMonitorTemplate);
return getDataTable(list);
}
/**
* 导出监控模板列表
*/
@RequiresPermissions("rocketmq:template:export")
@Log(title = "监控模板", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, RmMonitorTemplate rmMonitorTemplate)
{
List<RmMonitorTemplate> list = rmMonitorTemplateService.selectRmMonitorTemplateList(rmMonitorTemplate);
ExcelUtil<RmMonitorTemplate> util = new ExcelUtil<RmMonitorTemplate>(RmMonitorTemplate.class);
util.exportExcel(response, list, "监控模板数据");
}
/**
* 获取监控模板详细信息
*/
@RequiresPermissions("rocketmq:template:query")
@GetMapping(value = "/{id}")
public AjaxResult getInfo(@PathVariable("id") Long id)
{
return success(rmMonitorTemplateService.getTemplateMsgById(id));
}
/**
* 新增监控模板
*/
@RequiresPermissions("rocketmq:template:add")
@Log(title = "监控模板", businessType = BusinessType.INSERT)
@PostMapping
public AjaxResult add(@RequestBody RmMonitorTemplateVo rmMonitorTemplateVo)
{
return toAjax(rmMonitorTemplateService.addRmMonitorTemplate(rmMonitorTemplateVo));
}
/**
* 修改监控模板
*/
@RequiresPermissions("rocketmq:template:edit")
@Log(title = "监控模板", businessType = BusinessType.UPDATE)
@PutMapping
public AjaxResult edit(@RequestBody RmMonitorTemplate rmMonitorTemplate)
{
return toAjax(rmMonitorTemplateService.updateRmMonitorTemplate(rmMonitorTemplate));
}
/**
* 删除监控模板
*/
@RequiresPermissions("rocketmq:template:remove")
@Log(title = "监控模板", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public AjaxResult remove(@PathVariable Long[] ids)
{
return toAjax(rmMonitorTemplateService.deleteRmMonitorTemplateByIds(ids));
}
}

View File

@@ -0,0 +1,105 @@
package com.ruoyi.rocketmq.controller;
import java.util.List;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.ruoyi.common.log.annotation.Log;
import com.ruoyi.common.log.enums.BusinessType;
import com.ruoyi.common.security.annotation.RequiresPermissions;
import com.ruoyi.rocketmq.domain.RmTemplateLinux;
import com.ruoyi.rocketmq.service.IRmTemplateLinuxService;
import com.ruoyi.common.core.web.controller.BaseController;
import com.ruoyi.common.core.web.domain.AjaxResult;
import com.ruoyi.common.core.utils.poi.ExcelUtil;
import com.ruoyi.common.core.web.page.TableDataInfo;
/**
* Linux系统监控项Controller
*
* @author gyt
* @date 2025-09-09
*/
@RestController
@RequestMapping("/linux")
public class RmTemplateLinuxController extends BaseController
{
@Autowired
private IRmTemplateLinuxService rmTemplateLinuxService;
/**
* 查询Linux系统监控项列表
*/
@RequiresPermissions("rocketmq:linux:list")
@GetMapping("/list")
public TableDataInfo list(RmTemplateLinux rmTemplateLinux)
{
startPage();
List<RmTemplateLinux> list = rmTemplateLinuxService.selectRmTemplateLinuxList(rmTemplateLinux);
return getDataTable(list);
}
/**
* 导出Linux系统监控项列表
*/
@RequiresPermissions("rocketmq:linux:export")
@Log(title = "Linux系统监控项", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, RmTemplateLinux rmTemplateLinux)
{
List<RmTemplateLinux> list = rmTemplateLinuxService.selectRmTemplateLinuxList(rmTemplateLinux);
ExcelUtil<RmTemplateLinux> util = new ExcelUtil<RmTemplateLinux>(RmTemplateLinux.class);
util.exportExcel(response, list, "Linux系统监控项数据");
}
/**
* 获取Linux系统监控项详细信息
*/
@RequiresPermissions("rocketmq:linux:query")
@GetMapping(value = "/{id}")
public AjaxResult getInfo(@PathVariable("id") Long id)
{
return success(rmTemplateLinuxService.selectRmTemplateLinuxById(id));
}
/**
* 新增Linux系统监控项
*/
@RequiresPermissions("rocketmq:linux:add")
@Log(title = "Linux系统监控项", businessType = BusinessType.INSERT)
@PostMapping
public AjaxResult add(@RequestBody RmTemplateLinux rmTemplateLinux)
{
return toAjax(rmTemplateLinuxService.insertRmTemplateLinux(rmTemplateLinux));
}
/**
* 修改Linux系统监控项
*/
@RequiresPermissions("rocketmq:linux:edit")
@Log(title = "Linux系统监控项", businessType = BusinessType.UPDATE)
@PutMapping
public AjaxResult edit(@RequestBody RmTemplateLinux rmTemplateLinux)
{
return toAjax(rmTemplateLinuxService.updateRmTemplateLinux(rmTemplateLinux));
}
/**
* 删除Linux系统监控项
*/
@RequiresPermissions("rocketmq:linux:remove")
@Log(title = "Linux系统监控项", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public AjaxResult remove(@PathVariable Long[] ids)
{
return toAjax(rmTemplateLinuxService.deleteRmTemplateLinuxByIds(ids));
}
}

View File

@@ -0,0 +1,105 @@
package com.ruoyi.rocketmq.controller;
import java.util.List;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.ruoyi.common.log.annotation.Log;
import com.ruoyi.common.log.enums.BusinessType;
import com.ruoyi.common.security.annotation.RequiresPermissions;
import com.ruoyi.rocketmq.domain.RmTemplateSwitch;
import com.ruoyi.rocketmq.service.IRmTemplateSwitchService;
import com.ruoyi.common.core.web.controller.BaseController;
import com.ruoyi.common.core.web.domain.AjaxResult;
import com.ruoyi.common.core.utils.poi.ExcelUtil;
import com.ruoyi.common.core.web.page.TableDataInfo;
/**
* 交换机监控模板Controller
*
* @author gyt
* @date 2025-09-09
*/
@RestController
@RequestMapping("/switch")
public class RmTemplateSwitchController extends BaseController
{
@Autowired
private IRmTemplateSwitchService rmTemplateSwitchService;
/**
* 查询交换机监控模板列表
*/
@RequiresPermissions("rocketmq:switch:list")
@GetMapping("/list")
public TableDataInfo list(RmTemplateSwitch rmTemplateSwitch)
{
startPage();
List<RmTemplateSwitch> list = rmTemplateSwitchService.selectRmTemplateSwitchList(rmTemplateSwitch);
return getDataTable(list);
}
/**
* 导出交换机监控模板列表
*/
@RequiresPermissions("rocketmq:switch:export")
@Log(title = "交换机监控模板", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, RmTemplateSwitch rmTemplateSwitch)
{
List<RmTemplateSwitch> list = rmTemplateSwitchService.selectRmTemplateSwitchList(rmTemplateSwitch);
ExcelUtil<RmTemplateSwitch> util = new ExcelUtil<RmTemplateSwitch>(RmTemplateSwitch.class);
util.exportExcel(response, list, "交换机监控模板数据");
}
/**
* 获取交换机监控模板详细信息
*/
@RequiresPermissions("rocketmq:switch:query")
@GetMapping(value = "/{id}")
public AjaxResult getInfo(@PathVariable("id") Long id)
{
return success(rmTemplateSwitchService.selectRmTemplateSwitchById(id));
}
/**
* 新增交换机监控模板
*/
@RequiresPermissions("rocketmq:switch:add")
@Log(title = "交换机监控模板", businessType = BusinessType.INSERT)
@PostMapping
public AjaxResult add(@RequestBody RmTemplateSwitch rmTemplateSwitch)
{
return toAjax(rmTemplateSwitchService.insertRmTemplateSwitch(rmTemplateSwitch));
}
/**
* 修改交换机监控模板
*/
@RequiresPermissions("rocketmq:switch:edit")
@Log(title = "交换机监控模板", businessType = BusinessType.UPDATE)
@PutMapping
public AjaxResult edit(@RequestBody RmTemplateSwitch rmTemplateSwitch)
{
return toAjax(rmTemplateSwitchService.updateRmTemplateSwitch(rmTemplateSwitch));
}
/**
* 删除交换机监控模板
*/
@RequiresPermissions("rocketmq:switch:remove")
@Log(title = "交换机监控模板", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public AjaxResult remove(@PathVariable Long[] ids)
{
return toAjax(rmTemplateSwitchService.deleteRmTemplateSwitchByIds(ids));
}
}

View File

@@ -1,6 +1,7 @@
package com.ruoyi.rocketmq.controller; package com.ruoyi.rocketmq.controller;
import com.ruoyi.common.security.annotation.InnerAuth;
import com.ruoyi.rocketmq.producer.MessageProducer; import com.ruoyi.rocketmq.producer.MessageProducer;
import org.apache.rocketmq.client.producer.SendResult; import org.apache.rocketmq.client.producer.SendResult;
import org.apache.rocketmq.common.message.Message; import org.apache.rocketmq.common.message.Message;
@@ -124,11 +125,12 @@ public class RocketMqController {
/** /**
* 发送异步的消息 * 发送异步的消息
*/ */
@InnerAuth
@PostMapping("/sendAsyncProducerMessage") @PostMapping("/sendAsyncProducerMessage")
private Map sendAsyncProducerMessage(@RequestParam("topic") String topic,@RequestParam("tag") String tag,@RequestParam("key") String key,@RequestParam("value") String value){ private Map sendAsyncProducerMessage(@RequestParam("topic") String topic,@RequestParam("tag") String tag,@RequestParam("key") String key,@RequestParam("value") String value){
MessageProducer messageProducer = new MessageProducer(); MessageProducer messageProducer = new MessageProducer();
//调用MessageProducer配置好的消息方法 topic需要你根据你们业务定制相应的 //调用MessageProducer配置好的消息方法 topic需要你根据你们业务定制相应的
SendResult sendResult = messageProducer.sendAsyncProducerMessage("order-message","order_timeout_tag","title","content"); SendResult sendResult = messageProducer.sendAsyncProducerMessage(topic,tag,key,value);
Map<String,Object> result = new HashMap<>(); Map<String,Object> result = new HashMap<>();
result.put("data",sendResult); result.put("data",sendResult);
return result; return result;

View File

@@ -0,0 +1,56 @@
package com.ruoyi.rocketmq.domain;
import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity;
import lombok.Data;
/**
* 基础监控项对象 rm_initial_monitor_item
*
* @author gyt
* @date 2025-09-10
*/
@Data
public class RmInitialMonitorItem extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** 主键ID */
private Long id;
/** 监控项类型(监控项,自动发现项) */
@Excel(name = "监控项类型(监控项,自动发现项)")
private String itemType;
/** 监控标识(唯一键) */
@Excel(name = "监控标识(唯一键)")
private String metricKey;
/** 监控名称 */
@Excel(name = "监控名称")
private String metricName;
/** 监控OID */
@Excel(name = "监控OID")
private String oid;
/** 过滤值 */
@Excel(name = "过滤值")
private String filterValue;
/** 监控说明 */
@Excel(name = "监控说明")
private String monitorDescription;
/** 数据类型 */
@Excel(name = "数据类型")
private String dataType;
/** 资源类型 */
@Excel(name = "资源类型")
private String resourceType;
/** 采集周期 */
@Excel(name = "采集周期")
private String collectionCycle;
}

View File

@@ -0,0 +1,55 @@
package com.ruoyi.rocketmq.domain;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity;
import com.ruoyi.rocketmq.domain.vo.RmMonitorPolicyVo;
import lombok.Data;
import java.util.Date;
import java.util.List;
/**
* 资源监控策略对象 rm_monitor_policy
*
* @author gyt
* @date 2025-09-10
*/
@Data
public class RmMonitorPolicy extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** 主键ID */
private Long id;
/** 模板ID */
@Excel(name = "模板ID")
private Long templateId;
/** 资源组ID */
@Excel(name = "资源组ID")
private Long resourceGroupId;
/** 资源组名称 */
private String resourceGroupName;
/** 策略名称 */
@Excel(name = "策略名称")
private String policyName;
/** 描述 */
@Excel(name = "描述")
private String description;
/** 状态0-待下发1-已下发 */
@Excel(name = "状态0-待下发1-已下发")
private String status;
/** 下发策略时间 */
@JsonFormat(pattern = "yyyy-MM-dd")
@Excel(name = "下发策略时间", width = 30, dateFormat = "yyyy-MM-dd")
private Date deployTime;
/** 采集周期及id集合 */
private List<RmMonitorPolicyVo> collectionAndIdList;
}

View File

@@ -0,0 +1,45 @@
package com.ruoyi.rocketmq.domain;
import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity;
import lombok.Data;
/**
* 监控模板对象 rm_monitor_template
*
* @author gyt
* @date 2025-09-09
*/
@Data
public class RmMonitorTemplate extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** 主键ID */
private Long id;
/** 模板名称 */
@Excel(name = "模板名称")
private String templateName;
/** 模板描述 */
@Excel(name = "模板描述")
private String description;
/** 监控项 */
@Excel(name = "监控项")
private String monitorItems;
/** 自动发现项 */
@Excel(name = "自动发现项")
private String discoveryRules;
/** 资源组ID */
@Excel(name = "资源组ID")
private Long resourceGroupId;
/** 资源组名称 */
private String resourceGroupName;
/** 资源类型(linux,switch) */
private String resourcyType;
}

View File

@@ -0,0 +1,49 @@
package com.ruoyi.rocketmq.domain;
import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity;
import lombok.Data;
/**
* Linux系统监控项对象 rm_template_linux
*
* @author gyt
* @date 2025-09-09
*/
@Data
public class RmTemplateLinux extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** 主键ID */
private Long id;
/** 关联的模板ID */
@Excel(name = "关联的模板ID")
private Long templateId;
/** 关联的策略ID */
private Long policyId;
/** 监控项类型 */
@Excel(name = "监控项类型")
private String itemType;
/** 监控标识(唯一键) */
@Excel(name = "监控标识(唯一键)")
private String metricKey;
/** 监控名称 */
@Excel(name = "监控名称")
private String metricName;
/** 数据类型 */
@Excel(name = "数据类型")
private String dataType;
/** 监控状态(0-禁用,1启用) */
@Excel(name = "监控状态(0-禁用,1启用)")
private String monitorStatus;
/** 采集周期 */
private Long collectionCycle;
}

View File

@@ -0,0 +1,63 @@
package com.ruoyi.rocketmq.domain;
import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity;
import lombok.Data;
/**
* 交换机监控模板对象 rm_template_switch
*
* @author gyt
* @date 2025-09-09
*/
@Data
public class RmTemplateSwitch extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** 主键ID */
private Long id;
/** 关联的模板ID */
@Excel(name = "关联的模板ID")
private Long templateId;
/** 关联的策略ID */
private Long policyId;
/** 监控项类型 */
@Excel(name = "监控项类型")
private String itemType;
/** 监控标识(唯一键) */
@Excel(name = "监控标识(唯一键)")
private String metricKey;
/** 监控名称 */
@Excel(name = "监控名称")
private String metricName;
/** 监控OID(SNMP标识) */
@Excel(name = "监控OID(SNMP标识)")
private String oid;
/** 过滤值(用于特定端口或接口过滤) */
@Excel(name = "过滤值(用于特定端口或接口过滤)")
private String filterValue;
/** 监控说明 */
@Excel(name = "监控说明")
private String switchDescription;
/** 数据类型 */
@Excel(name = "数据类型")
private String dataType;
/** 监控状态(0-禁用,1启用) */
@Excel(name = "监控状态(0-禁用,1启用)")
private String monitorStatus;
/** 采集周期 */
private Long collectionCycle;
}

View File

@@ -0,0 +1,13 @@
package com.ruoyi.rocketmq.domain.vo;
import lombok.Data;
@Data
public class CollectVo {
/** 采集类型 */
private String type;
/** 是否采集 */
private boolean collect = false;
/** 采集周期 */
private Long interval = 300L;
}

View File

@@ -0,0 +1,23 @@
package com.ruoyi.rocketmq.domain.vo;
import com.ruoyi.common.core.web.domain.BaseEntity;
import lombok.Data;
/**
* 资源监控策略对象 rm_monitor_policy
*
* @author gyt
* @date 2025-09-10
*/
@Data
public class RmMonitorPolicyVo extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** 主键ID */
private Long id;
/** 采集周期 */
private Long collectionCycle;
}

View File

@@ -0,0 +1,67 @@
package com.ruoyi.rocketmq.domain.vo;
import com.ruoyi.common.core.web.domain.BaseEntity;
import lombok.Data;
/**
* 监控模板对象 rm_monitor_template业务类
*
* @author gyt
* @date 2025-09-09
*/
@Data
public class RmMonitorTemplateVo extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** 主键ID */
private Long id;
/** 模板名称 */
private String templateName;
/** 模板描述 */
private String description;
/** 监控项 */
private String monitorItems;
/** 自动发现项 */
private String discoveryRules;
/** 资源组ID */
private Long resourceGroupId;
/** 关联的模板ID */
private Long templateId;
/** 监控项类型 */
private String itemType;
/** 监控标识(唯一键) */
private String metricKey;
/** 监控名称 */
private String metricName;
/** 数据类型 */
private String dataType;
/** 监控状态(0-禁用,1启用) */
private String monitorStatus;
/** 监控OID(SNMP标识) */
private String oid;
/** 过滤值(用于特定端口或接口过滤) */
private String filterValue;
/** 监控说明 */
private String switchDescription;
/**
* 资源类型linuxswitch
*/
private String resourceType;
/**
* 监控ids
*/
private Long[] monitorIds;
}

View File

@@ -0,0 +1,73 @@
package com.ruoyi.rocketmq.enums;
import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.NoArgsConstructor;
/**
* 控制码
*/
@Getter
@AllArgsConstructor
@NoArgsConstructor
public enum MsgEnum {
注册("REGISTER"),
注册应答("REGISTER_RSP"),
断开("DISCONNECT"),
断开应答("DISCONNECT_RSP"),
心跳上报("HEARTBEAT"),
CPU上报("CPU"),
磁盘上报("DISK"),
容器上报("DOCKER"),
内存上报("MEMORY"),
网络上报("NET"),
挂载上报("POINT"),
系统其他上报("OTHER_SYSTEM"),
交换机上报("SWITCHBOARD"),
开启系统采集("SYSTEM_COLLECT_START"),
开启系统采集应答("SYSTEM_COLLECT_START_RSP"),
关闭系统采集("SYSTEM_COLLECT_STOP"),
关闭系统采集应答("SYSTEM_COLLECT_STOP_RSP"),
开启交换机采集("SWITCH_COLLECT_START"),
开启交换机采集应答("SWITCH_COLLECT_START_RSP"),
关闭交换机采集("SWITCH_COLLECT_STOP"),
关闭交换机采集应答("SWITCH_COLLECT_STOP_RSP"),
告警设置("ALARM_SET"),
告警设置应答("ALARM_SET_RSP"),
执行脚本策略("SCRIPT_POLICY"),
执行脚本策略应答("SCRIPT_POLICY_RSP"),
Agent版本更新("AGENT_VERSION_UPDATE"),
Agent版本更新应答("AGENT_VERSION_UPDATE_RSP");
private String value;
}

View File

@@ -0,0 +1,70 @@
package com.ruoyi.rocketmq.mapper;
import com.ruoyi.rocketmq.domain.RmInitialMonitorItem;
import java.util.List;
/**
* 基础监控项Mapper接口
*
* @author gyt
* @date 2025-09-10
*/
public interface RmInitialMonitorItemMapper
{
/**
* 查询基础监控项
*
* @param id 基础监控项主键
* @return 基础监控项
*/
public RmInitialMonitorItem selectRmInitialMonitorItemById(Long id);
/**
* 查询基础监控项列表
*
* @param rmInitialMonitorItem 基础监控项
* @return 基础监控项集合
*/
public List<RmInitialMonitorItem> selectRmInitialMonitorItemList(RmInitialMonitorItem rmInitialMonitorItem);
/**
* 新增基础监控项
*
* @param rmInitialMonitorItem 基础监控项
* @return 结果
*/
public int insertRmInitialMonitorItem(RmInitialMonitorItem rmInitialMonitorItem);
/**
* 修改基础监控项
*
* @param rmInitialMonitorItem 基础监控项
* @return 结果
*/
public int updateRmInitialMonitorItem(RmInitialMonitorItem rmInitialMonitorItem);
/**
* 删除基础监控项
*
* @param id 基础监控项主键
* @return 结果
*/
public int deleteRmInitialMonitorItemById(Long id);
/**
* 批量删除基础监控项
*
* @param ids 需要删除的数据主键集合
* @return 结果
*/
public int deleteRmInitialMonitorItemByIds(Long[] ids);
/**
* 批量查询基础监控项
*
* @param ids 基础监控项主键
* @return 基础监控项
*/
public List<RmInitialMonitorItem> selectRmInitialMonitorItemByIds(Long[] ids);
}

View File

@@ -0,0 +1,61 @@
package com.ruoyi.rocketmq.mapper;
import java.util.List;
import com.ruoyi.rocketmq.domain.RmMonitorPolicy;
/**
* 资源监控策略Mapper接口
*
* @author gyt
* @date 2025-09-10
*/
public interface RmMonitorPolicyMapper
{
/**
* 查询资源监控策略
*
* @param id 资源监控策略主键
* @return 资源监控策略
*/
public RmMonitorPolicy selectRmMonitorPolicyById(Long id);
/**
* 查询资源监控策略列表
*
* @param rmMonitorPolicy 资源监控策略
* @return 资源监控策略集合
*/
public List<RmMonitorPolicy> selectRmMonitorPolicyList(RmMonitorPolicy rmMonitorPolicy);
/**
* 新增资源监控策略
*
* @param rmMonitorPolicy 资源监控策略
* @return 结果
*/
public int insertRmMonitorPolicy(RmMonitorPolicy rmMonitorPolicy);
/**
* 修改资源监控策略
*
* @param rmMonitorPolicy 资源监控策略
* @return 结果
*/
public int updateRmMonitorPolicy(RmMonitorPolicy rmMonitorPolicy);
/**
* 删除资源监控策略
*
* @param id 资源监控策略主键
* @return 结果
*/
public int deleteRmMonitorPolicyById(Long id);
/**
* 批量删除资源监控策略
*
* @param ids 需要删除的数据主键集合
* @return 结果
*/
public int deleteRmMonitorPolicyByIds(Long[] ids);
}

View File

@@ -0,0 +1,61 @@
package com.ruoyi.rocketmq.mapper;
import java.util.List;
import com.ruoyi.rocketmq.domain.RmMonitorTemplate;
/**
* 监控模板Mapper接口
*
* @author gyt
* @date 2025-09-09
*/
public interface RmMonitorTemplateMapper
{
/**
* 查询监控模板
*
* @param id 监控模板主键
* @return 监控模板
*/
public RmMonitorTemplate selectRmMonitorTemplateById(Long id);
/**
* 查询监控模板列表
*
* @param rmMonitorTemplate 监控模板
* @return 监控模板集合
*/
public List<RmMonitorTemplate> selectRmMonitorTemplateList(RmMonitorTemplate rmMonitorTemplate);
/**
* 新增监控模板
*
* @param rmMonitorTemplate 监控模板
* @return 结果
*/
public int insertRmMonitorTemplate(RmMonitorTemplate rmMonitorTemplate);
/**
* 修改监控模板
*
* @param rmMonitorTemplate 监控模板
* @return 结果
*/
public int updateRmMonitorTemplate(RmMonitorTemplate rmMonitorTemplate);
/**
* 删除监控模板
*
* @param id 监控模板主键
* @return 结果
*/
public int deleteRmMonitorTemplateById(Long id);
/**
* 批量删除监控模板
*
* @param ids 需要删除的数据主键集合
* @return 结果
*/
public int deleteRmMonitorTemplateByIds(Long[] ids);
}

View File

@@ -0,0 +1,65 @@
package com.ruoyi.rocketmq.mapper;
import com.ruoyi.rocketmq.domain.RmTemplateLinux;
import org.springframework.data.repository.query.Param;
import java.util.List;
/**
* Linux系统监控项Mapper接口
*
* @author gyt
* @date 2025-09-09
*/
public interface RmTemplateLinuxMapper
{
/**
* 查询Linux系统监控项
*
* @param id Linux系统监控项主键
* @return Linux系统监控项
*/
public RmTemplateLinux selectRmTemplateLinuxById(Long id);
/**
* 查询Linux系统监控项列表
*
* @param rmTemplateLinux Linux系统监控项
* @return Linux系统监控项集合
*/
public List<RmTemplateLinux> selectRmTemplateLinuxList(RmTemplateLinux rmTemplateLinux);
/**
* 新增Linux系统监控项
*
* @param rmTemplateLinux Linux系统监控项
* @return 结果
*/
public int insertRmTemplateLinux(RmTemplateLinux rmTemplateLinux);
/**
* 修改Linux系统监控项
*
* @param rmTemplateLinux Linux系统监控项
* @return 结果
*/
public int updateRmTemplateLinux(RmTemplateLinux rmTemplateLinux);
/**
* 删除Linux系统监控项
*
* @param id Linux系统监控项主键
* @return 结果
*/
public int deleteRmTemplateLinuxById(Long id);
/**
* 批量删除Linux系统监控项
*
* @param ids 需要删除的数据主键集合
* @return 结果
*/
public int deleteRmTemplateLinuxByIds(Long[] ids);
void batchInsertRmTemplateLinux(@Param("list") List<RmTemplateLinux> linuxItems);
}

View File

@@ -0,0 +1,69 @@
package com.ruoyi.rocketmq.mapper;
import com.ruoyi.rocketmq.domain.RmTemplateSwitch;
import org.springframework.data.repository.query.Param;
import java.util.List;
/**
* 交换机监控模板Mapper接口
*
* @author gyt
* @date 2025-09-09
*/
public interface RmTemplateSwitchMapper
{
/**
* 查询交换机监控模板
*
* @param id 交换机监控模板主键
* @return 交换机监控模板
*/
public RmTemplateSwitch selectRmTemplateSwitchById(Long id);
/**
* 查询交换机监控模板列表
*
* @param rmTemplateSwitch 交换机监控模板
* @return 交换机监控模板集合
*/
public List<RmTemplateSwitch> selectRmTemplateSwitchList(RmTemplateSwitch rmTemplateSwitch);
/**
* 新增交换机监控模板
*
* @param rmTemplateSwitch 交换机监控模板
* @return 结果
*/
public int insertRmTemplateSwitch(RmTemplateSwitch rmTemplateSwitch);
/**
* 修改交换机监控模板
*
* @param rmTemplateSwitch 交换机监控模板
* @return 结果
*/
public int updateRmTemplateSwitch(RmTemplateSwitch rmTemplateSwitch);
/**
* 删除交换机监控模板
*
* @param id 交换机监控模板主键
* @return 结果
*/
public int deleteRmTemplateSwitchById(Long id);
/**
* 批量删除交换机监控模板
*
* @param ids 需要删除的数据主键集合
* @return 结果
*/
public int deleteRmTemplateSwitchByIds(Long[] ids);
/**
* 批量新增交换机监控模板信息
* @param switchItems
*/
void batchInsertRmTemplateSwitch(@Param("list") List<RmTemplateSwitch> switchItems);
}

View File

@@ -23,4 +23,8 @@ public class ConsumerMode {
private int consumeThreadMax; private int consumeThreadMax;
@Value("${suning.rocketmq.conumer.consumeMessageBatchMaxSize}") @Value("${suning.rocketmq.conumer.consumeMessageBatchMaxSize}")
private int consumeMessageBatchMaxSize; private int consumeMessageBatchMaxSize;
@Value("${suning.rocketmq.producer.agentTopic}")
private String agentTopic;
@Value("${suning.rocketmq.producer.agentGroup}")
private String agentGroup;
} }

View File

@@ -14,6 +14,10 @@ import org.springframework.context.annotation.Configuration;
public class ProducerMode { public class ProducerMode {
@Value("${suning.rocketmq.producer.groupName}") @Value("${suning.rocketmq.producer.groupName}")
private String groupName; private String groupName;
@Value("${suning.rocketmq.producer.agentTopic}")
private String agentTopic;
@Value("${suning.rocketmq.producer.agentGroup}")
private String agentGroup;
@Value("${suning.rocketmq.namesrvAddr}") @Value("${suning.rocketmq.namesrvAddr}")
private String namesrvAddr; private String namesrvAddr;
@Value("${suning.rocketmq.producer.maxMessageSize}") @Value("${suning.rocketmq.producer.maxMessageSize}")

View File

@@ -0,0 +1,69 @@
package com.ruoyi.rocketmq.service;
import com.ruoyi.rocketmq.domain.RmInitialMonitorItem;
import java.util.List;
import java.util.Map;
/**
* 基础监控项Service接口
*
* @author gyt
* @date 2025-09-10
*/
public interface IRmInitialMonitorItemService
{
/**
* 查询基础监控项
*
* @param id 基础监控项主键
* @return 基础监控项
*/
public RmInitialMonitorItem selectRmInitialMonitorItemById(Long id);
/**
* 查询基础监控项列表
*
* @param rmInitialMonitorItem 基础监控项
* @return 基础监控项集合
*/
public List<RmInitialMonitorItem> selectRmInitialMonitorItemList(RmInitialMonitorItem rmInitialMonitorItem);
/**
* 新增基础监控项
*
* @param rmInitialMonitorItem 基础监控项
* @return 结果
*/
public int insertRmInitialMonitorItem(RmInitialMonitorItem rmInitialMonitorItem);
/**
* 修改基础监控项
*
* @param rmInitialMonitorItem 基础监控项
* @return 结果
*/
public int updateRmInitialMonitorItem(RmInitialMonitorItem rmInitialMonitorItem);
/**
* 批量删除基础监控项
*
* @param ids 需要删除的基础监控项主键集合
* @return 结果
*/
public int deleteRmInitialMonitorItemByIds(Long[] ids);
/**
* 删除基础监控项信息
*
* @param id 基础监控项主键
* @return 结果
*/
public int deleteRmInitialMonitorItemById(Long id);
/**
* 查询linux监控项列表
* @return
*/
Map<String, List<RmInitialMonitorItem>> selectAllMsgList(RmInitialMonitorItem rmInitialMonitorItem);
}

View File

@@ -0,0 +1,69 @@
package com.ruoyi.rocketmq.service;
import com.ruoyi.rocketmq.domain.RmMonitorPolicy;
import java.util.List;
import java.util.Map;
/**
* 资源监控策略Service接口
*
* @author gyt
* @date 2025-09-10
*/
public interface IRmMonitorPolicyService
{
/**
* 查询资源监控策略
*
* @param id 资源监控策略主键
* @return 资源监控策略
*/
public RmMonitorPolicy selectRmMonitorPolicyById(Long id);
/**
* 查询资源监控策略列表
*
* @param rmMonitorPolicy 资源监控策略
* @return 资源监控策略集合
*/
public List<RmMonitorPolicy> selectRmMonitorPolicyList(RmMonitorPolicy rmMonitorPolicy);
/**
* 新增资源监控策略
*
* @param rmMonitorPolicy 资源监控策略
* @return 结果
*/
public int insertRmMonitorPolicy(RmMonitorPolicy rmMonitorPolicy);
/**
* 修改资源监控策略
*
* @param rmMonitorPolicy 资源监控策略
* @return 结果
*/
public int updateRmMonitorPolicy(RmMonitorPolicy rmMonitorPolicy);
/**
* 批量删除资源监控策略
*
* @param ids 需要删除的资源监控策略主键集合
* @return 结果
*/
public int deleteRmMonitorPolicyByIds(Long[] ids);
/**
* 删除资源监控策略信息
*
* @param id 资源监控策略主键
* @return 结果
*/
public int deleteRmMonitorPolicyById(Long id);
int addRmMonitorPolicy(RmMonitorPolicy rmMonitorPolicy);
Map<String, Object> getRmMonitorPolicyMsgById(Long id);
int issuePolicy(Long id);
}

View File

@@ -0,0 +1,79 @@
package com.ruoyi.rocketmq.service;
import com.ruoyi.rocketmq.domain.RmMonitorTemplate;
import com.ruoyi.rocketmq.domain.vo.RmMonitorTemplateVo;
import java.util.List;
import java.util.Map;
/**
* 监控模板Service接口
*
* @author gyt
* @date 2025-09-09
*/
public interface IRmMonitorTemplateService
{
/**
* 查询监控模板
*
* @param id 监控模板主键
* @return 监控模板
*/
public RmMonitorTemplate selectRmMonitorTemplateById(Long id);
/**
* 查询监控模板列表
*
* @param rmMonitorTemplate 监控模板
* @return 监控模板集合
*/
public List<RmMonitorTemplate> selectRmMonitorTemplateList(RmMonitorTemplate rmMonitorTemplate);
/**
* 新增监控模板
*
* @param rmMonitorTemplate 监控模板
* @return 结果
*/
public int insertRmMonitorTemplate(RmMonitorTemplate rmMonitorTemplate);
/**
* 修改监控模板
*
* @param rmMonitorTemplate 监控模板
* @return 结果
*/
public int updateRmMonitorTemplate(RmMonitorTemplate rmMonitorTemplate);
/**
* 批量删除监控模板
*
* @param ids 需要删除的监控模板主键集合
* @return 结果
*/
public int deleteRmMonitorTemplateByIds(Long[] ids);
/**
* 删除监控模板信息
*
* @param id 监控模板主键
* @return 结果
*/
public int deleteRmMonitorTemplateById(Long id);
/**
* 新增
* @param rmMonitorTemplateVo
* @return
*/
public int addRmMonitorTemplate(RmMonitorTemplateVo rmMonitorTemplateVo);
/**
* 详情
* @param id
* @return
*/
Map<String, Object> getTemplateMsgById(Long id);
}

View File

@@ -0,0 +1,61 @@
package com.ruoyi.rocketmq.service;
import java.util.List;
import com.ruoyi.rocketmq.domain.RmTemplateLinux;
/**
* Linux系统监控项Service接口
*
* @author gyt
* @date 2025-09-09
*/
public interface IRmTemplateLinuxService
{
/**
* 查询Linux系统监控项
*
* @param id Linux系统监控项主键
* @return Linux系统监控项
*/
public RmTemplateLinux selectRmTemplateLinuxById(Long id);
/**
* 查询Linux系统监控项列表
*
* @param rmTemplateLinux Linux系统监控项
* @return Linux系统监控项集合
*/
public List<RmTemplateLinux> selectRmTemplateLinuxList(RmTemplateLinux rmTemplateLinux);
/**
* 新增Linux系统监控项
*
* @param rmTemplateLinux Linux系统监控项
* @return 结果
*/
public int insertRmTemplateLinux(RmTemplateLinux rmTemplateLinux);
/**
* 修改Linux系统监控项
*
* @param rmTemplateLinux Linux系统监控项
* @return 结果
*/
public int updateRmTemplateLinux(RmTemplateLinux rmTemplateLinux);
/**
* 批量删除Linux系统监控项
*
* @param ids 需要删除的Linux系统监控项主键集合
* @return 结果
*/
public int deleteRmTemplateLinuxByIds(Long[] ids);
/**
* 删除Linux系统监控项信息
*
* @param id Linux系统监控项主键
* @return 结果
*/
public int deleteRmTemplateLinuxById(Long id);
}

View File

@@ -0,0 +1,61 @@
package com.ruoyi.rocketmq.service;
import java.util.List;
import com.ruoyi.rocketmq.domain.RmTemplateSwitch;
/**
* 交换机监控模板Service接口
*
* @author gyt
* @date 2025-09-09
*/
public interface IRmTemplateSwitchService
{
/**
* 查询交换机监控模板
*
* @param id 交换机监控模板主键
* @return 交换机监控模板
*/
public RmTemplateSwitch selectRmTemplateSwitchById(Long id);
/**
* 查询交换机监控模板列表
*
* @param rmTemplateSwitch 交换机监控模板
* @return 交换机监控模板集合
*/
public List<RmTemplateSwitch> selectRmTemplateSwitchList(RmTemplateSwitch rmTemplateSwitch);
/**
* 新增交换机监控模板
*
* @param rmTemplateSwitch 交换机监控模板
* @return 结果
*/
public int insertRmTemplateSwitch(RmTemplateSwitch rmTemplateSwitch);
/**
* 修改交换机监控模板
*
* @param rmTemplateSwitch 交换机监控模板
* @return 结果
*/
public int updateRmTemplateSwitch(RmTemplateSwitch rmTemplateSwitch);
/**
* 批量删除交换机监控模板
*
* @param ids 需要删除的交换机监控模板主键集合
* @return 结果
*/
public int deleteRmTemplateSwitchByIds(Long[] ids);
/**
* 删除交换机监控模板信息
*
* @param id 交换机监控模板主键
* @return 结果
*/
public int deleteRmTemplateSwitchById(Long id);
}

View File

@@ -0,0 +1,162 @@
package com.ruoyi.rocketmq.service.impl;
import com.ruoyi.common.core.utils.DateUtils;
import com.ruoyi.rocketmq.domain.RmInitialMonitorItem;
import com.ruoyi.rocketmq.mapper.RmInitialMonitorItemMapper;
import com.ruoyi.rocketmq.service.IRmInitialMonitorItemService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/**
* 基础监控项Service业务层处理
*
* @author gyt
* @date 2025-09-10
*/
@Service
public class RmInitialMonitorItemServiceImpl implements IRmInitialMonitorItemService
{
@Autowired
private RmInitialMonitorItemMapper rmInitialMonitorItemMapper;
/**
* 查询基础监控项
*
* @param id 基础监控项主键
* @return 基础监控项
*/
@Override
public RmInitialMonitorItem selectRmInitialMonitorItemById(Long id)
{
return rmInitialMonitorItemMapper.selectRmInitialMonitorItemById(id);
}
/**
* 查询基础监控项列表
*
* @param rmInitialMonitorItem 基础监控项
* @return 基础监控项
*/
@Override
public List<RmInitialMonitorItem> selectRmInitialMonitorItemList(RmInitialMonitorItem rmInitialMonitorItem)
{
return rmInitialMonitorItemMapper.selectRmInitialMonitorItemList(rmInitialMonitorItem);
}
/**
* 新增基础监控项
*
* @param rmInitialMonitorItem 基础监控项
* @return 结果
*/
@Override
public int insertRmInitialMonitorItem(RmInitialMonitorItem rmInitialMonitorItem)
{
rmInitialMonitorItem.setCreateTime(DateUtils.getNowDate());
return rmInitialMonitorItemMapper.insertRmInitialMonitorItem(rmInitialMonitorItem);
}
/**
* 修改基础监控项
*
* @param rmInitialMonitorItem 基础监控项
* @return 结果
*/
@Override
public int updateRmInitialMonitorItem(RmInitialMonitorItem rmInitialMonitorItem)
{
rmInitialMonitorItem.setUpdateTime(DateUtils.getNowDate());
return rmInitialMonitorItemMapper.updateRmInitialMonitorItem(rmInitialMonitorItem);
}
/**
* 批量删除基础监控项
*
* @param ids 需要删除的基础监控项主键
* @return 结果
*/
@Override
public int deleteRmInitialMonitorItemByIds(Long[] ids)
{
return rmInitialMonitorItemMapper.deleteRmInitialMonitorItemByIds(ids);
}
/**
* 删除基础监控项信息
*
* @param id 基础监控项主键
* @return 结果
*/
@Override
public int deleteRmInitialMonitorItemById(Long id)
{
return rmInitialMonitorItemMapper.deleteRmInitialMonitorItemById(id);
}
/**
* 查询所有监控标识以及监控名称
* @param rmInitialMonitorItem
* @return
*/
@Override
public Map<String, List<RmInitialMonitorItem>> selectAllMsgList(RmInitialMonitorItem rmInitialMonitorItem) {
Map<String, List<RmInitialMonitorItem>> resultMap = new HashMap<>();
String resourceType = rmInitialMonitorItem.getResourceType();
String itemType = rmInitialMonitorItem.getItemType();
List<RmInitialMonitorItem> allItems = rmInitialMonitorItemMapper.selectRmInitialMonitorItemList(rmInitialMonitorItem);
if ("linux".equals(resourceType)) {
if ("monitorItem".equals(itemType)) {
// CPU信息
resultMap.put("cpu", filterItems(allItems, "CPU"));
// 其他系统信息
resultMap.put("other", filterItems(allItems, "OTHER"));
}
else if ("autodiscoverItem".equals(itemType)) {
// 挂载点信息
resultMap.put("point", filterItems(allItems, "POINT"));
// 网络接口信息
resultMap.put("net", filterItems(allItems, "NET"));
// 磁盘信息
resultMap.put("disk", filterItems(allItems, "DISK"));
// Docker容器信息
resultMap.put("docker", filterItems(allItems, "DOCKER"));
}
}
else if ("switch".equals(resourceType)) {
if ("monitorItem".equals(itemType)) {
// 系统信息
resultMap.put("system", filterItems(allItems, "SYSTEM"));
// MPU信息
resultMap.put("mpu", filterItems(allItems, "MPU"));
// 电源信息
resultMap.put("power", filterItems(allItems, "POWERSOURCE"));
}
else if ("autodiscoverItem".equals(itemType)) {
// 网络端口信息
resultMap.put("netport", filterItems(allItems, "NETPORT"));
// 光模块信息
resultMap.put("lightmodule", filterItems(allItems, "LIGHTMODULE"));
// 风扇信息
resultMap.put("fan", filterItems(allItems, "FAN"));
}
}
return resultMap;
}
/**
* 通用过滤方法
*/
private List<RmInitialMonitorItem> filterItems(List<RmInitialMonitorItem> items, String dataType) {
return items.stream()
.filter(item -> dataType.equals(item.getDataType()))
.collect(Collectors.toList());
}
}

View File

@@ -0,0 +1,303 @@
package com.ruoyi.rocketmq.service.impl;
import com.alibaba.fastjson.JSONObject;
import com.ruoyi.common.core.constant.SecurityConstants;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.common.core.utils.DateUtils;
import com.ruoyi.common.core.utils.StringUtils;
import com.ruoyi.rocketmq.domain.*;
import com.ruoyi.rocketmq.domain.vo.CollectVo;
import com.ruoyi.rocketmq.domain.vo.RmMonitorPolicyVo;
import com.ruoyi.rocketmq.mapper.RmMonitorPolicyMapper;
import com.ruoyi.rocketmq.mapper.RmMonitorTemplateMapper;
import com.ruoyi.rocketmq.mapper.RmTemplateLinuxMapper;
import com.ruoyi.rocketmq.model.ProducerMode;
import com.ruoyi.rocketmq.producer.MessageProducer;
import com.ruoyi.rocketmq.service.IRmMonitorPolicyService;
import com.ruoyi.rocketmq.utils.DataProcessUtil;
import com.ruoyi.system.api.RemoteRevenueConfigService;
import com.ruoyi.system.api.domain.RmResourceGroupRemote;
import com.ruoyi.system.api.domain.RmResourceRegistrationRemote;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import java.util.*;
/**
* 资源监控策略Service业务层处理
*
* @author gyt
* @date 2025-09-10
*/
@Service
@Slf4j
public class RmMonitorPolicyServiceImpl implements IRmMonitorPolicyService
{
@Autowired
private ProducerMode producerMode;
@Autowired
private RmMonitorPolicyMapper rmMonitorPolicyMapper;
@Autowired
private RmTemplateLinuxMapper rmTemplateLinuxMapper;
@Autowired
private RmMonitorTemplateMapper rmMonitorTemplateMapper;
@Autowired
private RemoteRevenueConfigService remoteRevenueConfigService;
/**
* 查询资源监控策略
*
* @param id 资源监控策略主键
* @return 资源监控策略
*/
@Override
public RmMonitorPolicy selectRmMonitorPolicyById(Long id)
{
return rmMonitorPolicyMapper.selectRmMonitorPolicyById(id);
}
/**
* 查询资源监控策略列表
*
* @param rmMonitorPolicy 资源监控策略
* @return 资源监控策略
*/
@Override
public List<RmMonitorPolicy> selectRmMonitorPolicyList(RmMonitorPolicy rmMonitorPolicy)
{
return rmMonitorPolicyMapper.selectRmMonitorPolicyList(rmMonitorPolicy);
}
/**
* 新增资源监控策略
*
* @param rmMonitorPolicy 资源监控策略
* @return 结果
*/
@Override
public int insertRmMonitorPolicy(RmMonitorPolicy rmMonitorPolicy)
{
rmMonitorPolicy.setCreateTime(DateUtils.getNowDate());
return rmMonitorPolicyMapper.insertRmMonitorPolicy(rmMonitorPolicy);
}
/**
* 修改资源监控策略
*
* @param rmMonitorPolicy 资源监控策略
* @return 结果
*/
@Override
public int updateRmMonitorPolicy(RmMonitorPolicy rmMonitorPolicy)
{
rmMonitorPolicy.setUpdateTime(DateUtils.getNowDate());
return rmMonitorPolicyMapper.updateRmMonitorPolicy(rmMonitorPolicy);
}
/**
* 批量删除资源监控策略
*
* @param ids 需要删除的资源监控策略主键
* @return 结果
*/
@Override
public int deleteRmMonitorPolicyByIds(Long[] ids)
{
return rmMonitorPolicyMapper.deleteRmMonitorPolicyByIds(ids);
}
/**
* 删除资源监控策略信息
*
* @param id 资源监控策略主键
* @return 结果
*/
@Override
public int deleteRmMonitorPolicyById(Long id)
{
return rmMonitorPolicyMapper.deleteRmMonitorPolicyById(id);
}
@Override
public int addRmMonitorPolicy(RmMonitorPolicy rmMonitorPolicy) {
rmMonitorPolicyMapper.insertRmMonitorPolicy(rmMonitorPolicy);
// 模板绑定资源组信息
RmMonitorTemplate rmMonitorTemplate = new RmMonitorTemplate();
rmMonitorTemplate.setId(rmMonitorPolicy.getTemplateId());
rmMonitorTemplate.setResourceGroupId(rmMonitorPolicy.getResourceGroupId());
rmMonitorTemplateMapper.updateRmMonitorTemplate(rmMonitorTemplate);
// 拿到采集周期
List<RmMonitorPolicyVo> collectionAndIdList = rmMonitorPolicy.getCollectionAndIdList();
if(!collectionAndIdList.isEmpty()){
for (RmMonitorPolicyVo rmMonitorPolicyVo : collectionAndIdList) {
// 添加采集周期
RmTemplateLinux rmTemplateLinux = new RmTemplateLinux();
rmTemplateLinux.setId(rmMonitorPolicyVo.getId());
rmTemplateLinux.setCollectionCycle(rmMonitorPolicyVo.getCollectionCycle());
rmTemplateLinuxMapper.updateRmTemplateLinux(rmTemplateLinux);
}
}
return 1;
}
/**
* 根据id查询监控策略详情
* @param id
* @return
*/
@Override
public Map<String, Object> getRmMonitorPolicyMsgById(Long id) {
Map<String, Object> result = new HashMap<>();
// 1. 获取资源监控策略基础信息
RmMonitorPolicy rmMonitorPolicy = rmMonitorPolicyMapper.selectRmMonitorPolicyById(id);
if(rmMonitorPolicy != null){
rmMonitorPolicy.setResourceGroupName(DataProcessUtil.getResourceGroupNameById(rmMonitorPolicy.getResourceGroupId()));
result.put("policy", rmMonitorPolicy);
// 模板id
Long templateId = rmMonitorPolicy.getTemplateId();
// 2. 处理Linux模板数据
DataProcessUtil.processLinuxTemplateData(templateId, result);
// 3. 处理Switch模板数据
DataProcessUtil.processSwitchTemplateData(templateId, result);
}
return result;
}
/**
* 下发策略
* @param id
* @return
*/
@Override
public int issuePolicy(Long id) {
try {
// 获取策略详情和资源设备
RmMonitorPolicy policy = rmMonitorPolicyMapper.selectRmMonitorPolicyById(id);
if (policy == null) {
log.error("策略不存在id: {}", id);
return 0;
}
List<RmResourceRegistrationRemote> devices = getResourceDevices(policy.getResourceGroupId());
if (CollectionUtils.isEmpty(devices)) {
return 0;
}
// 构建并发送采集配置
Map<String, Object> policyDetails = getRmMonitorPolicyMsgById(id);
List<CollectVo> collectVos = buildCollectConfigurations(policyDetails);
sendConfigurationsToDevices(devices, collectVos);
// 更新策略状态为已下发
RmMonitorPolicy policyUpdate = new RmMonitorPolicy();
policyUpdate.setId(id);
policyUpdate.setStatus("1");
rmMonitorPolicyMapper.updateRmMonitorPolicy(policyUpdate);
return 1;
} catch (Exception e) {
log.error("下发策略失败id: {}", id, e);
return 0;
}
}
/**
* 获取资源设备列表
*/
private List<RmResourceRegistrationRemote> getResourceDevices(Long resourceGroupId) {
R<RmResourceGroupRemote> groupResponse = remoteRevenueConfigService
.getResourceGroupMsgById(resourceGroupId, SecurityConstants.INNER);
if (groupResponse == null || groupResponse.getData() == null
|| StringUtils.isEmpty(groupResponse.getData().getIncludedDevicesId())) {
log.error("资源组信息不完整resourceGroupId: {}", resourceGroupId);
return Collections.emptyList();
}
String[] deviceIds = groupResponse.getData().getIncludedDevicesId().split(",");
R<List<RmResourceRegistrationRemote>> devicesResponse = remoteRevenueConfigService
.getRegistrationByIds(deviceIds, SecurityConstants.INNER);
return devicesResponse != null ? devicesResponse.getData() : Collections.emptyList();
}
/**
* 构建采集配置
*/
private List<CollectVo> buildCollectConfigurations(Map<String, Object> policyDetails) {
List<CollectVo> collectVos = new ArrayList<>();
// 处理Linux配置
if (policyDetails.containsKey("linux")) {
Map<String, List<RmTemplateLinux>> linuxConfigs = (Map<String, List<RmTemplateLinux>>) policyDetails.get("linux");
processConfigurations(linuxConfigs, collectVos, new String[]{"cpu", "other", "point", "net", "disk", "docker"});
}
// 处理Switch配置
if (policyDetails.containsKey("switch")) {
Map<String, List<RmTemplateSwitch>> switchConfigs = (Map<String, List<RmTemplateSwitch>>) policyDetails.get("switch");
processConfigurations(switchConfigs, collectVos, new String[]{"system", "mpu", "power", "netport", "lightmodule", "fan"});
}
return collectVos;
}
/**
* 通用配置处理方法
*/
private <T> void processConfigurations(Map<String, List<T>> configs, List<CollectVo> collectVos, String[] types) {
for (String type : types) {
if (configs.get(type) != null) {
for (T config : configs.get(type)) {
CollectVo vo = new CollectVo();
vo.setCollect(true);
if (config instanceof RmTemplateLinux) {
RmTemplateLinux linuxConfig = (RmTemplateLinux) config;
vo.setType(linuxConfig.getMetricKey());
vo.setInterval(linuxConfig.getCollectionCycle());
} else if (config instanceof RmTemplateSwitch) {
RmTemplateSwitch switchConfig = (RmTemplateSwitch) config;
vo.setType(switchConfig.getMetricKey());
vo.setInterval(switchConfig.getCollectionCycle());
}
collectVos.add(vo);
}
}
}
}
/**
* 发送配置到设备
*/
private void sendConfigurationsToDevices(List<RmResourceRegistrationRemote> devices, List<CollectVo> collectVos) {
MessageProducer messageProducer = new MessageProducer();
String configJson = JSONObject.toJSONString(collectVos);
for (RmResourceRegistrationRemote device : devices) {
try {
DeviceMessage message = new DeviceMessage();
message.setClientId(device.getHardwareSn());
message.setData(configJson);
message.setDataType("collects");
messageProducer.sendAsyncProducerMessage(
producerMode.getAgentTopic(),
"collects",
"title",
JSONObject.toJSONString(message)
);
} catch (Exception e) {
log.error("发送设备配置失败deviceId: {}", device.getHardwareSn(), e);
}
}
}
}

View File

@@ -0,0 +1,214 @@
package com.ruoyi.rocketmq.service.impl;
import com.ruoyi.common.core.utils.DateUtils;
import com.ruoyi.rocketmq.domain.RmInitialMonitorItem;
import com.ruoyi.rocketmq.domain.RmMonitorTemplate;
import com.ruoyi.rocketmq.domain.RmTemplateLinux;
import com.ruoyi.rocketmq.domain.RmTemplateSwitch;
import com.ruoyi.rocketmq.domain.vo.RmMonitorTemplateVo;
import com.ruoyi.rocketmq.mapper.RmInitialMonitorItemMapper;
import com.ruoyi.rocketmq.mapper.RmMonitorTemplateMapper;
import com.ruoyi.rocketmq.mapper.RmTemplateLinuxMapper;
import com.ruoyi.rocketmq.mapper.RmTemplateSwitchMapper;
import com.ruoyi.rocketmq.service.IRmMonitorTemplateService;
import com.ruoyi.rocketmq.utils.DataProcessUtil;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/**
* 监控模板Service业务层处理
*
* @author gyt
* @date 2025-09-09
*/
@Service
public class RmMonitorTemplateServiceImpl implements IRmMonitorTemplateService
{
@Autowired
private RmMonitorTemplateMapper rmMonitorTemplateMapper;
@Autowired
private RmTemplateLinuxMapper rmTemplateLinuxMapper;
@Autowired
private RmTemplateSwitchMapper rmTemplateSwitchMapper;
@Autowired
private RmInitialMonitorItemMapper rmInitialMonitorItemMapper;
/**
* 查询监控模板
*
* @param id 监控模板主键
* @return 监控模板
*/
@Override
public RmMonitorTemplate selectRmMonitorTemplateById(Long id)
{
return rmMonitorTemplateMapper.selectRmMonitorTemplateById(id);
}
/**
* 查询监控模板列表
*
* @param rmMonitorTemplate 监控模板
* @return 监控模板
*/
@Override
public List<RmMonitorTemplate> selectRmMonitorTemplateList(RmMonitorTemplate rmMonitorTemplate)
{
return rmMonitorTemplateMapper.selectRmMonitorTemplateList(rmMonitorTemplate);
}
/**
* 新增监控模板
*
* @param rmMonitorTemplate 监控模板
* @return 结果
*/
@Override
public int insertRmMonitorTemplate(RmMonitorTemplate rmMonitorTemplate)
{
rmMonitorTemplate.setCreateTime(DateUtils.getNowDate());
return rmMonitorTemplateMapper.insertRmMonitorTemplate(rmMonitorTemplate);
}
/**
* 修改监控模板
*
* @param rmMonitorTemplate 监控模板
* @return 结果
*/
@Override
public int updateRmMonitorTemplate(RmMonitorTemplate rmMonitorTemplate)
{
rmMonitorTemplate.setUpdateTime(DateUtils.getNowDate());
return rmMonitorTemplateMapper.updateRmMonitorTemplate(rmMonitorTemplate);
}
/**
* 批量删除监控模板
*
* @param ids 需要删除的监控模板主键
* @return 结果
*/
@Override
public int deleteRmMonitorTemplateByIds(Long[] ids)
{
return rmMonitorTemplateMapper.deleteRmMonitorTemplateByIds(ids);
}
/**
* 删除监控模板信息
*
* @param id 监控模板主键
* @return 结果
*/
@Override
public int deleteRmMonitorTemplateById(Long id)
{
return rmMonitorTemplateMapper.deleteRmMonitorTemplateById(id);
}
@Override
@Transactional(rollbackFor = Exception.class)
public int addRmMonitorTemplate(RmMonitorTemplateVo rmMonitorTemplateVo) {
RmMonitorTemplate rmMonitorTemplate = new RmMonitorTemplate();
BeanUtils.copyProperties(rmMonitorTemplateVo, rmMonitorTemplate);
rmMonitorTemplateMapper.insertRmMonitorTemplate(rmMonitorTemplate);
Long templateId = rmMonitorTemplate.getId();
// linux系统信息
if("linux".equals(rmMonitorTemplateVo.getResourceType())){
// 根据监控信息id查询详细信息
List<RmInitialMonitorItem> monitorItems = rmInitialMonitorItemMapper.selectRmInitialMonitorItemByIds(rmMonitorTemplateVo.getMonitorIds());
// 批量准备插入数据
List<RmTemplateLinux> linuxItems = monitorItems.stream()
.map(item -> {
RmTemplateLinux linuxItem = new RmTemplateLinux();
linuxItem.setTemplateId(templateId);
linuxItem.setMetricKey(item.getMetricKey());
linuxItem.setMetricName(item.getMetricName());
linuxItem.setDataType(item.getDataType());
linuxItem.setItemType(item.getItemType());
return linuxItem;
})
.collect(Collectors.toList());
// 批量插入
if(!linuxItems.isEmpty()) {
rmTemplateLinuxMapper.batchInsertRmTemplateLinux(linuxItems);
int monitorCount = (int) linuxItems.stream().filter(r -> "monitorItem".equals(r.getItemType())).count();
int autoDiscoverCount = (int) linuxItems.stream().filter(r -> "autoDiscoverItem".equals(r.getItemType())).count();
RmMonitorTemplate monitorTemplate = new RmMonitorTemplate();
monitorTemplate.setId(templateId);
monitorTemplate.setMonitorItems(monitorCount + "");
monitorTemplate.setDiscoveryRules(autoDiscoverCount + "");
monitorTemplate.setResourcyType("linux");
rmMonitorTemplateMapper.updateRmMonitorTemplate(monitorTemplate);
}
}
// 华为交换机信息
if("switch".equals(rmMonitorTemplateVo.getResourceType())){
// 根据监控信息id查询详细信息
List<RmInitialMonitorItem> monitorItems = rmInitialMonitorItemMapper.selectRmInitialMonitorItemByIds(rmMonitorTemplateVo.getMonitorIds());
// 批量准备插入数据
List<RmTemplateSwitch> switchItems = monitorItems.stream()
.map(item -> {
RmTemplateSwitch switchItem = new RmTemplateSwitch();
switchItem.setTemplateId(templateId);
switchItem.setMetricKey(item.getMetricKey());
switchItem.setMetricName(item.getMetricName());
switchItem.setOid(item.getOid());
switchItem.setFilterValue(item.getFilterValue());
switchItem.setSwitchDescription(item.getMonitorDescription());
switchItem.setDataType(item.getDataType());
switchItem.setItemType(item.getItemType());
return switchItem;
})
.collect(Collectors.toList());
// 批量插入
if(!switchItems.isEmpty()) {
rmTemplateSwitchMapper.batchInsertRmTemplateSwitch(switchItems);
int monitorCount = (int) switchItems.stream().filter(r -> "monitorItem".equals(r.getItemType())).count();
int autoDiscoverCount = (int) switchItems.stream().filter(r -> "autoDiscoverItem".equals(r.getItemType())).count();
RmMonitorTemplate monitorTemplate = new RmMonitorTemplate();
monitorTemplate.setId(templateId);
monitorTemplate.setMonitorItems(monitorCount + "");
monitorTemplate.setDiscoveryRules(autoDiscoverCount + "");
monitorTemplate.setResourcyType("switch");
rmMonitorTemplateMapper.updateRmMonitorTemplate(monitorTemplate);
}
}
return 1;
}
/**
* 获取监控模板详情
* @param id
* @return
*/
@Override
public Map<String, Object> getTemplateMsgById(Long id) {
Map<String, Object> result = new HashMap<>();
// 1. 获取模板基础信息
RmMonitorTemplate template = rmMonitorTemplateMapper.selectRmMonitorTemplateById(id);
if(template.getResourceGroupId() != null){
template.setResourceGroupName(DataProcessUtil.getResourceGroupNameById(template.getResourceGroupId()));
}
result.put("template", template);
// 2. 处理Linux模板数据
DataProcessUtil.processLinuxTemplateData(id, result);
// 3. 处理Switch模板数据
DataProcessUtil.processSwitchTemplateData(id, result);
return result;
}
}

View File

@@ -0,0 +1,96 @@
package com.ruoyi.rocketmq.service.impl;
import java.util.List;
import com.ruoyi.common.core.utils.DateUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.ruoyi.rocketmq.mapper.RmTemplateLinuxMapper;
import com.ruoyi.rocketmq.domain.RmTemplateLinux;
import com.ruoyi.rocketmq.service.IRmTemplateLinuxService;
/**
* Linux系统监控项Service业务层处理
*
* @author gyt
* @date 2025-09-09
*/
@Service
public class RmTemplateLinuxServiceImpl implements IRmTemplateLinuxService
{
@Autowired
private RmTemplateLinuxMapper rmTemplateLinuxMapper;
/**
* 查询Linux系统监控项
*
* @param id Linux系统监控项主键
* @return Linux系统监控项
*/
@Override
public RmTemplateLinux selectRmTemplateLinuxById(Long id)
{
return rmTemplateLinuxMapper.selectRmTemplateLinuxById(id);
}
/**
* 查询Linux系统监控项列表
*
* @param rmTemplateLinux Linux系统监控项
* @return Linux系统监控项
*/
@Override
public List<RmTemplateLinux> selectRmTemplateLinuxList(RmTemplateLinux rmTemplateLinux)
{
return rmTemplateLinuxMapper.selectRmTemplateLinuxList(rmTemplateLinux);
}
/**
* 新增Linux系统监控项
*
* @param rmTemplateLinux Linux系统监控项
* @return 结果
*/
@Override
public int insertRmTemplateLinux(RmTemplateLinux rmTemplateLinux)
{
rmTemplateLinux.setCreateTime(DateUtils.getNowDate());
return rmTemplateLinuxMapper.insertRmTemplateLinux(rmTemplateLinux);
}
/**
* 修改Linux系统监控项
*
* @param rmTemplateLinux Linux系统监控项
* @return 结果
*/
@Override
public int updateRmTemplateLinux(RmTemplateLinux rmTemplateLinux)
{
rmTemplateLinux.setUpdateTime(DateUtils.getNowDate());
return rmTemplateLinuxMapper.updateRmTemplateLinux(rmTemplateLinux);
}
/**
* 批量删除Linux系统监控项
*
* @param ids 需要删除的Linux系统监控项主键
* @return 结果
*/
@Override
public int deleteRmTemplateLinuxByIds(Long[] ids)
{
return rmTemplateLinuxMapper.deleteRmTemplateLinuxByIds(ids);
}
/**
* 删除Linux系统监控项信息
*
* @param id Linux系统监控项主键
* @return 结果
*/
@Override
public int deleteRmTemplateLinuxById(Long id)
{
return rmTemplateLinuxMapper.deleteRmTemplateLinuxById(id);
}
}

View File

@@ -0,0 +1,96 @@
package com.ruoyi.rocketmq.service.impl;
import java.util.List;
import com.ruoyi.common.core.utils.DateUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.ruoyi.rocketmq.mapper.RmTemplateSwitchMapper;
import com.ruoyi.rocketmq.domain.RmTemplateSwitch;
import com.ruoyi.rocketmq.service.IRmTemplateSwitchService;
/**
* 交换机监控模板Service业务层处理
*
* @author gyt
* @date 2025-09-09
*/
@Service
public class RmTemplateSwitchServiceImpl implements IRmTemplateSwitchService
{
@Autowired
private RmTemplateSwitchMapper rmTemplateSwitchMapper;
/**
* 查询交换机监控模板
*
* @param id 交换机监控模板主键
* @return 交换机监控模板
*/
@Override
public RmTemplateSwitch selectRmTemplateSwitchById(Long id)
{
return rmTemplateSwitchMapper.selectRmTemplateSwitchById(id);
}
/**
* 查询交换机监控模板列表
*
* @param rmTemplateSwitch 交换机监控模板
* @return 交换机监控模板
*/
@Override
public List<RmTemplateSwitch> selectRmTemplateSwitchList(RmTemplateSwitch rmTemplateSwitch)
{
return rmTemplateSwitchMapper.selectRmTemplateSwitchList(rmTemplateSwitch);
}
/**
* 新增交换机监控模板
*
* @param rmTemplateSwitch 交换机监控模板
* @return 结果
*/
@Override
public int insertRmTemplateSwitch(RmTemplateSwitch rmTemplateSwitch)
{
rmTemplateSwitch.setCreateTime(DateUtils.getNowDate());
return rmTemplateSwitchMapper.insertRmTemplateSwitch(rmTemplateSwitch);
}
/**
* 修改交换机监控模板
*
* @param rmTemplateSwitch 交换机监控模板
* @return 结果
*/
@Override
public int updateRmTemplateSwitch(RmTemplateSwitch rmTemplateSwitch)
{
rmTemplateSwitch.setUpdateTime(DateUtils.getNowDate());
return rmTemplateSwitchMapper.updateRmTemplateSwitch(rmTemplateSwitch);
}
/**
* 批量删除交换机监控模板
*
* @param ids 需要删除的交换机监控模板主键
* @return 结果
*/
@Override
public int deleteRmTemplateSwitchByIds(Long[] ids)
{
return rmTemplateSwitchMapper.deleteRmTemplateSwitchByIds(ids);
}
/**
* 删除交换机监控模板信息
*
* @param id 交换机监控模板主键
* @return 结果
*/
@Override
public int deleteRmTemplateSwitchById(Long id)
{
return rmTemplateSwitchMapper.deleteRmTemplateSwitchById(id);
}
}

View File

@@ -0,0 +1,104 @@
package com.ruoyi.rocketmq.utils;
import com.ruoyi.common.core.constant.SecurityConstants;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.rocketmq.domain.RmTemplateLinux;
import com.ruoyi.rocketmq.domain.RmTemplateSwitch;
import com.ruoyi.rocketmq.mapper.RmMonitorTemplateMapper;
import com.ruoyi.rocketmq.mapper.RmTemplateLinuxMapper;
import com.ruoyi.rocketmq.mapper.RmTemplateSwitchMapper;
import com.ruoyi.system.api.RemoteRevenueConfigService;
import com.ruoyi.system.api.domain.RmResourceGroupRemote;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
@Slf4j
public class DataProcessUtil {
@Autowired
private RmMonitorTemplateMapper rmMonitorTemplateMapper;
@Autowired
private static RmTemplateLinuxMapper rmTemplateLinuxMapper;
@Autowired
private static RmTemplateSwitchMapper rmTemplateSwitchMapper;
@Autowired
private static RemoteRevenueConfigService remoteRevenueConfigService;
/**
* 补充资源组信息
*/
public static String getResourceGroupNameById(Long resourceGroupId) {
try {
R<RmResourceGroupRemote> resourceGroupResponse = remoteRevenueConfigService
.getResourceGroupMsgById(resourceGroupId, SecurityConstants.INNER);
if (resourceGroupResponse != null && resourceGroupResponse.getData() != null) {
return resourceGroupResponse.getData().getGroupName();
}
} catch (Exception e) {
log.error("获取资源组信息失败resourceGroupId: {}", resourceGroupId, e);
}
return null;
}
/**
* 处理Linux模板数据
*/
public static void processLinuxTemplateData(Long templateId, Map<String, Object> result) {
RmTemplateLinux query = new RmTemplateLinux();
query.setTemplateId(templateId);
List<RmTemplateLinux> linuxItems = rmTemplateLinuxMapper.selectRmTemplateLinuxList(query);
if (!linuxItems.isEmpty()) {
Map<String, List<RmTemplateLinux>> linuxData = new HashMap<>();
linuxData.put("cpu", filterItemsByDataType(linuxItems, "CPU"));
linuxData.put("other", filterItemsByDataType(linuxItems, "OTHER"));
linuxData.put("point", filterItemsByDataType(linuxItems, "POINT"));
linuxData.put("net", filterItemsByDataType(linuxItems, "NET"));
linuxData.put("disk", filterItemsByDataType(linuxItems, "DISK"));
linuxData.put("docker", filterItemsByDataType(linuxItems, "DOCKER"));
result.put("linux", linuxData);
}
}
/**
* 处理Switch模板数据
*/
public static void processSwitchTemplateData(Long templateId, Map<String, Object> result) {
RmTemplateSwitch query = new RmTemplateSwitch();
query.setTemplateId(templateId);
List<RmTemplateSwitch> switchItems = rmTemplateSwitchMapper.selectRmTemplateSwitchList(query);
if (!switchItems.isEmpty()) {
Map<String, List<RmTemplateSwitch>> switchData = new HashMap<>();
switchData.put("system", filterItemsByDataType(switchItems, "SYSTEM"));
switchData.put("mpu", filterItemsByDataType(switchItems, "MPU"));
switchData.put("power", filterItemsByDataType(switchItems, "POWERSOURCE"));
switchData.put("netport", filterItemsByDataType(switchItems, "NETPORT"));
switchData.put("lightmodule", filterItemsByDataType(switchItems, "LIGHTMODULE"));
switchData.put("fan", filterItemsByDataType(switchItems, "FAN"));
result.put("switch", switchData);
}
}
/**
* 通用过滤方法
*/
public static <T> List<T> filterItemsByDataType(List<T> items, String dataType) {
return items.stream()
.filter(item -> {
try {
Field dataTypeField = item.getClass().getDeclaredField("dataType");
dataTypeField.setAccessible(true);
return dataType.equals(dataTypeField.get(item));
} catch (Exception e) {
return false;
}
})
.collect(Collectors.toList());
}
}

View File

@@ -105,21 +105,21 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<insert id="insert" parameterType="InitialBandwidthTraffic"> <insert id="insert" parameterType="InitialBandwidthTraffic">
INSERT INTO ${tableName} ( INSERT INTO ${tableName} (
`name`, `mac`, `status`, `type`, ipV4, `in_dropped`, `out_dropped`, `name`, `mac`, `status`, `type`, ipV4, `in_dropped`, `out_dropped`,
`in_speed`, `out_speed`, create_by, update_by, client_id, create_time `in_speed`, `out_speed`, duplex, speed, create_by, update_by, client_id, create_time
) VALUES ( ) VALUES (
#{name}, #{mac}, #{status}, #{type}, #{ipV4}, #{inDropped}, #{outDropped}, #{name}, #{mac}, #{status}, #{type}, #{ipV4}, #{inDropped}, #{outDropped},
#{inSpeed}, #{outSpeed}, #{createBy}, #{updateBy}, #{clientId}, #{createTime} #{inSpeed}, #{outSpeed}, #{duplex}, #{speed}, #{createBy}, #{updateBy}, #{clientId}, #{createTime}
) )
</insert> </insert>
<insert id="batchInsert" parameterType="InitialBandwidthTraffic"> <insert id="batchInsert" parameterType="InitialBandwidthTraffic">
INSERT IGNORE INTO ${tableName} ( INSERT IGNORE INTO ${tableName} (
`name`, `mac`, `status`, `type`, ipV4, `in_dropped`, `out_dropped`, `name`, `mac`, `status`, `type`, ipV4, `in_dropped`, `out_dropped`,
`in_speed`, `out_speed`,create_by, update_by, client_id, create_time `in_speed`, `out_speed`,duplex, speed, create_by, update_by, client_id, create_time
) VALUES ) VALUES
<foreach collection="list" item="item" separator=","> <foreach collection="list" item="item" separator=",">
( (
#{item.name}, #{item.mac}, #{item.status}, #{item.type}, #{item.ipV4}, #{item.inDropped}, #{item.outDropped}, #{item.name}, #{item.mac}, #{item.status}, #{item.type}, #{item.ipV4}, #{item.inDropped}, #{item.outDropped},
#{item.inSpeed}, #{item.outSpeed}, #{item.createBy}, #{item.updateBy}, #{item.clientId}, #{item.createTime} #{item.inSpeed}, #{item.outSpeed}, #{item.duplex}, #{item.speed}, #{item.createBy}, #{item.updateBy}, #{item.clientId}, #{item.createTime}
) )
</foreach> </foreach>
</insert> </insert>

View File

@@ -0,0 +1,119 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.rocketmq.mapper.RmInitialMonitorItemMapper">
<resultMap type="RmInitialMonitorItem" id="RmInitialMonitorItemResult">
<result property="id" column="id" />
<result property="itemType" column="item_type" />
<result property="metricKey" column="metric_key" />
<result property="metricName" column="metric_name" />
<result property="oid" column="oid" />
<result property="filterValue" column="filter_value" />
<result property="monitorDescription" column="monitor_description" />
<result property="dataType" column="data_type" />
<result property="resourceType" column="resource_type" />
<result property="collectionCycle" column="collection_cycle" />
<result property="createTime" column="create_time" />
<result property="updateTime" column="update_time" />
<result property="createBy" column="create_by" />
<result property="updateBy" column="update_by" />
</resultMap>
<sql id="selectRmInitialMonitorItemVo">
select id, item_type, metric_key, metric_name, oid, filter_value, monitor_description, data_type, resource_type, collection_cycle, create_time, update_time, create_by, update_by from rm_initial_monitor_item
</sql>
<select id="selectRmInitialMonitorItemList" parameterType="RmInitialMonitorItem" resultMap="RmInitialMonitorItemResult">
<include refid="selectRmInitialMonitorItemVo"/>
<where>
<if test="itemType != null and itemType != ''"> and item_type = #{itemType}</if>
<if test="metricKey != null and metricKey != ''"> and metric_key = #{metricKey}</if>
<if test="metricName != null and metricName != ''"> and metric_name like concat('%', #{metricName}, '%')</if>
<if test="oid != null and oid != ''"> and oid = #{oid}</if>
<if test="filterValue != null and filterValue != ''"> and filter_value = #{filterValue}</if>
<if test="monitorDescription != null and monitorDescription != ''"> and monitor_description = #{monitorDescription}</if>
<if test="dataType != null and dataType != ''"> and data_type = #{dataType}</if>
<if test="resourceType != null and resourceType != ''"> and resource_type = #{resourceType}</if>
<if test="collectionCycle != null and collectionCycle != ''"> and collection_cycle = #{collectionCycle}</if>
</where>
</select>
<select id="selectRmInitialMonitorItemById" parameterType="Long" resultMap="RmInitialMonitorItemResult">
<include refid="selectRmInitialMonitorItemVo"/>
where id = #{id}
</select>
<insert id="insertRmInitialMonitorItem" parameterType="RmInitialMonitorItem" useGeneratedKeys="true" keyProperty="id">
insert into rm_initial_monitor_item
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="itemType != null and itemType != ''">item_type,</if>
<if test="metricKey != null and metricKey != ''">metric_key,</if>
<if test="metricName != null and metricName != ''">metric_name,</if>
<if test="oid != null">oid,</if>
<if test="filterValue != null">filter_value,</if>
<if test="monitorDescription != null">monitor_description,</if>
<if test="dataType != null and dataType != ''">data_type,</if>
<if test="resourceType != null and resourceType != ''">resource_type,</if>
<if test="collectionCycle != null">collection_cycle,</if>
<if test="createTime != null">create_time,</if>
<if test="updateTime != null">update_time,</if>
<if test="createBy != null">create_by,</if>
<if test="updateBy != null">update_by,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="itemType != null and itemType != ''">#{itemType},</if>
<if test="metricKey != null and metricKey != ''">#{metricKey},</if>
<if test="metricName != null and metricName != ''">#{metricName},</if>
<if test="oid != null">#{oid},</if>
<if test="filterValue != null">#{filterValue},</if>
<if test="monitorDescription != null">#{monitorDescription},</if>
<if test="dataType != null and dataType != ''">#{dataType},</if>
<if test="resourceType != null and resourceType != ''">#{resourceType},</if>
<if test="collectionCycle != null">#{collectionCycle},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateTime != null">#{updateTime},</if>
<if test="createBy != null">#{createBy},</if>
<if test="updateBy != null">#{updateBy},</if>
</trim>
</insert>
<update id="updateRmInitialMonitorItem" parameterType="RmInitialMonitorItem">
update rm_initial_monitor_item
<trim prefix="SET" suffixOverrides=",">
<if test="itemType != null and itemType != ''">item_type = #{itemType},</if>
<if test="metricKey != null and metricKey != ''">metric_key = #{metricKey},</if>
<if test="metricName != null and metricName != ''">metric_name = #{metricName},</if>
<if test="oid != null">oid = #{oid},</if>
<if test="filterValue != null">filter_value = #{filterValue},</if>
<if test="monitorDescription != null">monitor_description = #{monitorDescription},</if>
<if test="dataType != null and dataType != ''">data_type = #{dataType},</if>
<if test="resourceType != null and resourceType != ''">resource_type = #{resourceType},</if>
<if test="collectionCycle != null">collection_cycle = #{collectionCycle},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
<if test="createBy != null">create_by = #{createBy},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteRmInitialMonitorItemById" parameterType="Long">
delete from rm_initial_monitor_item where id = #{id}
</delete>
<delete id="deleteRmInitialMonitorItemByIds" parameterType="String">
delete from rm_initial_monitor_item where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
<select id="selectRmInitialMonitorItemByIds" parameterType="java.lang.Long" resultMap="RmInitialMonitorItemResult">
<include refid="selectRmInitialMonitorItemVo"/>
where id in
<foreach item="id" collection="monitorIds" open="(" separator="," close=")">
#{id}
</foreach>
</select>
</mapper>

View File

@@ -0,0 +1,97 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.rocketmq.mapper.RmMonitorPolicyMapper">
<resultMap type="RmMonitorPolicy" id="RmMonitorPolicyResult">
<result property="id" column="id" />
<result property="templateId" column="template_id" />
<result property="resourceGroupId" column="resource_group_id" />
<result property="policyName" column="policy_name" />
<result property="description" column="description" />
<result property="status" column="status" />
<result property="deployTime" column="deploy_time" />
<result property="createTime" column="create_time" />
<result property="updateTime" column="update_time" />
<result property="createBy" column="create_by" />
<result property="updateBy" column="update_by" />
</resultMap>
<sql id="selectRmMonitorPolicyVo">
select id, template_id, resource_group_id, policy_name, description, status, deploy_time, create_time, update_time, create_by, update_by from rm_monitor_policy
</sql>
<select id="selectRmMonitorPolicyList" parameterType="RmMonitorPolicy" resultMap="RmMonitorPolicyResult">
<include refid="selectRmMonitorPolicyVo"/>
<where>
<if test="templateId != null "> and template_id = #{templateId}</if>
<if test="resourceGroupId != null "> and resource_group_id = #{resourceGroupId}</if>
<if test="policyName != null and policyName != ''"> and policy_name like concat('%', #{policyName}, '%')</if>
<if test="description != null and description != ''"> and description = #{description}</if>
<if test="status != null and status != ''"> and status = #{status}</if>
<if test="deployTime != null "> and deploy_time = #{deployTime}</if>
</where>
</select>
<select id="selectRmMonitorPolicyById" parameterType="Long" resultMap="RmMonitorPolicyResult">
<include refid="selectRmMonitorPolicyVo"/>
where id = #{id}
</select>
<insert id="insertRmMonitorPolicy" parameterType="RmMonitorPolicy" useGeneratedKeys="true" keyProperty="id">
insert into rm_monitor_policy
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="templateId != null">template_id,</if>
<if test="resourceGroupId != null">resource_group_id,</if>
<if test="policyName != null and policyName != ''">policy_name,</if>
<if test="description != null">description,</if>
<if test="status != null and status != ''">status,</if>
<if test="deployTime != null">deploy_time,</if>
<if test="createTime != null">create_time,</if>
<if test="updateTime != null">update_time,</if>
<if test="createBy != null">create_by,</if>
<if test="updateBy != null">update_by,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="templateId != null">#{templateId},</if>
<if test="resourceGroupId != null">#{resourceGroupId},</if>
<if test="policyName != null and policyName != ''">#{policyName},</if>
<if test="description != null">#{description},</if>
<if test="status != null and status != ''">#{status},</if>
<if test="deployTime != null">#{deployTime},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateTime != null">#{updateTime},</if>
<if test="createBy != null">#{createBy},</if>
<if test="updateBy != null">#{updateBy},</if>
</trim>
</insert>
<update id="updateRmMonitorPolicy" parameterType="RmMonitorPolicy">
update rm_monitor_policy
<trim prefix="SET" suffixOverrides=",">
<if test="templateId != null">template_id = #{templateId},</if>
<if test="resourceGroupId != null">resource_group_id = #{resourceGroupId},</if>
<if test="policyName != null and policyName != ''">policy_name = #{policyName},</if>
<if test="description != null">description = #{description},</if>
<if test="status != null and status != ''">status = #{status},</if>
<if test="deployTime != null">deploy_time = #{deployTime},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
<if test="createBy != null">create_by = #{createBy},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteRmMonitorPolicyById" parameterType="Long">
delete from rm_monitor_policy where id = #{id}
</delete>
<delete id="deleteRmMonitorPolicyByIds" parameterType="String">
delete from rm_monitor_policy where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@@ -0,0 +1,97 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.rocketmq.mapper.RmMonitorTemplateMapper">
<resultMap type="RmMonitorTemplate" id="RmMonitorTemplateResult">
<result property="id" column="id" />
<result property="templateName" column="template_name" />
<result property="description" column="description" />
<result property="monitorItems" column="monitor_items" />
<result property="discoveryRules" column="discovery_rules" />
<result property="resourceGroupId" column="resource_group_id" />
<result property="resourcyType" column="resourcy_type" />
<result property="createTime" column="create_time" />
<result property="updateTime" column="update_time" />
<result property="createBy" column="create_by" />
<result property="updateBy" column="update_by" />
</resultMap>
<sql id="selectRmMonitorTemplateVo">
select id, template_name, description, monitor_items, discovery_rules, resource_group_id, resourcy_type, create_time, update_time, create_by, update_by from rm_monitor_template
</sql>
<select id="selectRmMonitorTemplateList" parameterType="RmMonitorTemplate" resultMap="RmMonitorTemplateResult">
<include refid="selectRmMonitorTemplateVo"/>
<where>
<if test="templateName != null and templateName != ''"> and template_name like concat('%', #{templateName}, '%')</if>
<if test="description != null and description != ''"> and description = #{description}</if>
<if test="monitorItems != null and monitorItems != ''"> and monitor_items = #{monitorItems}</if>
<if test="discoveryRules != null and discoveryRules != ''"> and discovery_rules = #{discoveryRules}</if>
<if test="resourceGroupId != null "> and resource_group_id = #{resourceGroupId}</if>
<if test="resourcyType != null and resourcyType != ''"> and resourcy_type = #{resourcyType}</if>
</where>
</select>
<select id="selectRmMonitorTemplateById" parameterType="Long" resultMap="RmMonitorTemplateResult">
<include refid="selectRmMonitorTemplateVo"/>
where id = #{id}
</select>
<insert id="insertRmMonitorTemplate" parameterType="RmMonitorTemplate" useGeneratedKeys="true" keyProperty="id">
insert into rm_monitor_template
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="templateName != null and templateName != ''">template_name,</if>
<if test="description != null">description,</if>
<if test="monitorItems != null">monitor_items,</if>
<if test="discoveryRules != null">discovery_rules,</if>
<if test="resourceGroupId != null">resource_group_id,</if>
<if test="resourcyType != null">resourcy_type,</if>
<if test="createTime != null">create_time,</if>
<if test="updateTime != null">update_time,</if>
<if test="createBy != null">create_by,</if>
<if test="updateBy != null">update_by,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="templateName != null and templateName != ''">#{templateName},</if>
<if test="description != null">#{description},</if>
<if test="monitorItems != null">#{monitorItems},</if>
<if test="discoveryRules != null">#{discoveryRules},</if>
<if test="resourceGroupId != null">#{resourceGroupId},</if>
<if test="resourcyType != null">#{resourcyType},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateTime != null">#{updateTime},</if>
<if test="createBy != null">#{createBy},</if>
<if test="updateBy != null">#{updateBy},</if>
</trim>
</insert>
<update id="updateRmMonitorTemplate" parameterType="RmMonitorTemplate">
update rm_monitor_template
<trim prefix="SET" suffixOverrides=",">
<if test="templateName != null and templateName != ''">template_name = #{templateName},</if>
<if test="description != null">description = #{description},</if>
<if test="monitorItems != null">monitor_items = #{monitorItems},</if>
<if test="discoveryRules != null">discovery_rules = #{discoveryRules},</if>
<if test="resourceGroupId != null">resource_group_id = #{resourceGroupId},</if>
<if test="resourcyType != null">resourcy_type = #{resourcyType},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
<if test="createBy != null">create_by = #{createBy},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteRmMonitorTemplateById" parameterType="Long">
delete from rm_monitor_template where id = #{id}
</delete>
<delete id="deleteRmMonitorTemplateByIds" parameterType="String">
delete from rm_monitor_template where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@@ -0,0 +1,128 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.rocketmq.mapper.RmTemplateLinuxMapper">
<resultMap type="RmTemplateLinux" id="RmTemplateLinuxResult">
<result property="id" column="id" />
<result property="templateId" column="template_id" />
<result property="policyId" column="policy_id" />
<result property="itemType" column="item_type" />
<result property="metricKey" column="metric_key" />
<result property="metricName" column="metric_name" />
<result property="dataType" column="data_type" />
<result property="monitorStatus" column="monitor_status" />
<result property="collectionCycle" column="collection_cycle" />
<result property="createTime" column="create_time" />
<result property="updateTime" column="update_time" />
<result property="createBy" column="create_by" />
<result property="updateBy" column="update_by" />
</resultMap>
<sql id="selectRmTemplateLinuxVo">
select id, template_id, policy_id, item_type, metric_key, metric_name, data_type, monitor_status, collection_cycle, create_time, update_time, create_by, update_by from rm_template_linux
</sql>
<select id="selectRmTemplateLinuxList" parameterType="RmTemplateLinux" resultMap="RmTemplateLinuxResult">
<include refid="selectRmTemplateLinuxVo"/>
<where>
<if test="templateId != null "> and template_id = #{templateId}</if>
<if test="policyId != null "> and policy_id = #{policyId}</if>
<if test="itemType != null and itemType != ''"> and item_type = #{itemType}</if>
<if test="metricKey != null and metricKey != ''"> and metric_key = #{metricKey}</if>
<if test="metricName != null and metricName != ''"> and metric_name like concat('%', #{metricName}, '%')</if>
<if test="dataType != null and dataType != ''"> and data_type = #{dataType}</if>
<if test="monitorStatus != null and monitorStatus != ''"> and monitor_status = #{monitorStatus}</if>
<if test="collectionCycle != null and collectionCycle != ''"> and collection_cycle = #{collectionCycle}</if>
</where>
</select>
<select id="selectRmTemplateLinuxById" parameterType="Long" resultMap="RmTemplateLinuxResult">
<include refid="selectRmTemplateLinuxVo"/>
where id = #{id}
</select>
<insert id="insertRmTemplateLinux" parameterType="RmTemplateLinux" useGeneratedKeys="true" keyProperty="id">
insert into rm_template_linux
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="templateId != null">template_id,</if>
<if test="policyId != null">policy_id,</if>
<if test="itemType != null and itemType != ''">item_type,</if>
<if test="metricKey != null and metricKey != ''">metric_key,</if>
<if test="metricName != null and metricName != ''">metric_name,</if>
<if test="dataType != null and dataType != ''">data_type,</if>
<if test="monitorStatus != null">monitor_status,</if>
<if test="collectionCycle != null">collection_cycle,</if>
<if test="createTime != null">create_time,</if>
<if test="updateTime != null">update_time,</if>
<if test="createBy != null">create_by,</if>
<if test="updateBy != null">update_by,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="templateId != null">#{templateId},</if>
<if test="policyId != null">#{policyId},</if>
<if test="itemType != null and itemType != ''">#{itemType},</if>
<if test="metricKey != null and metricKey != ''">#{metricKey},</if>
<if test="metricName != null and metricName != ''">#{metricName},</if>
<if test="dataType != null and dataType != ''">#{dataType},</if>
<if test="monitorStatus != null">#{monitorStatus},</if>
<if test="collectionCycle != null">#{collectionCycle},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateTime != null">#{updateTime},</if>
<if test="createBy != null">#{createBy},</if>
<if test="updateBy != null">#{updateBy},</if>
</trim>
</insert>
<update id="updateRmTemplateLinux" parameterType="RmTemplateLinux">
update rm_template_linux
<trim prefix="SET" suffixOverrides=",">
<if test="templateId != null">template_id = #{templateId},</if>
<if test="policyId != null">policy_id = #{policyId},</if>
<if test="itemType != null and itemType != ''">item_type = #{itemType},</if>
<if test="metricKey != null and metricKey != ''">metric_key = #{metricKey},</if>
<if test="metricName != null and metricName != ''">metric_name = #{metricName},</if>
<if test="dataType != null and dataType != ''">data_type = #{dataType},</if>
<if test="monitorStatus != null">monitor_status = #{monitorStatus},</if>
<if test="collectionCycle != null">collection_cycle = #{collectionCycle},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
<if test="createBy != null">create_by = #{createBy},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteRmTemplateLinuxById" parameterType="Long">
delete from rm_template_linux where id = #{id}
</delete>
<delete id="deleteRmTemplateLinuxByIds" parameterType="String">
delete from rm_template_linux where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
<insert id="batchInsertRmTemplateLinux" parameterType="list">
insert into rm_template_linux
(template_id, policy_id, item_type, metric_key, metric_name, data_type,
monitor_status, create_time, update_time, create_by, update_by)
values
<foreach collection="list" item="item" separator=",">
(
#{item.templateId},
#{item.policyId},
#{item.itemType},
#{item.metricKey},
#{item.metricName},
#{item.dataType},
#{item.monitorStatus},
#{item.createTime},
#{item.updateTime},
#{item.createBy},
#{item.updateBy}
)
</foreach>
</insert>
</mapper>

View File

@@ -0,0 +1,160 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.rocketmq.mapper.RmTemplateSwitchMapper">
<resultMap type="RmTemplateSwitch" id="RmTemplateSwitchResult">
<result property="id" column="id" />
<result property="templateId" column="template_id" />
<result property="policyId" column="policy_id" />
<result property="itemType" column="item_type" />
<result property="metricKey" column="metric_key" />
<result property="metricName" column="metric_name" />
<result property="oid" column="oid" />
<result property="filterValue" column="filter_value" />
<result property="switchDescription" column="switch_description" />
<result property="dataType" column="data_type" />
<result property="monitorStatus" column="monitor_status" />
<result property="collectionCycle" column="collection_cycle" />
<result property="createTime" column="create_time" />
<result property="updateTime" column="update_time" />
<result property="createBy" column="create_by" />
<result property="updateBy" column="update_by" />
</resultMap>
<sql id="selectRmTemplateSwitchVo">
select id, template_id, policy_id, item_type, metric_key, metric_name, oid, filter_value, switch_description, data_type, monitor_status, collection_cycle, create_time, update_time, create_by, update_by from rm_template_switch
</sql>
<select id="selectRmTemplateSwitchList" parameterType="RmTemplateSwitch" resultMap="RmTemplateSwitchResult">
<include refid="selectRmTemplateSwitchVo"/>
<where>
<if test="templateId != null "> and template_id = #{templateId}</if>
<if test="policyId != null "> and policy_id = #{policyId}</if>
<if test="itemType != null and itemType != ''"> and item_type = #{itemType}</if>
<if test="metricKey != null and metricKey != ''"> and metric_key = #{metricKey}</if>
<if test="metricName != null and metricName != ''"> and metric_name like concat('%', #{metricName}, '%')</if>
<if test="oid != null and oid != ''"> and oid = #{oid}</if>
<if test="filterValue != null and filterValue != ''"> and filter_value = #{filterValue}</if>
<if test="switchDescription != null and switchDescription != ''"> and switch_description = #{switchDescription}</if>
<if test="dataType != null and dataType != ''"> and data_type = #{dataType}</if>
<if test="monitorStatus != null and monitorStatus != ''"> and monitor_status = #{monitorStatus}</if>
<if test="collectionCycle != null and collectionCycle != ''"> and collection_cycle = #{collectionCycle}</if>
</where>
</select>
<select id="selectRmTemplateSwitchById" parameterType="Long" resultMap="RmTemplateSwitchResult">
<include refid="selectRmTemplateSwitchVo"/>
where id = #{id}
</select>
<insert id="insertRmTemplateSwitch" parameterType="RmTemplateSwitch" useGeneratedKeys="true" keyProperty="id">
insert into rm_template_switch
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="templateId != null">template_id,</if>
<if test="policyId != null">policy_id,</if>
<if test="itemType != null and itemType != ''">item_type,</if>
<if test="metricKey != null and metricKey != ''">metric_key,</if>
<if test="metricName != null and metricName != ''">metric_name,</if>
<if test="oid != null and oid != ''">oid,</if>
<if test="filterValue != null">filter_value,</if>
<if test="switchDescription != null">switch_description,</if>
<if test="dataType != null and dataType != ''">data_type,</if>
<if test="monitorStatus != null">monitor_status,</if>
<if test="collectionCycle != null">collection_cycle,</if>
<if test="createTime != null">create_time,</if>
<if test="updateTime != null">update_time,</if>
<if test="createBy != null">create_by,</if>
<if test="updateBy != null">update_by,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="templateId != null">#{templateId},</if>
<if test="policyId != null">#{policyId},</if>
<if test="itemType != null and itemType != ''">#{itemType},</if>
<if test="metricKey != null and metricKey != ''">#{metricKey},</if>
<if test="metricName != null and metricName != ''">#{metricName},</if>
<if test="oid != null and oid != ''">#{oid},</if>
<if test="filterValue != null">#{filterValue},</if>
<if test="switchDescription != null">#{switchDescription},</if>
<if test="dataType != null and dataType != ''">#{dataType},</if>
<if test="monitorStatus != null">#{monitorStatus},</if>
<if test="collectionCycle != null">#{collectionCycle},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateTime != null">#{updateTime},</if>
<if test="createBy != null">#{createBy},</if>
<if test="updateBy != null">#{updateBy},</if>
</trim>
</insert>
<update id="updateRmTemplateSwitch" parameterType="RmTemplateSwitch">
update rm_template_switch
<trim prefix="SET" suffixOverrides=",">
<if test="templateId != null">template_id = #{templateId},</if>
<if test="policyId != null">policy_id = #{policyId},</if>
<if test="itemType != null and itemType != ''">item_type = #{itemType},</if>
<if test="metricKey != null and metricKey != ''">metric_key = #{metricKey},</if>
<if test="metricName != null and metricName != ''">metric_name = #{metricName},</if>
<if test="oid != null and oid != ''">oid = #{oid},</if>
<if test="filterValue != null">filter_value = #{filterValue},</if>
<if test="switchDescription != null">switch_description = #{switchDescription},</if>
<if test="dataType != null and dataType != ''">data_type = #{dataType},</if>
<if test="monitorStatus != null">monitor_status = #{monitorStatus},</if>
<if test="collectionCycle != null">collection_cycle = #{collectionCycle},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
<if test="createBy != null">create_by = #{createBy},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteRmTemplateSwitchById" parameterType="Long">
delete from rm_template_switch where id = #{id}
</delete>
<delete id="deleteRmTemplateSwitchByIds" parameterType="String">
delete from rm_template_switch where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
<insert id="batchInsertRmTemplateSwitch" parameterType="list">
INSERT INTO rm_template_switch
(
template_id,
policy_id,
item_type,
metric_key,
metric_name,
oid,
filter_value,
switch_description,
data_type,
monitor_status,
create_time,
update_time,
create_by,
update_by
)
VALUES
<foreach collection="list" item="item" separator=",">
(
#{item.templateId},
#{item.policyId},
#{item.itemType},
#{item.metricKey},
#{item.metricName},
#{item.oid},
#{item.filterValue},
#{item.switchDescription},
#{item.dataType},
#{item.monitorStatus},
#{item.createTime},
#{item.updateTime},
#{item.createBy},
#{item.updateBy}
)
</foreach>
</insert>
</mapper>