# Sermant Backend使用手册

# 功能介绍

Sermant Backend包含Sermant数据处理后端模块和前端信息展示模块,旨在为Sermant提供运行时的管理能力和可观测能力,当前主要包括Sermant Agent心跳信息, 上报事件的接收和展示,webhook推送,配置管理、热插拔服务等功能。

# 实例状态展示服务

Sermant Backend与Sermant Agent配合使用。Sermant Agent挂载在宿主应用启动后作为数据发送端,定时发送当前Sermant Agent的心跳数据(服务名、主机名、实例ID、版本号、IP、时间戳、挂载插件信息),Backend作为数据接收端,可接收处理Sermant Agent发送的心跳数据,并进行展示。页面实际效果图参见实例状态验证

# 事件信息展示服务

Sermant Agent挂载在宿主应用启动后作为数据发送端不仅可以发送当前Sermant Agent的心跳数据,还可以发送事件等数据,Backend作为数据接收端,可接收处理事件等数据,将紧急事件推送至webhook,并在前端可视化展示,提供观测Sermant Agent运行状态的能力。页面实际效果图参见事件管理验证

# 配置管理服务

Sermant Backend与配置中心配合使用,可以管理配置中心的所有配置项,并且可以在页面上查看、新增、修改、删除配置项。实际效果图参见配置管理验证

# 热插拔服务

Sermant Backend与Sermant Agent配合使用,还可以作为热插拔功能的服务端,监听Sermant Backend的热插拔指令,执行插件安装、卸载、升级以及外部Agent的挂载操作。实际效果图参见热插拔服务验证

注:Sermant Backend为非必要组件,用户可按需部署。

# 参数配置

# Sermant Agent参数配置

Sermant Backend提供的实例状态管理和事件管理能力,需要依赖Sermant Agent上报的数据,所以在使用Sermant Backend时,需要先配置Sermant Agent中用于连接Sermant Backend、开启数据上报的相关参数,在配置文件agent/config/config.properties中修改以下配置:

参数键 说明 默认值 是否必须
agent.service.heartbeat.enable 心跳服务开关 false 使用Sermant Backend的热插拔服务时必须
agent.service.gateway.enable 网关服务开关 false 开启心跳服务、事件上报时或者使用Sermant Backend的热插拔服务必须
agent.service.dynamic.config.enable 动态配置开关 false 使用Sermant Backend的热插拔服务时必须
agent.service.hot.plugging.service.enable 热插拔服务开关 false 使用Sermant Backend的热插拔服务时必须
gateway.nettyIp Netty服务端的IP 127.0.0.1
gateway.nettyPort Netty服务端的端口 6888
event.enable 事件上报开关 false
event.offerWarnLog 是否上报warn级别日志 false
event.offerErrorLog 是否上报error级别日志 false
event.sendInterval 事件发送间隔(ms) 30000 开启事件上报时必须
event.offerInterval 相同事件的上报间隔 300000 开启事件上报时必须

# Sermant Backend参数配置

Sermant Backend参数可在编译打包前通过sermant-backend/src/main/resources/application.properties配置文件进行修改,同时也支持在jar包启动前通过-D参数或环境变量的方式进行配置。

# 基础参数

参数键 说明 默认值 是否必须
server.port Sermant Backend的服务占用端口 8900
netty.port Netty消息接收端口 6888
netty.wait.time Netty的读等待时间,单位:s 60

# 实例状态参数

参数键 说明 默认值 是否必须
max.effective.time 判断应用心跳存活的有效时间,单位:ms 60000
max.cache.time 应用心跳在缓存中的有效时间,单位:ms 600000

# 事件管理参数

参数键 说明 默认值 是否必须
database.type 事件存储类型,当前支持redis数据库和内存 MEMORY
database.address redis数据库地址 127.0.0.1:6379
database.user redis数据库用户名 default
database.password redis数据库密码 null
database.event.expire 事件过期时间,单位:天 7
webhook.eventpush.level webhook事件推送级别,支持EMERGENCY,IMPORTANT,NORMAL三种级别;支持飞书和钉钉两种webhook EMERGENCY

# 配置管理参数

