简介:ARMS企业级场景被集成场景介绍

通过本次最佳实践内容,您可以看到ARMS OpenAPI可以灵活的被集成到客户链路监控场景,并对其进行可视化图形展示监控信息。

1. 背景信息

应用实时监控服务ARMS(Application Real-Time Monitoring Service)是一款应用性能管理产品,能帮助你实现全栈式的性能监控和端到端的全链路追踪诊断,让应用运维更加高效。

本次最佳实践是基于调用ARMS OpenAPI的形式来实现客户应用场景链路监控的可视化图形展示,使用环境为专有云V3.10版本ASCM控制台,调用ARMS OpenAPI接口通过工具Postman进行测试,在第二章节详细介绍了测试环境及测试工具。第三章节通过一个查询所有应用ARMS OpenAPI接口描述调用过程,并且包含该接口需要请求传入的参数接口列表。最后一章节将对一个复杂应用场景,获取链路监控信息使用到ARMSOpenAPI接口,对每个接口列表字段、调用过程及返回结果详细介绍。

最佳实践价值

通过调用ARMS OpenAPI在应用场景的使用,直观给阅读者了解到ARMS产品的能力,及ARMS提供一套OpenAPI可以容易的集成到客户应用中,快速实现复杂的微服务链路监控能力,由ARMS监控服务能力涵盖范围能力比较广,包含浏览器、小程序、APP、分布式应用和容器环境,因此完整的监控能力,开发过程中不需要集成多开源组件的形式,使微服务程序监控功能开发简单,让应用运维变得容易。

2. 环境

在使用ARMS前您需要按照以下内容对当前的系统环境进行检查。

本次最佳实践基于专有云企业版V3.10.0版本ARMS。

说明ARMS OpenAPI各个版本变化不大,使用方式保持一致,所以此文档也适用于公共云产品或专有云V3.7.0以上版本。专有云V3.10.0控制台称为ASCM,V3.10.0之前版本为Apsara Stack。

1.登录ASCM控制台。

2.将鼠标指向页面上方导航栏中的产品,单击企业级分布式应用服务EDAS

图1:ASCM

说明:由于ARMS监控应用数据,需要EDAS产品配合。本次测试先通过EDAS部署一个标准的Spring Boot应用,开通ARMS监控并得到监控数据。

图 2:EDAS控制台

图 3:ARMS控制台

3.测试工具检查。

本实践将会在专有云环境中创建win64虚拟机,然后在虚拟机中安装Postman进行测试。

图4:Postman测试

3. Open API使用

调用URL确认

OpenAPI接口均为REST服务,首先确认服务的URL。
每个专有云环境域名不同,会导致URL不同。请根据具体环境信息修改URL信息,前缀及端口不变。
http://arms.console.example.com:8099/

名称 接口
数据集API /dataset/GeneralQuery.json
关键应用性能指标 /metric/Metric.json
报警信息
应用监控-应用拓扑 /trace/Dependecies.json
事件集 /eventset/EventList.json

调用示例-查看所有应用:

API说明

URL:http://arms.console.example.com:8099/trace/Services.json

参数列表

字段名称 字段类型 字段含义 是否必选 备注
_userId String 用户id 用户名称(如arms_admin)

返回格式示例

