速查列表:Apache SkyWalking OAL 的 域(Scopes)

简介: 在流模式(Streaming mode)下,SkyWalking 提供了 观测分析语言(Observability Analysis Language,OAL) 来分析流入的数据。OAL脚本现在位于/config文件夹,用户可以简单地改变和重新启动服务器,使其有效。但是,OAL脚本仍然是编译语言,OAL运行时动态生成Java代码。可以在系统环境上设置SW_OAL_ENGINE_DEBUG=Y,查看生成了哪些类。

OAL简介

在流模式(Streaming mode)下,SkyWalking 提供了 观测分析语言(Observability Analysis Language,OAL) 来分析流入的数据。

OAL脚本现在位于/config文件夹,用户可以简单地改变和重新启动服务器,使其有效。

但是,OAL脚本仍然是编译语言,OAL运行时动态生成Java代码。可以在系统环境上设置SW_OAL_ENGINE_DEBUG=Y,查看生成了哪些类。

作用域(Scope)

作用域包括全局(All)、服务(Service)、服务实例(Service Instance)、端点(Endpoint)、服务关系(Service Relation)、服务实例关系(Service Instance Relation)、端点关系(Endpoint Relation)。

接下来我来详细了解一下每个作用域。

全局(All)

名称 备注 是否分组键 数据类型
name 表示每个请求对应的服务名称 string
serviceInstanceName 表示引用的服务实例名称 string
endpoint 表示每个请求的端点名称 string
latency 表示每个请求的耗时 int(单位:毫秒)
status 表示请求成功还是失败的状态 bool(true 表示成功)
responseCode 如果该请求是 HTTP 请求, 则表示 HTTP 响应的状态码. 如 200, 404, 302 int
type 表示请求类型,例如: Database, HTTP, RPC, gRPC enum

服务(Service)

按照服务计算每个请求的度量数据。

名称 备注 是否分组键 数据类型
name 表示服务的名称 string
nodeType 表示服务节点或网络地址的类型,如:Normal, Database, MQ, Cache enum
serviceInstanceName 表示引用的服务实例名称 string
endpointName 表示端点的名称, 如:HTTP URI的完整路径 string
latency 表示每个请求的耗时 int
status 表示请求成功还是失败的状态 bool(true 表示成功)
responseCode 如果该请求是 HTTP 请求, 表示 HTTP 请求的响应码 int
type 表示每个请求的类型, 如: Database, HTTP, RPC, gRPC enum

服务实例(Service Instance)

按照服务实例计算每个请求的度量数据。

名称 备注 是否分组键 数据类型
name 表示服务实例名称。现在原生探针使用 uuid@ipv4 作为服务实例名称, 当需要在聚合中设置过滤器(Filter)时,这个毫无用处。 string
nodeType 表示服务节点或网络地址的类型,如:Normal, Database, MQ, Cache enum
serviceName 表示服务的名称 string
endpointName 表示端点的名称, 如 HTTP URI 的完整路径. string
latency 表示每个请求的耗时 int
status 表示请求成功还是失败的状态 bool(true 表示成功)
responseCode 如果该请求是 HTTP 请求, 则表示 HTTP 响应的状态码. 如 200, 404, 302. int
type 表示请求类型,例如: Database, HTTP, RPC, gRPC enum

服务实例(Service Instance)二级作用域

当服务实例是一个 JVM 并且通过 javaagent 收集时,计算服务实例的度量指标。

1. ServiceInstanceJVMCPU

名称 备注 是否分组键 数据类型
name 表示服务实例名称。现在原生探针使用 uuid@ipv4 作为服务实例名称, 当需要在聚合中设置过滤器(Filter)时,这个毫无用处。 string
serviceName 表示服务的名称 string
usePercent 表示 CPU 耗时百分比 double

2. ServiceInstanceJVMMemory

名称 备注 是否分组键 数据类型
name 表示服务实例名称。 现在原生探针使用 uuid@ipv4 作为服务实例名称, 当需要在聚合中设置过滤器(Filter)时,这个毫无用处。 string
serviceName 表示服务的名称 string
heapStatus 表示该指标是否是堆的指标 bool
init 参考 JVM 文档 long
max 参考 JVM 文档 long
used 参考 JVM 文档 long
committed 参考 JVM 文档 long

3. ServiceInstanceJVMMemoryPool