参数键 说明 默认值 是否必须
dynamic.config.enable 配置管理的开关 true
dynamic.config.namespace 默认的命名空间(连接Nacos配置中心时使用) default 连接配置中心Nacos时必须
dynamic.config.timeout 请求配置中心的超时时间 30000 置管理的开关开启时必须
dynamic.config.serverAddress 配置中心的连接地址 127.0.0.1:30110 配置管理的开关开启时必须
dynamic.config.dynamicConfigType 配置中心的类型,支持ZOOKEEPER、NACOS、KIE KIE 配置管理的开关开启时必须
dynamic.config.connectTimeout 连接配置中心的超时时间 3000 配置管理的开关开启时必须
dynamic.config.enableAuth 是否开启授权认证,支持Nacos和Zookeeper false 配置管理的开关开启时必须
dynamic.config.userName 授权认证时使用的用户名(明文) null 开启授权认证时必须
dynamic.config.password 授权认证时使用的密码(采用AES加密后的密文,密文生成方式请参考AES加密常见问题 null 开启授权认证时必须
dynamic.config.secretKey 密码采用AES方式加密时使用的密钥, 密钥生成方式请参考AES加密常见问题 null 开启授权认证时必须
dynamic.config.template.path 配置页面的UI模板路径,模板的开发参见配置管理的UI模板 null

# 支持版本

Sermant Backend使用JDK 1.8版本开发,因此运行环境需JDK 1.8及以上版本。

# 操作和结果验证

# 1 准备工作

# 2 修改Sermant Agent参数配置

修改${path}/sermant-agent/agent/config/config.properties文件为以下内容:

# Heartbeat service switch
agent.service.heartbeat.enable=true
# Gateway service switch
agent.service.gateway.enable=true
# Dynamic config service switch
agent.service.dynamic.config.enable=true
# dynamic mount service switch
agent.service.hot.plugging.service.enable=true
# Event switch
event.enable=true
# Report warn log switch
event.offerWarnLog=true
# Report error log switch
event.offerErrorLog=true

说明:${path}为sermant所在路径。

# 3 部署应用

# 3.1 部署Sermant Backend

# windwos
java -Dwebhook.eventpush.level=NORMAL -Ddynamic.config.enable=true -Ddynamic.config.serverAddress=127.0.0.1:2181 -Ddynamic.config.dynamicConfigType=ZOOKEEPER -jar ${path}\sermant-agent\server\sermant\sermant-backend-x.x.x.jar

#linux mac
java -Dwebhook.eventpush.level=NORMAL -Ddynamic.config.enable=true -Ddynamic.config.serverAddress=127.0.0.1:2181 -Ddynamic.config.dynamicConfigType=ZOOKEEPER -jar ${path}/sermant-agent/server/sermant/sermant-backend-x.x.x.jar

说明: ${path}为sermant实际安装路径,x.x.x代表sermant某个版本号。

# 3.2 部署宿主应用

解压Demo二进制产物压缩包,即可得到service-a.jar和service-b.jar。

# windwos
java -Dserver.port=8989 -javaagent:${path}\sermant-agent\agent\sermant-agent.jar=appName=default -jar service-a.jar
java -Dserver.port=8990 -jar service-b.jar

#linux mac
java -Dserver.port=8989 -javaagent:${path}/sermant-agent/agent/sermant-agent.jar=appName=default -jar service-a.jar
java -Dserver.port=8990 -jar service-b.jar

说明: ${path}为sermant实际安装路径

# 3.3 动态挂载Sermant

通过agentmain方式给宿主应用service-b动态挂载Sermant Agent,具体操作方式参见Agent挂载

# 4 实例状态验证

通过浏览器访问地址http://127.0.0.1:8900/ 可查看前端展示页面,若页面中如下展示Sermant Agent实例的心跳信息,则验证心跳成功。

# 5 事件管理验证

通过点击事件管理标签中的观测按钮,可查看Sermant Agent上报的事件信息,若页面中如下展示Sermant Agent实例上报的事件信息,则验证事件上报成功。

# 5.1 验证事件查询

5.1.1 上报时间查询

事件管理 -> 监测页面,下图红色方框位置设置查询的事件时间范围,点击查询按钮进行查询

5.1.2 服务名查询

事件管理 -> 监测页面,下图红色方框位置设置按服务名查询,输入需要查询的服务名(支持单个或多个服务名查询),点击查询按钮进行查询

5.1.3 ip查询

事件管理 -> 监测页面,下图红色方框位置设置按ip查询,输入需要查询的ip地址(支持单个或多个ip查询),点击查询按钮进行查询

5.1.4 级别查询

事件管理 -> 监测页面,下图红色方框位置选择需要查询的事件级别,支持多选,选择后点击筛选进行查询

5.1.5 类型查询

事件管理 -> 监测页面,下图红色方框位置选择需要查询的事件类型,支持多选,选择后点击筛选进行查询

5.1.6 详细信息展示

事件管理 -> 监测页面,点击下图红色方框位置查看事件详细信息

5.1.7 事件自动刷新

事件管理 -> 监测页面,点击下图红色方框自动刷新按钮,开启事件自动刷新(开启后将会定时自动获取最新事件,再次点击按钮关闭,或在查看事件列表时自动关闭)

# 5.2 验证webhook事件通知

  • 通过浏览器访问地址http://127.0.0.1:8900/
  • 点击菜单栏事件管理 -> 配置 进入webhook配置界面,如下图所示:
  • 开启webhook,如下图所示:
  • 点击webhook的编辑按钮,设置webhook地址,如下图所示:
  • 点击webhook的测试连接按钮,可在对应webhook接收到测试事件通知
    • 飞书测试事件推送如下图所示:

    • 钉钉测试事件推送如下图所示:

# 6 配置管理验证

  • 通过浏览器访问地址http://127.0.0.1:8900/
  • 点击菜单栏配置管理进入配置管理界面即可查看配置中心的配置,配置管理页面默认会展示路由插件的配置,如下图所示:

# 6.1 验证配置新增

  • 在配置管理页面,点击新增按钮可以跳转到配置详情页面进行配置新增,如下图所示:
  • 在配置详情页面输入必要的配置信息之后即可点击提交按钮进行配置新增,如下图所示:
  • 配置新增成功之后,即可在配置管理页面查询到该配置项。

# 6.2 验证配置查询

  • 在配置管理页面,可以选择不同的插件类型来查询不同的插件配置,也可以输入不同的查询条件(如服务名称、应用名称等)查询符合条件的插件配置。下面为查询流控插件配置的结果图(上一步已经新增):

# 6.3 验证配置修改

  • 在配置管理页面可以点击查看按钮跳转到配置详情页面修改配置内容。如下图所示:
  • 在配置详情页面可以对配置内容进行修改,修改后点击提交按钮可以将修改后的内容提交到配置中心。
  • 再次进入配置详情页面即可查看修改后的配置内容。

# 6.4 验证配置删除

  • 在配置管理页面可以进行配置的删除操作,点击删除按钮会提示是否进行删除操作。如下图所示:
  • 选择之后会删除该配置项,如下图所示:

# 7 热插拔服务验证

通过浏览器访问地址http://127.0.0.1:8900/ 可查看实例状态页面,在实例状态页面可以对动态挂载的Sermant Agent执行热插拔服务。

# 7.1 插件安装

  • 选择要执行热插拔服务的实例,点击热插拔按钮
  • 选择安装插件服务,输入插件名称即可点击确认按钮进行插件安装

注:动态安装插件前请确保插件的JAR包在${path}/sermant-agent-x.x.x/pluginPackage/${pluginName}下。 ${path}为sermant实际安装路径,x.x.x代表sermant某个版本号,${pluginName}为插件名称

  • 由于心跳和事件上报有时间周期,插件信息和事件并非立即刷新,需等待最新的心跳信息和事件上报后即可查看

# 7.2 插件升级

  • 在实例状态页面选择要执行热插拔服务的实例,点击热插拔按钮
  • 选择更新插件服务,输入插件名称即可点击确认按钮进行插件更新

注:动态更新插件前请确保插件的JAR包已经被更新

  • 由于心跳和事件上报有时间周期,插件信息和事件并非立即刷新,需等待最新的心跳信息和事件上报后即可查看

# 7.3 插件卸载

  • 在实例状态页面选择要执行热插拔服务的实例,点击热插拔按钮
  • 选择卸载插件服务,输入插件名称即可点击确认按钮进行插件卸载
  • 由于心跳和事件上报有时间周期,插件信息和事件并非立即刷新,需等待最新的心跳信息和事件上报后即可查看

# 7.4 外部Agent安装

参考在Sermant中使用和管理外部JavaAgent

上次更新: 2025/1/20 06:41:14