{"code": 200,"data": {"details": [{"pid": "string", //应用对应的pid"regionId": "string","serviceName": "string" //应用名称}],"services":[ //应用名称列表"string","string"]},"success": true}

Postman调用结果

参数设置:_userId= 121827433423****

图5:Postman调用结果

4. 应用描述

从ARMS中取得应用拓扑数据、曲线图、应用监控指标数据,将通过大屏DataV展示。

图6:DataV展示

5. 查询接口调用次数

通过/metric/Metric.json接口获得应用相关性能数据,查询接口调用次数。

API说明

  • URL :http://arms.console.example.com:8099/metric/Metric.json
  • 接口说明:
字段名称 字段类型 字段含义 是否必选 备注
startTime Long 查询数据的起始时间
endTime Long 查询数据的截止时间
intervalInSec Integer 时间间隔 建议填写
metric String metric字段 详细填写参考参数填写示范
filters List[String] 过滤字段 详细填写参考参数填写示范
measures List[String] 指标 详细填写参考参数填写示范
dimensions List[String] 维度 详细填写参考参数填写示范
orderBy String 排序字段
sortOrder String 排序 默认不排序(ASC或者DESC)
limit Integer 返回条数
_userId String 用户id 用户名称(如arms_admin)

调用示例

查询指定应用过往7天的接口调用次数

参数填写示范:

字段名称 字段类型 字段含义 必选 示例值 值来源
startTime Long 查询数据的起始时间 1578199319898 系统时间
endTime Long 查询数据的截止时间 1578804119898 系统时间
intervalInSec Integer 时间间隔 默认3600秒,即1小时 人工设置
metric String metric字段,查询的指标 APPSTAT.DETAIL 人工设置
filters List[String] 过滤字段,严格按照格式,否则调用出错 [{key=pid,value=1218274334230390@db61f75c2f******},{key=regionId,value=cn-******-d01}] Pid、regionid来自于专有云环境
measures List[String] 指标 [rt,count,error,errrate] API文档
dimensions List[String] 维度 [pid,rpcType,rootIp] API文档
orderBy String 排序字段
sortOrder String 排序 默认不排序(ASC或者DESC)
limit Integer 返回条数
_userId String 用户id 121827433423****

查询结果

参数设置:

图7:参数设置

结果说明:

  • 返回结果为JSON数据集。
  • 数据集会标示查询状态,成功返回200,如果失败会返回相应的错误码和错误原因。典型错误例如缺少必要参数、身份认证错误等(是因为filters参数没按格式要求写好)。
  • OpenAPI返回的结果集组织形式与查询数据的开始时间、结束时间、数据间隔时间有关。本次查询是查询了过往7天,数据间隔时间设置成了24小时,所以这个结果集里返回了7个”data”的集合。
  • 每个data里包括在“measure”和”dimension”里指定的查询,以本结果集为例,就包括:Count:0.0
    PID:
    rpcDesc: HTTP入口
    rpcType:0(HTTP调用)
  • 调整查询的开始、结束、间隔时间,会影响data数据的条数,调整接口查询参数会影响每条data里的数据。
  • 如果需要计算一些聚合值,比如过往7天总的HTTP调用次数,需要自行把多条data数据进行计算相加后得出结果。

6. 查询异常数量

通过/metric/Metric.json 接口获得应用相关性能数据,查询异常数量。

API说明

  • URL :http://arms.console.example.com:8099/metric/Metric.json
  • 接口说明:
字段名称 字段类型 字段含义 是否必选 备注
startTime Long 查询数据的起始时间
endTime Long 查询数据的截止时间
intervalInSec Integer 时间间隔 建议填写
metric String metric字段 详细填写参考下文
filters List[String] 过滤字段 详细填写参考下文
measures List[String] 指标 详细填写参考下文
dimensions List[String] 维度 详细填写参考下文
orderBy String 排序字段
sortOrder String 排序 默认不排序(ASC或者DESC)
limit Integer 返回条数
_userId String 用户id 用户名称(如arms_admin)

调用示例

查询指定应用过往7天的接口调用次数。

参数填写示范:

字段名称 字段类型 字段含义 必选 示例值 值来源
startTime Long 查询数据的起始时间 1577980826988 系统时间
endTime Long 查询数据的截止时间 1578585626989 系统时间
intervalInSec Integer 时间间隔 默认3600秒,即1小时 人工设置
metric String metric字段,查询的指标 APPSTAT.EXCEPTION 人工设置
filters List[String] 过滤字段,严格按照格式,否则调用出错。 [{key=pid,value=1218274334230390@db61f75c2f******},{key=regionId,value=cn-******-d01}] Pid、regionid来自于专有云环境
measures List[String] 指标 [count] API 文档
dimensions List[String] 维度 [pid,rpc,endpoint,exceptionInfo] API文档
orderBy String 排序字段
sortOrder String 排序 默认不排序(ASC或者DESC)
limit Integer 返回条数
_userId String 用户id 1218274334230390

查询结果

参数设置:

图8:参数设置

查询结果:

图9:查询结果

结果说明:

  • 返回结果为JSON数据集。
  • 数据集会标示查询状态,成功返回200,如果失败会返回相应的错误码和错误原因。典型错误例如缺少必要参数、身份认证错误等(是因为filters参数没按格式要求写好)。
  • 本次查询未查到相关数据,所以exception数量为0。

7. 查询当前应用实例数量

通过/metric/Metric.json接口获得应用相关性能数据,查询当前应用实例数量。

API说明

  • URL :http://arms.console.example.com:8099/metric/Metric.json
  • 接口说明:
字段名称 字段类型 字段含义 是否必选 备注
startTime Long 查询数据的起始时间
endTime Long 查询数据的截止时间
intervalInSec Integer 时间间隔 建议填写
metric String metric字段 详细填写参考下文
filters List[String] 过滤字段 详细填写参考下文
measures List[String] 指标 详细填写参考下文
dimensions List[String] 维度 详细填写参考下文
orderBy String 排序字段
sortOrder String 排序 默认不排序(ASC或者DESC)
limit Integer 返回条数
_userId String 用户id 用户名称(如arms_admin)

调用示例

查询指定应用过往7天的接口调用次数。

参数填写示范:

字段名称 字段类型 字段含义 必选 示例值 值来源
startTime Long 查询数据的起始时间 1577980826988 系统时间
endTime Long 查询数据的截止时间 1578585626989 系统时间
intervalInSec Integer 时间间隔 默认3600秒,即1小时 人工设置
metric String metric字段,查询的指标 APPSTAT.DETAIL 人工设置
filters List[String] 过滤字段,严格按照格式,否则调用出错。 [{key=pid,value=1218274334230390@db61f75c2f28609},{key=regionId,value=******}] Pid、regionid来自于专有云环境
measures List[String] 指标 [count] API 文档
dimensions List[String] 维度 [pid,rootIp] API文档
orderBy String 排序字段
sortOrder String 排序 默认不排序(ASC或者DESC)
limit Integer 返回条数
_userId String 用户id 12182743342******

查询结果

参数设置:

图10:参数设置

查询结果:

图11:查询结果

结果说明:

  • 返回结果为JSON数据集。
  • 数据集会标示查询状态,成功返回200,如果失败会返回相应的错误码和错误原因。典型错误例如缺少必要参数、身份认证错误等(是因为filters参数没按格式要求写好)。
  • Openapi返回的结果集组织形式与查询数据的开始时间、结束时间、数据间隔时间有关。本次查询是查询了过往7天,数据间隔时间设置成了24小时,所以这个结果集里返回了7个”data”的集合。
  • 每个data里包括在measuredimension里指定的查询,以本结果集为例,就包括:Count:0.0
    RootIP
  • 本次查询需求是要看此应用一共部署了多少实例,所以对结果中不同IP进行计算,即可以算出共有多少实例数量。另外一个方法是设置intervalInSec的值,让它等查询区间,这样出来的data集合的条数就是实例数量值,因为每个IP都会有条数据。

8. 查询当前应用拓扑图

通过/trace/Dependecies.json接口获得应用拓扑相关数据。

API说明

  • URL :http://arms.console.example.com:8099/trace/Dependecies.json
  • 接口说明:
字段名称 字段类型 字段含义 是否必选 备注
startTime Long 查询数据的起始时间
endTime Long 查询数据的截止时间
_userId String 用户id 用户名称(如arms_admin)
type String 查询类型 查询全部关系使用ALL;单个应用的关系使用APP
pid String 应用对应的pid 当type=APP时必须填写

调用示例

查询指定应用过往7天的接口调用次数。

参数填写示范:

本测试1月12日进行,查询过去7天的数据。

字段名称 字段类型 字段含义 必选 示例值
startTime Long 查询数据的起始时间 1578199319898 (1月5日)
endTime Long 查询数据的截止时间 1578804119898 (1月12日)
_userId String 用户id 1218274334******
type String 查询类型 APP
pid String 应用对应的pid 1218274334230390@db61f75c******

查询结果

参数设置:

图12:参数设置

查询结果:

{"code": 200,"data": {"link": [{"code": 200,"data": {"link": [{"callCount": 26997.0,"child": "Demo-Service","childNodeId": 731107445,"childPid": "1218274334230390@db61f75c2******","elapsed": 16.2328,"errorCount": 16.0,"parent": "USER","parentNodeId": 812148234,"parentPid": "1218274334230390@db61f75c2******","protocol": "HTTP"},{"callCount": 8.0,"child": "pdsa_lhh_rocketmq","childNodeId": -1762019072,"childPid": "pdsa_lhh_rocketmq","elapsed": 11190.5,"errorCount": 8.0,"parent": "Demo-Service","parentNodeId": 731107445,"parentPid": "1218274334230390@db61f75c2******","protocol": "AliWareMQ"}],"nodes": [{"elapsed": 0.0,"errorCount": 0.0,"id": 812148234,"name": "USER","pid": "1218274334230390@db61f75c2******","requestCount": 0.0,"type": "USER"},{"elapsed": 0.0,"errorCount": 0.0,"id": 731107445,"name": "Demo-Service","pid": "1218274334230390@db61f75c2******","requestCount": 0.0,"type": "MQ_PRODUCER"},{"elapsed": 0.0,"errorCount": 0.0,"id": -1762019072,"name": "pdsa_****_rocketmq","pid": "pdsa_****_rocketmq","requestCount": 0.0,"type": "METAQ"}]},"success": true}

实际拓扑图效果如下:

图13:拓扑图

结果说明:

  • 返回结果为JSON数据集。
  • 数据集会标示查询状态,成功返回200,如果失败会返回相应的错误码和错误原因。典型错误例如缺少必要参数、身份认证错误等(是因为filters参数没按格式要求写好)。
  • 查询结果是一个点线图的节点数据和连接数据,需要使用者自行按照图表控件组装相应数据。

我们是阿里云智能全球技术服务-SRE团队,我们致力成为一个以技术为基础、面向服务、保障业务系统高可用的工程师团队;提供专业、体系化的SRE服务,帮助广大客户更好地使用云、基于云构建更加稳定可靠的业务系统,提升业务稳定性。我们期望能够分享更多帮助企业客户上云、用好云,让客户云上业务运行更加稳定可靠的技术,您可用钉钉扫描下方二维码,加入阿里云SRE技术学院钉钉圈子,和更多云上人交流关于云平台的那些事。

原文链接:https://developer.aliyun.com/article/785342?

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

ARMS企业级场景被集成场景介绍相关推荐

  1. 数睿数据受邀参与中俄数字经济高峰论坛,并发布企业级无代码新场景

    2022年中俄数字经济高峰论坛举行,数睿数据受邀参加,并在开幕式上发布企业级无代码应用新场景. 11月3日,以"开源开放 数创未来"为主题的2022年中俄数字经济高峰论坛在中国北京 ...

  2. Learning Cocos2d-x for XNA(6)——场景切换和场景过渡效果

    在进行此部分学习的时候,确保Cocos2d-x for xna引擎的版本为0.1.2(或更高版本),实测0.1.0版本部分功能出现BUG. 之前的源码都是0.1.0版本的,从此次开始都是0.1.2版本 ...

  3. 企业级前端项目组框架vue-fpg介绍

    企业级前端项目组框架vue-fpg介绍 VUE-FPG是什么? VUE-FPG怎么用 常用框架命令: 常用框架指令 常用项目指令 VUE-FPG是什么? VUE-FPG是一套基于VUE框架和Webpa ...

  4. Controller中目标场景及手工场景

    场景是一种用来模拟大量用户操作的技术手段,通过配置和执行场景向服务器产生负载,验证系统各项性能指标是否达到用户要求. 新建场景 1.通过VuGen直接切换当前脚步进入到场景 在菜单下打开Create ...

  5. 3D场景中选取场景中的物体。

    杨航最近在学Unity3D 在一些经典的游戏中,需要玩家在一个3D场景中选取场景中的物体.例如<仙剑奇侠传>,选择要攻击的敌人时.为我方角色增加血量.为我方角色添加状态,通常我们使 ...

  6. mysql memcached 使用场景_memcache 应用场景

    一..memcache应用场景 1.应用场景一: 缓解数据库压力,提高交互速度.它的一个总原则是将经常需要从数据库读取的数据缓存在memcached中.这些数据也分为几类: (1).经常被读取并且实时 ...

  7. Unity3D基础36:场景自适应与场景切换

    前文:https://blog.csdn.net/jaihk662/article/category/8659261 一.场景分辨率 游戏场景分辨率设置 16:9常用分辨率有:1920*1080, 1 ...

  8. flink 出现反压场景, 异常场景造成Exceeded checkpoint tolerable failure threshold.

    flink 出现反压场景,异常场景造成Exceeded checkpoint tolerable failure threshold. 监控反压情况 根据算子的InPool, OutPool 的比例, ...

  9. threejs 加载两个场景_three.js 场景切换

    用6个面组成的立方体作为场景图,发现会出现变形的现象,css3DRenderer 不会变形,但是不方便增加文字,最后采用scene的背景作为场景,背景是用cubeTextureLoader()加载的. ...

最新文章

  1. sqlserver 自增ID插入指定数据
  2. 多列布局——column-width
  3. redis-day1
  4. 【白皮书分享】创新中国2030:释放技术红利,解锁增长动能-埃森哲.pdf(附下载链接)...
  5. 自建服务器调试,Mac简单实现服务器搭建(本地)与iOS调试
  6. 有关科学计算方面的python解决
  7. CUDA学习(二十三)
  8. 菜鸟教程-maven
  9. 软件测试视频课网盘,软件测试工程师必学视频教学全套五合一
  10. php 酒店用户管理系统,酒店宾馆管理系统的设计与实现(PHP,MySQL)
  11. c语言正三角形编程plc,02-C语言实现一个简单PLC仿真小程序(下)
  12. HTML调用Discuz系统变量,Discuz论坛js调用详解
  13. CAS单点登录:CAS客户端搭建(整合Shiro和Spring Boot)
  14. java中的\uxxxx
  15. 创新创意springboot计算机毕业设计题目300例,总有你需要用到的!
  16. 品Spring:详细解说bean后处理器
  17. HTMLCSS选择器
  18. C++常见编译WARNING小结
  19. 极竞而生 ChinaJoy 2021全球电竞大会圆满召开
  20. 数据科学家定位和职业规划

热门文章

  1. java 使用maven 打包 添加本地lib包
  2. intellij idea操作maven时控制台中文乱码
  3. Github | 备战秋招,最全面试题集合!
  4. mysql tcp 远程_MySQL开启远程访问
  5. 郁金香汇编代码注入怎么写看雪_雷军1994年写的诗一样的代码,我把它运行起来了!...
  6. ajax 微信code获取_ajax 实现微信网页授权登录的方法
  7. android sharedpre,Android SharedPreferences四种操作模式使用详解_Android_脚本之家
  8. linux安装多版本php_Linux系统下为Nginx安装多版本PHP
  9. window 10下 Spark 安装简单使用
  10. [TCP/IP] TCP如何保证可靠性