名称 备注 是否分组键 数据类型
name 表示服务实例名称。现在原生探针使用 uuid@ipv4 作为服务实例名称, 当需要在聚合中设置过滤器(Filter)时,这个毫无用处。 string
serviceName 表示服务的名称 string
poolType 根据不同的 JVM 版本, 可能包括 CODE_CACHE_USAGE, NEWGEN_USAGE, OLDGEN_USAGE, SURVIVOR_USAGE, PERMGEN_USAGE, METASPACE_USAGE enum
init 参考 JVM 文档 long
max 参考 JVM 文档 long
used 参考 JVM 文档 long
committed 参考 JVM 文档 long

4. ServiceInstanceJVMGC

名称 备注 是否分组键 数据类型
name 表示服务实例名称。现在原生探针使用 uuid@ipv4 作为服务实例名称, 当需要在聚合中设置过滤器(Filter)时,这个毫无用处。 string
serviceName 表示服务的名称 string
phrase NEW/OLD Enum
time GC 耗时 long
count GC 次数 long

5. ServiceInstanceJVMThread

名称 备注 是否分组键 数据类型
name 表示服务实例名称。现在原生探针使用 uuid@ipv4 作为服务实例名称, 当需要在聚合中设置过滤器(Filter)时,这个毫无用处。 string
serviceName 表示服务的名称 string
liveCount 表示活跃线程的当前数量 int
daemonCount 表示当前守护进程线程的数量 int
peakCount 表示当前峰值线程数 int

端点(Endpoint)

计算服务中每个端点请求的度量指标。

名称 备注 是否分组键 数据类型
name 表示端点的名称, 如 HTTP URI 的完整路径. string
nodeType 表示服务节点或网络地址的类型,如:Normal, Database, MQ, Cache enum
serviceName 表示服务的名称 string
serviceInstanceName 表示引用的服务实例 id 的名称. string
latency 表示每个请求的耗时 int
status 表示请求成功还是失败的状态 bool(true 表示成功)
responseCode 如果该请求是 HTTP 请求, 则表示 HTTP 响应的状态码,如:200, 404, 302. int
type 表示请求类型,例如: Database, HTTP, RPC, gRPC enum

服务关系(Service Relation)

计算服务与服务之间每个请求的度量指标。

名称 备注 是否分组键 数据类型
sourceServiceName 表示源服务的名称 string
sourceServiceNodeType 表示源服务节点或网络地址的类型,如:Normal, Database, MQ, Cache enum
sourceServiceInstanceName 表示源服务实例名称 string
destServiceName 表示目标服务的名称 string
destServiceNodeType 表示目标服务节点或网络地址的类型,如:Normal, Database, MQ, Cache enum
destServiceInstanceName 表示目标服务实例名称 string
endpoint 表示本次调用中使用的端点 string
componentId 表示本次调用中使用到的组件 ID string
latency 表示每个请求的耗时 int
status 表示请求成功还是失败的状态 bool(true 表示成功)
responseCode 如果该请求是 HTTP 请求, 则表示 HTTP 响应的状态码. 如 200, 404, 302. int
type 表示请求类型,例如: Database, HTTP, RPC, gRPC enum
detectPoint 本地请求探测点位置,如:client, server, proxy. enum
tlsMode 表示源服务和目标服务之间的TLS模式,如:service_relation_mtls_cpm = from(ServiceRelation.*).filter(tlsMode == "mTLS").cpm() string

服务实例关系(Service Instance Relation)

计算服务实例与服务实例之间每个请求的度量指标。

名称 备注 是否分组键 数据类型
sourceServiceName 表示源服务的名称 string
sourceServiceNodeType 表示源服务节点或网络地址的类型,如:Normal, Database, MQ, Cache enum
sourceServiceInstanceName 表示源服务实例名称 string
destServiceName 表示目标服务的名称
destServiceNodeType 表示目标服务节点或网络地址的类型,如:Normal, Database, MQ, Cache enum
destServiceInstanceName 表示目标服务实例名称 string
endpoint 表示本次调用中使用的端点 string
componentId 表示本次调用中使用到的组件 ID string
latency 表示每个请求的耗时 int
status 表示请求成功还是失败的状态 bool(true 表示成功)
responseCode 如果该请求是 HTTP 请求, 则表示 HTTP 响应的状态码. 如 200, 404, 302. int
type 表示请求类型,例如: Database, HTTP, RPC, gRPC enum
detectPoint 本地请求探测点位置,如:client, server, proxy. enum
tlsMode 表示源服务和目标服务之间的TLS模式,如:service_relation_mtls_cpm = from(ServiceRelation.*).filter(tlsMode == "mTLS").cpm() string

