parent
5070304883
commit
1152e9b42c
@ -0,0 +1,30 @@ |
|||||||
|
package rition.backend.api.v1.dto.response; |
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableField; |
||||||
|
import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler; |
||||||
|
import com.fasterxml.jackson.annotation.JsonFormat; |
||||||
|
import lombok.AllArgsConstructor; |
||||||
|
import lombok.Builder; |
||||||
|
import lombok.Data; |
||||||
|
import lombok.NoArgsConstructor; |
||||||
|
|
||||||
|
import java.time.Instant; |
||||||
|
import java.util.Map; |
||||||
|
|
||||||
|
@Data |
||||||
|
@Builder |
||||||
|
@NoArgsConstructor |
||||||
|
@AllArgsConstructor |
||||||
|
public class MetricDataResponse { |
||||||
|
/** |
||||||
|
* 监控指标值,使用json格式存储 |
||||||
|
*/ |
||||||
|
@TableField(typeHandler = JacksonTypeHandler.class) |
||||||
|
private Map<String, Double> metricData; |
||||||
|
|
||||||
|
/** |
||||||
|
* create_time |
||||||
|
*/ |
||||||
|
@JsonFormat() |
||||||
|
private Instant time; |
||||||
|
} |
@ -1,5 +1,5 @@ |
|||||||
|
|
||||||
package rition.common.data.dto; |
package rition.common.data.dto.service; |
||||||
|
|
||||||
import lombok.AllArgsConstructor; |
import lombok.AllArgsConstructor; |
||||||
import lombok.Builder; |
import lombok.Builder; |
@ -1,5 +1,40 @@ |
|||||||
<?xml version="1.0" encoding="UTF-8" ?> |
<?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" > |
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > |
||||||
<mapper namespace="rition.common.data.dao.mapper.MetricRecordMapper"> |
<mapper namespace="rition.common.data.dao.mapper.MetricRecordMapper"> |
||||||
|
<resultMap id="metricDataEntity" type="rition.common.data.entity.MetricRecordEntity"> |
||||||
|
<result property="metricData" column="metric_data" typeHandler="com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler"/> |
||||||
|
</resultMap> |
||||||
|
|
||||||
|
<select id="getMetricDataGroupByHour" resultMap="metricDataEntity" resultType="rition.common.data.entity.MetricRecordEntity"> |
||||||
|
SELECT JSON_OBJECT( |
||||||
|
<foreach collection="metricItems" item="metricItem" separator=","> |
||||||
|
"${metricItem}", ${metricItem} |
||||||
|
</foreach> |
||||||
|
) AS metric_data, |
||||||
|
t AS time |
||||||
|
FROM ( |
||||||
|
SELECT |
||||||
|
<foreach collection="metricItems" item="metricItem"> |
||||||
|
avg(JSON_EXTRACT(metric_data, "$.${metricItem}")) as ${metricItem}, |
||||||
|
</foreach> |
||||||
|
DATE_FORMAT(time,'%Y-%m-%d %H:00:00') as t |
||||||
|
FROM record WHERE `time` BETWEEN #{startTime} and #{endTime} and `instance_id` = #{instanceId} |
||||||
|
GROUP BY t ORDER BY t |
||||||
|
) AS tab; |
||||||
|
|
||||||
|
<!-- |
||||||
|
SELECT |
||||||
|
JSON_OBJECT('node_sockstat_TCP_tw', node_sockstat_TCP_tw), |
||||||
|
t AS time |
||||||
|
FROM ( |
||||||
|
SELECT |
||||||
|
avg(JSON_EXTRACT(metric_data, "$.node_sockstat_TCP_tw")) node_sockstat_TCP_tw, |
||||||
|
DATE_FORMAT(time,'%Y-%m-%d %H:00:00') as t |
||||||
|
FROM record |
||||||
|
WHERE `time` BETWEEN '2024-04-17 14:00:00' and '2024-04-17 15:00:00' |
||||||
|
GROUP BY t ORDER BY t |
||||||
|
) AS tab |
||||||
|
--> |
||||||
|
</select> |
||||||
|
|
||||||
</mapper> |
</mapper> |
@ -0,0 +1,73 @@ |
|||||||
|
package rition.service.panel; |
||||||
|
|
||||||
|
import lombok.extern.slf4j.Slf4j; |
||||||
|
import org.springframework.stereotype.Service; |
||||||
|
import rition.common.data.dao.mapper.MetricRecordMapper; |
||||||
|
import rition.common.data.entity.MetricRecordEntity; |
||||||
|
|
||||||
|
import java.time.Instant; |
||||||
|
import java.util.ArrayList; |
||||||
|
import java.util.HashSet; |
||||||
|
import java.util.List; |
||||||
|
|
||||||
|
@Slf4j |
||||||
|
@Service |
||||||
|
public class MetricService { |
||||||
|
|
||||||
|
private final MetricRecordMapper metricRecordMapper; |
||||||
|
|
||||||
|
public MetricService(MetricRecordMapper metricRecordMapper) { |
||||||
|
this.metricRecordMapper = metricRecordMapper; |
||||||
|
} |
||||||
|
|
||||||
|
public List<MetricRecordEntity> getMetricDataRange(String instanceId, |
||||||
|
List<String> metricItems, |
||||||
|
Instant start, Instant end) { |
||||||
|
var filteredMetricItems = this.filterMetricItems(metricItems); |
||||||
|
if (filteredMetricItems.isEmpty()) { |
||||||
|
return new ArrayList<>(); |
||||||
|
} |
||||||
|
|
||||||
|
return metricRecordMapper.getMetricDataGroupByHour(instanceId, metricItems, start, end); |
||||||
|
} |
||||||
|
|
||||||
|
private static final HashSet<String> allowedMetricItems = new HashSet<>(22); |
||||||
|
|
||||||
|
static { |
||||||
|
allowedMetricItems.add("up"); |
||||||
|
allowedMetricItems.add("node_load5"); |
||||||
|
allowedMetricItems.add("node_sockstat_TCP_tw"); |
||||||
|
allowedMetricItems.add("node_cpu_seconds_total"); |
||||||
|
allowedMetricItems.add("node_memory_Cached_bytes"); |
||||||
|
allowedMetricItems.add("node_memory_Buffers_bytes"); |
||||||
|
allowedMetricItems.add("node_memory_MemFree_bytes"); |
||||||
|
allowedMetricItems.add("node_disk_read_bytes_total"); |
||||||
|
allowedMetricItems.add("node_filesystem_free_bytes"); |
||||||
|
allowedMetricItems.add("node_filesystem_size_bytes"); |
||||||
|
allowedMetricItems.add("node_memory_MemTotal_bytes"); |
||||||
|
allowedMetricItems.add("node_netstat_Tcp_CurrEstab"); |
||||||
|
allowedMetricItems.add("node_filesystem_avail_bytes"); |
||||||
|
allowedMetricItems.add("node_disk_written_bytes_total"); |
||||||
|
allowedMetricItems.add("node_disk_reads_completed_total"); |
||||||
|
allowedMetricItems.add("node_network_receive_drop_total"); |
||||||
|
allowedMetricItems.add("node_disk_writes_completed_total"); |
||||||
|
allowedMetricItems.add("node_network_receive_bytes_total"); |
||||||
|
allowedMetricItems.add("node_network_transmit_drop_total"); |
||||||
|
allowedMetricItems.add("node_network_transmit_bytes_total"); |
||||||
|
allowedMetricItems.add("node_network_receive_packets_total"); |
||||||
|
allowedMetricItems.add("node_network_transmit_packets_total"); |
||||||
|
} |
||||||
|
|
||||||
|
public List<String> filterMetricItems(List<String> metricItems) { |
||||||
|
List<String> filteredMetricItems = new ArrayList<>(metricItems.size()); |
||||||
|
for (String metricItem : metricItems) { |
||||||
|
if (allowedMetricItems.contains(metricItem)) { |
||||||
|
filteredMetricItems.add(metricItem); |
||||||
|
} else { |
||||||
|
log.warn("[MetricService]: 含有非允许的指标值:{}", metricItem); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return filteredMetricItems; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,12 @@ |
|||||||
|
spring: |
||||||
|
datasource: |
||||||
|
driver-class-name: com.mysql.cj.jdbc.Driver |
||||||
|
url: jdbc:mysql://127.0.0.1:3306/rition?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=Asia/Shanghai&rewriteBatchedStatements=true |
||||||
|
username: root |
||||||
|
password: Test2333! |
||||||
|
mybatis: |
||||||
|
configuration: |
||||||
|
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl |
||||||
|
mybatis-plus: |
||||||
|
configuration: |
||||||
|
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl |
Loading…
Reference in new issue