Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
B
byh-alarm-service
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
包
包
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
杨凯
byh-alarm-service
Commits
70022732
提交
70022732
authored
4月 20, 2026
作者:
Edwin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: 添加告警消息详情
上级
c15fa091
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
26 行增加
和
10 行删除
+26
-10
AlarmServiceImpl.java
...ebaiyihui/alarm/server/service/Impl/AlarmServiceImpl.java
+26
-10
没有找到文件。
alarm-server/src/main/java/com/ebaiyihui/alarm/server/service/Impl/AlarmServiceImpl.java
浏览文件 @
70022732
...
...
@@ -61,6 +61,7 @@ public class AlarmServiceImpl implements AlarmService {
"Service instance (.+) of (.+) is down in (.+) of last (.+)"
,
Pattern
.
CASE_INSENSITIVE
);
private
static
final
Map
<
String
,
String
>
RULE_NAME_TRANSLATIONS
=
buildRuleNameTranslations
();
@Value
(
"${webHookUrl}"
)
private
String
webHookUrl
;
...
...
@@ -141,22 +142,13 @@ public class AlarmServiceImpl implements AlarmService {
private
String
formatReadableMessage
(
AlarmMessage
alarmMessage
,
String
serviceName
,
String
rawMessage
)
{
StringBuilder
builder
=
new
StringBuilder
();
builder
.
append
(
"【告警】"
);
if
(!
StringUtil
.
isBlank
(
alarmMessage
.
getScope
()))
{
builder
.
append
(
"\n范围: "
).
append
(
alarmMessage
.
getScope
());
}
if
(!
StringUtil
.
isBlank
(
serviceName
))
{
builder
.
append
(
"\n服务: "
).
append
(
serviceName
);
}
else
if
(!
StringUtil
.
isBlank
(
alarmMessage
.
getName
()))
{
builder
.
append
(
"\n对象: "
).
append
(
alarmMessage
.
getName
());
}
if
(!
StringUtil
.
isBlank
(
alarmMessage
.
getId0
()))
{
builder
.
append
(
"\nID0: "
).
append
(
alarmMessage
.
getId0
());
}
if
(!
StringUtil
.
isBlank
(
alarmMessage
.
getId1
()))
{
builder
.
append
(
"\nID1: "
).
append
(
alarmMessage
.
getId1
());
}
if
(!
StringUtil
.
isBlank
(
alarmMessage
.
getRuleName
()))
{
builder
.
append
(
"\n规则: "
).
append
(
alarmMessage
.
getRuleName
(
));
builder
.
append
(
"\n规则: "
).
append
(
translateRuleName
(
alarmMessage
.
getRuleName
()
));
}
String
startTime
=
formatStartTime
(
alarmMessage
.
getStartTime
());
if
(!
StringUtil
.
isBlank
(
startTime
))
{
...
...
@@ -262,6 +254,30 @@ public class AlarmServiceImpl implements AlarmService {
.
replace
(
" second"
,
"秒"
);
}
private
String
translateRuleName
(
String
ruleName
)
{
String
key
=
ruleName
.
trim
().
toLowerCase
(
Locale
.
ROOT
);
String
translated
=
RULE_NAME_TRANSLATIONS
.
get
(
key
);
if
(
translated
!=
null
)
{
return
translated
;
}
return
ruleName
;
}
private
static
Map
<
String
,
String
>
buildRuleNameTranslations
()
{
Map
<
String
,
String
>
translations
=
new
HashMap
<>();
translations
.
put
(
"service_resp_time_rule"
,
"服务响应时间告警"
);
translations
.
put
(
"service_sla_rule"
,
"服务可用率告警"
);
translations
.
put
(
"service_resp_time_percentile_rule"
,
"服务分位响应时间告警"
);
translations
.
put
(
"service_instance_resp_time_rule"
,
"服务实例响应时间告警"
);
translations
.
put
(
"database_access_resp_time_rule"
,
"数据库访问响应时间告警"
);
translations
.
put
(
"endpoint_relation_resp_time_rule"
,
"接口关系响应时间告警"
);
translations
.
put
(
"service_percentile_rule"
,
"服务分位响应时间告警"
);
translations
.
put
(
"endpoint_resp_time_rule"
,
"接口响应时间告警"
);
translations
.
put
(
"endpoint_sla_rule"
,
"接口可用率告警"
);
translations
.
put
(
"service_instance_down_rule"
,
"服务实例存活告警"
);
return
Collections
.
unmodifiableMap
(
translations
);
}
private
String
formatStartTime
(
long
startTime
)
{
if
(
startTime
<=
0
)
{
return
""
;
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论