端点关系(Endpoint Relation)

计算一个端点和另一个端点之间的依赖关系的度量数据。这种关系很难检测,也依赖于跟踪库来传播上一个端点。
所以端点关系范围聚合,仅仅在使用 SkyWalking 原生探针进行追踪的情况下才有效,包括自动打点探针(如 Java, .NET),
OpenCensus SkyWalking exporter以及其他传播追踪上下文的实现.

名称 备注 是否分组键 数据类型
endpoint 表示父级端点名称 string
serviceName 表示父级端点的服务名称 string
serviceNodeType 表示父级端点的服务节点或网络地址的类型,如:Normal, Database, MQ, Cache enum
childEndpoint 表示子父级端点名称 string
childServiceName 表示子级端点的服务名称 string
childServiceNodeType 表示子级端点的服务节点或网络地址的类型,如:Normal, Database, MQ, Cache string
childServiceInstanceName 表示子级端点的服务实例名称 string
rpcLatency 表示RPC请求的耗时,排除了父级端点自身的耗时 int
componentId 表示此调用中使用的组件ID string
status 表示请求成功还是失败的状态 bool(true 表示成功)
responseCode 如果该请求是 HTTP 请求,则表示 HTTP 响应的状态码 int
type 表示请求类型,例如: Database, HTTP, RPC, gRPC enum
detectPoint 本地请求探测点位置,如:client, server, proxy. enum

浏览器传输(BrowserAppTraffic)

计算浏览器应用程序的每个请求的度量数据。

名称 备注 是否分组键 数据类型
name 表示每个请求的浏览器应用程序名称 string
count 表示请求数,固定为1 int
trafficCategory 表示传输类别,如:NORMAL, FIRST_ERROR, ERROR enum
errorCategory 代表错误类别,如:AJAX, RESOURCE, VUE, PROMISE, UNKNOWN enum

浏览器单一版本传输(BrowserAppSingleVersionTraffic)

计算浏览器应用程序中浏览器单一版本的每个请求的度量数据。

名称 备注 是否分组键 数据类型
name 表示每个请求的单一版本名 string
serviceName 表示浏览器应用程序的名称 string
count 表示请求数,固定为1 int
trafficCategory 表示传输类别,如:NORMAL, FIRST_ERROR, ERROR enum
errorCategory 代表错误类别,如:AJAX, RESOURCE, VUE, PROMISE, UNKNOWN enum

浏览器页面传输(BrowserAppPageTraffic)

计算浏览器应用程序中页面的每个请求的度量数据。

名称 备注 是否分组键 数据类型
name 表示每个请求的页面名称 string
serviceName 表示浏览器应用程序的名称 string
count 表示请求数,固定为1 int
trafficCategory 表示传输类别,如:NORMAL, FIRST_ERROR, ERROR enum
errorCategory 代表错误类别,如:AJAX, RESOURCE, VUE, PROMISE, UNKNOWN enum

浏览器页面耗时(BrowserAppPagePerf)

计算浏览器应用程序中页面的每个请求耗时的度量数据。

名称 备注 是否分组键 数据类型
name 表示每个请求的页面名称 string
serviceName 表示浏览器应用程序的名称 string
redirectTime 表示重定向的耗时 int(单位:毫秒)
dnsTime 表示DNS查询的耗时 int(单位:毫秒)
ttfbTime 发出页面请求到接收到应答数据第一个字节所花费的耗时 int(单位:毫秒)
tcpTime TCP连接的耗时 int(单位:毫秒)
transTime 内容传输的耗时 int(单位:毫秒)
domAnalysisTime DOM结构分析的耗时 int(单位:毫秒)
fptTime 首次渲染时间/白屏时间 int(单位:毫秒)
domReadyTime DOM结构准备的耗时 int(单位:毫秒)
loadPageTime 整个页面加载时间 int(in ms)
resTime 页面中同步加载资源的耗时 int(单位:毫秒)
sslTime 仅对HTTPS有效 int(单位:毫秒)
ttlTime 首次交互时间 int(单位:毫秒)
firstPackTime 第一个包的时间 int(单位:毫秒)
fmpTime 首次有效绘制时间 int(单位:毫秒)
注:本文以SkyWalking的8.2.0版本为例进行介绍,如果版本不同会略有差异。
相关实践学习
RocketMQ一站式入门使用
从源码编译、部署broker、部署namesrv,使用java客户端首发消息等一站式入门RocketMQ。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
监控 Java API
图解 Apache SkyWalking UI 的使用
Apache SkyWalking的UI界面主要分为以下几个区域: 功能选择区:这里列出了主要的UI功能,包括仪表盘、拓扑图、追踪、性能刨析、告警等功能 重新加载区:控制重新加载机制,包括定期重新加载或手动重新加载。 时间选择器:控制时区和时间范围。这里有一个中文/英文切换按钮,默认,UI使用浏览器语言设置。 下面逐一介绍功能选择区的各个功能:
1369 0
图解 Apache SkyWalking UI 的使用
|
存储 SQL 缓存
详解 Apache SkyWalking OAP 的分布式计算
SkyWalking的OAP(Observability Analysis Platform,观测分析平台)是一个用于链路数据的分布式计算系统。 因为它巧妙的设计,使得在链路数据计算和聚合过程中,不需要考虑数据的一致性,也没有事务、分布式锁等概念。 在极端情况下,可能出现链路数据的丢失,但会最大限度保障OAP集群的可用性。咱们来看一下,它是如何设计的,为以后的系统设计和架构提供一些思路。
390 0
|
消息中间件 监控 数据可视化
基于Apache SkyWalking构建企业级APM(Application Performance Monitoring)监控系统
基于Apache SkyWalking构建企业级APM(Application Performance Monitoring)监控系统
459 1
基于Apache SkyWalking构建企业级APM(Application Performance Monitoring)监控系统
|
监控 Cloud Native 安全
吴晟:SkyWalking 与 Apache 软件基金会的那些事 | DEV. Together 2021 中国开发者生态峰会
吴晟:SkyWalking 与 Apache 软件基金会的那些事 | DEV. Together 2021 中国开发者生态峰会
618 0
吴晟:SkyWalking 与 Apache 软件基金会的那些事 | DEV. Together 2021 中国开发者生态峰会
|
Apache
详解 Apache SkyWalking 的跨进程传播协议
SkyWalking 跨进程传播协议是用于上下文的传播,本文介绍的版本是3.0,也被称为为sw8协议。
633 0
详解 Apache SkyWalking 的跨进程传播协议
|
Prometheus 监控 Cloud Native
如何开启Apache SkyWalking的自监控?
1. 开启Prometheus遥测数据 默认情况下, 遥测功能(telemetry)是关闭的(selector 为 none),像这样:
362 0
如何开启Apache SkyWalking的自监控?
|
存储 Java Apache
一篇文章快速搞懂 Apache SkyWalking 的 OAL
在流模式(Streaming mode)下,SkyWalking 提供了 观测分析语言(Observability Analysis Language,OAL) 来分析流入的数据。 OAL 聚焦于服务,服务实例以及端点的度量指标,因此 OAL 非常易于学习和使用。 6.3版本以后,OAL引擎嵌入在OAP服务器运行时中,称为oal-rt(OAL运行时)。 OAL脚本现在位于/config文件夹,用户可以简单地改变和重新启动服务器,使其有效。
638 0
|
Apache
Apache SkyWalking 告警动态配置源码简析
AlarmModuleProvider实现了ModuleProvider接口,通过SPI的方式被加载进来。AlarmModuleProvider的prepare方法先被调用,做一些预处理:
264 0
|
JSON Kubernetes Cloud Native
Apache SkyWalking 告警配置指南
Apache SkyWalking是分布式系统的应用程序性能监视工具(Application Performance Management,APM),专为微服务、云原生架构和基于容器(Docker、K8s、Mesos)架构而设计。 它提供了分布式追踪、服务网格遥测分析、度量聚合和可视化一体化解决方案。
1291 0
|
1月前
|
消息中间件 API Apache
官宣|阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会
本文整理自阿里云开源大数据平台徐榜江 (雪尽),关于阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会。
1411 1
官宣|阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会

热门文章

最新文章

推荐镜像

更多