Skip to content

Commit 8ebb52d

Browse files
authored
Adapt new Browser data upload protocol (#13009)
1 parent f5b9463 commit 8ebb52d

File tree

13 files changed

+372
-8
lines changed

13 files changed

+372
-8
lines changed

docs/en/changes/changes.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,7 @@
5858
* MQE: Support `top_n_of` function for merging multiple metrics topn query.
5959
* Support `labelAvg` function in the OAL engine.
6060
* Added `maxLabelCount` parameter in the `labelCount` function of OAL to limit the number of labels can be counted.
61-
* Adapt the new Browser API(`/browser/perfData/webVitals`, `/browser/perfData/resources`) protocol.
61+
* Adapt the new Browser API(`/browser/perfData/webVitals`, `/browser/perfData/webInteractions`, `/browser/perfData/resources`) protocol.
6262
* Add Circuit Breaking mechanism.
6363
* BanyanDB: Add support for compatibility checks based on the BanyanDB server's API version.
6464
* MQE: Support `&&(and)`, `||(or)` bool operators.

oap-server/oal-grammar/src/main/antlr4/org/apache/skywalking/oal/rt/grammar/OALLexer.g4

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -75,6 +75,7 @@ SRC_BROWSER_APP_PAGE_TRAFFIC: 'BrowserAppPageTraffic';
7575
SRC_BROWSER_APP_SINGLE_VERSION_TRAFFIC: 'BrowserAppSingleVersionTraffic';
7676
SRC_BROWSER_APP_RESOURCE_PERF: 'BrowserAppResourcePerf';
7777
SRC_BROWSER_APP_WEB_VITALS_PERF: 'BrowserAppWebVitalsPerf';
78+
SRC_BROWSER_APP_WEB_INTERACTION_PERF: 'BrowserAppWebInteractionPerf';
7879

7980
// Constructors symbols
8081

oap-server/oal-grammar/src/main/antlr4/org/apache/skywalking/oal/rt/grammar/OALParser.g4

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -59,7 +59,7 @@ source
5959
SRC_SERVICE_INSTANCE_CLR_CPU | SRC_SERVICE_INSTANCE_CLR_GC | SRC_SERVICE_INSTANCE_CLR_THREAD |
6060
SRC_SERVICE_INSTANCE_JVM_CPU | SRC_SERVICE_INSTANCE_JVM_MEMORY | SRC_SERVICE_INSTANCE_JVM_MEMORY_POOL | SRC_SERVICE_INSTANCE_JVM_GC | SRC_SERVICE_INSTANCE_JVM_THREAD | SRC_SERVICE_INSTANCE_JVM_CLASS |// JVM source of service instance
6161
SRC_ENVOY_INSTANCE_METRIC |
62-
SRC_BROWSER_APP_PERF | SRC_BROWSER_APP_PAGE_PERF | SRC_BROWSER_APP_SINGLE_VERSION_PERF | SRC_BROWSER_APP_RESOURCE_PERF | SRC_BROWSER_APP_WEB_VITALS_PERF |
62+
SRC_BROWSER_APP_PERF | SRC_BROWSER_APP_PAGE_PERF | SRC_BROWSER_APP_SINGLE_VERSION_PERF | SRC_BROWSER_APP_RESOURCE_PERF | SRC_BROWSER_APP_WEB_VITALS_PERF | SRC_BROWSER_APP_WEB_INTERACTION_PERF |
6363
SRC_BROWSER_APP_TRAFFIC | SRC_BROWSER_APP_PAGE_TRAFFIC | SRC_BROWSER_APP_SINGLE_VERSION_TRAFFIC |
6464
SRC_EVENT | SRC_MQ_ACCESS | SRC_MQ_ENDPOINT_ACCESS |
6565
SRC_K8S_SERVICE | SRC_K8S_SERVICE_INSTANCE | SRC_K8S_ENDPOINT | SRC_K8S_SERVICE_RELATION | SRC_K8S_SERVICE_INSTANCE_RELATION |
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,58 @@
1+
/*
2+
* Licensed to the Apache Software Foundation (ASF) under one or more
3+
* contributor license agreements. See the NOTICE file distributed with
4+
* this work for additional information regarding copyright ownership.
5+
* The ASF licenses this file to You under the Apache License, Version 2.0
6+
* (the "License"); you may not use this file except in compliance with
7+
* the License. You may obtain a copy of the License at
8+
*
9+
* http://www.apache.org/licenses/LICENSE-2.0
10+
*
11+
* Unless required by applicable law or agreed to in writing, software
12+
* distributed under the License is distributed on an "AS IS" BASIS,
13+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14+
* See the License for the specific language governing permissions and
15+
* limitations under the License.
16+
*
17+
*/
18+
19+
package org.apache.skywalking.oap.server.core.browser.source;
20+
21+
import lombok.Getter;
22+
import lombok.Setter;
23+
import org.apache.skywalking.oap.server.core.analysis.IDManager;
24+
import org.apache.skywalking.oap.server.core.source.ScopeDeclaration;
25+
import org.apache.skywalking.oap.server.core.source.ScopeDefaultColumn;
26+
import org.apache.skywalking.oap.server.core.source.Source;
27+
28+
import static org.apache.skywalking.oap.server.core.source.DefaultScopeDefine.BROWSER_APP_WEB_INTERACTION_PAGE_PERF;
29+
import static org.apache.skywalking.oap.server.core.source.DefaultScopeDefine.ENDPOINT_CATALOG_NAME;
30+
31+
@ScopeDeclaration(id = BROWSER_APP_WEB_INTERACTION_PAGE_PERF, name = "BrowserAppWebInteractionPerf", catalog = ENDPOINT_CATALOG_NAME)
32+
@ScopeDefaultColumn.VirtualColumnDefinition(fieldName = "entityId", columnName = "entity_id", isID = true, type = String.class)
33+
@Setter
34+
@Getter
35+
public class BrowserAppWebInteractionPerf extends Source {
36+
@Override
37+
public int scope() {
38+
return BROWSER_APP_WEB_INTERACTION_PAGE_PERF;
39+
}
40+
41+
@Override
42+
public String getEntityId() {
43+
return IDManager.EndpointID.buildId(serviceId, path);
44+
}
45+
46+
@ScopeDefaultColumn.DefinedByField(columnName = "service_id")
47+
@ScopeDefaultColumn.BanyanDB(groupByCondInTopN = true)
48+
private String serviceId;
49+
@ScopeDefaultColumn.DefinedByField(columnName = "service_name", requireDynamicActive = true)
50+
private String serviceName;
51+
private String path;
52+
private int inpTime;
53+
54+
@Override
55+
public void prepare() {
56+
serviceId = IDManager.ServiceID.buildId(serviceName, true);
57+
}
58+
}

oap-server/server-core/src/main/java/org/apache/skywalking/oap/server/core/source/DefaultScopeDefine.java

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -149,6 +149,7 @@ public class DefaultScopeDefine {
149149

150150
public static final int BROWSER_APP_WEB_VITALS_PAGE_PERF = 87;
151151
public static final int BROWSER_APP_RESOURCE_PERF = 88;
152+
public static final int BROWSER_APP_WEB_INTERACTION_PAGE_PERF = 89;
152153

153154
/**
154155
* Catalog of scope, the metrics processor could use this to group all generated metrics by oal rt.

oap-server/server-receiver-plugin/skywalking-browser-receiver-plugin/src/main/java/org/apache/skywalking/oap/server/receiver/browser/provider/BrowserModuleProvider.java

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,8 +38,10 @@
3838
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.PerfDataParserListenerManager;
3939
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserPerfDataDecorator;
4040
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserResourcePerfDataDecorator;
41+
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserWebInteractionPerfDataDecorator;
4142
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserWebVitalsPerfDataDecorator;
4243
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.listener.BrowserPerfDataAnalysisListener;
44+
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.listener.BrowserWebInteractionPerfDataAnalysisListener;
4345
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.listener.BrowserWebResourcePerfDataAnalysisListener;
4446
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.listener.BrowserWebVitalsPerfDataAnalysisListener;
4547
import org.apache.skywalking.oap.server.receiver.sharing.server.SharingServerModule;
@@ -126,6 +128,7 @@ private PerfDataParserListenerManager perfDataListenerManager() {
126128
listenerManager.add(BrowserPerfDataDecorator.class, new BrowserPerfDataAnalysisListener.Factory(getManager(), moduleConfig));
127129
listenerManager.add(BrowserWebVitalsPerfDataDecorator.class, new BrowserWebVitalsPerfDataAnalysisListener.Factory(getManager(), moduleConfig));
128130
listenerManager.add(BrowserResourcePerfDataDecorator.class, new BrowserWebResourcePerfDataAnalysisListener.Factory(getManager(), moduleConfig));
131+
listenerManager.add(BrowserWebInteractionPerfDataDecorator.class, new BrowserWebInteractionPerfDataAnalysisListener.Factory(getManager(), moduleConfig));
129132
return listenerManager;
130133
}
131134

oap-server/server-receiver-plugin/skywalking-browser-receiver-plugin/src/main/java/org/apache/skywalking/oap/server/receiver/browser/provider/handler/grpc/BrowserPerfServiceHandler.java

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@
2424
import org.apache.skywalking.apm.network.language.agent.v3.BrowserPerfData;
2525
import org.apache.skywalking.apm.network.language.agent.v3.BrowserPerfServiceGrpc;
2626
import org.apache.skywalking.apm.network.language.agent.v3.BrowserResourcePerfData;
27+
import org.apache.skywalking.apm.network.language.agent.v3.BrowserWebInteractionsPerfData;
2728
import org.apache.skywalking.apm.network.language.agent.v3.BrowserWebVitalsPerfData;
2829
import org.apache.skywalking.oap.server.library.module.ModuleManager;
2930
import org.apache.skywalking.oap.server.library.server.grpc.GRPCHandler;
@@ -34,6 +35,7 @@
3435
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.PerfDataAnalyzer;
3536
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.PerfDataParserListenerManager;
3637
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserResourcePerfDataDecorator;
38+
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserWebInteractionPerfDataDecorator;
3739
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserWebVitalsPerfDataDecorator;
3840
import org.apache.skywalking.oap.server.telemetry.TelemetryModule;
3941
import org.apache.skywalking.oap.server.telemetry.api.CounterMetrics;
@@ -150,6 +152,25 @@ public void collectWebVitalsPerfData(BrowserWebVitalsPerfData request, StreamObs
150152
}
151153
}
152154

155+
@Override
156+
public void collectWebInteractionsPerfData(BrowserWebInteractionsPerfData request, StreamObserver<Commands> responseObserver) {
157+
if (log.isDebugEnabled()) {
158+
log.debug("receive browser web interaction performance data");
159+
}
160+
HistogramMetrics.Timer timer = perfHistogram.createTimer();
161+
try {
162+
PerfDataAnalyzer analyzer = new PerfDataAnalyzer(perfDataListenerManager);
163+
analyzer.doAnalysis(new BrowserWebInteractionPerfDataDecorator(request));
164+
} catch (Throwable e) {
165+
log.error(e.getMessage(), e);
166+
perfErrorCounter.inc();
167+
} finally {
168+
timer.finish();
169+
responseObserver.onNext(Commands.newBuilder().build());
170+
responseObserver.onCompleted();
171+
}
172+
}
173+
153174
@Override
154175
public StreamObserver<BrowserErrorLog> collectErrorLogs(final StreamObserver<Commands> responseObserver) {
155176
return new StreamObserver<BrowserErrorLog>() {

oap-server/server-receiver-plugin/skywalking-browser-receiver-plugin/src/main/java/org/apache/skywalking/oap/server/receiver/browser/provider/handler/rest/BrowserPerfServiceHTTPHandler.java

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@
2424
import org.apache.skywalking.apm.network.language.agent.v3.BrowserErrorLog;
2525
import org.apache.skywalking.apm.network.language.agent.v3.BrowserPerfData;
2626
import org.apache.skywalking.apm.network.language.agent.v3.BrowserResourcePerfData;
27+
import org.apache.skywalking.apm.network.language.agent.v3.BrowserWebInteractionsPerfData;
2728
import org.apache.skywalking.apm.network.language.agent.v3.BrowserWebVitalsPerfData;
2829
import org.apache.skywalking.oap.server.library.module.ModuleManager;
2930
import org.apache.skywalking.oap.server.receiver.browser.provider.BrowserServiceModuleConfig;
@@ -33,6 +34,7 @@
3334
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.PerfDataAnalyzer;
3435
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.PerfDataParserListenerManager;
3536
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserResourcePerfDataDecorator;
37+
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserWebInteractionPerfDataDecorator;
3638
import org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators.BrowserWebVitalsPerfDataDecorator;
3739
import org.apache.skywalking.oap.server.telemetry.TelemetryModule;
3840
import org.apache.skywalking.oap.server.telemetry.api.CounterMetrics;
@@ -159,4 +161,19 @@ public Commands collectResourcesPerfData(final List<BrowserResourcePerfData> res
159161
throw e;
160162
}
161163
}
164+
165+
@Post("/browser/perfData/webInteractions")
166+
public Commands collectWebInteractionsPerfData(final List<BrowserWebInteractionsPerfData> perfDataList) {
167+
try (HistogramMetrics.Timer ignored = perfHistogram.createTimer()) {
168+
perfDataList.forEach(perfData -> {
169+
final PerfDataAnalyzer analyzer = new PerfDataAnalyzer(perfDataListenerManager);
170+
analyzer.doAnalysis(new BrowserWebInteractionPerfDataDecorator(perfData));
171+
});
172+
return Commands.newBuilder().build();
173+
} catch (Throwable e) {
174+
log.error(e.getMessage(), e);
175+
perfErrorCounter.inc();
176+
throw e;
177+
}
178+
}
162179
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,67 @@
1+
/*
2+
* Licensed to the Apache Software Foundation (ASF) under one or more
3+
* contributor license agreements. See the NOTICE file distributed with
4+
* this work for additional information regarding copyright ownership.
5+
* The ASF licenses this file to You under the Apache License, Version 2.0
6+
* (the "License"); you may not use this file except in compliance with
7+
* the License. You may obtain a copy of the License at
8+
*
9+
* http://www.apache.org/licenses/LICENSE-2.0
10+
*
11+
* Unless required by applicable law or agreed to in writing, software
12+
* distributed under the License is distributed on an "AS IS" BASIS,
13+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14+
* See the License for the specific language governing permissions and
15+
* limitations under the License.
16+
*
17+
*/
18+
19+
package org.apache.skywalking.oap.server.receiver.browser.provider.parser.performance.decorators;
20+
21+
import org.apache.skywalking.apm.network.language.agent.v3.BrowserWebInteractionsPerfData;
22+
23+
public class BrowserWebInteractionPerfDataDecorator implements BrowserPerfDecorator {
24+
private BrowserWebInteractionsPerfData.Builder builder;
25+
26+
public BrowserWebInteractionPerfDataDecorator(BrowserWebInteractionsPerfData data) {
27+
this.builder = data.toBuilder();
28+
}
29+
30+
@Override
31+
public String getService() {
32+
return builder.getService();
33+
}
34+
35+
@Override
36+
public void setTime(long time) {
37+
builder.setTime(time);
38+
}
39+
40+
@Override
41+
public String getServiceVersion() {
42+
return builder.getServiceVersion();
43+
}
44+
45+
@Override
46+
public void setServiceVersion(String serviceVersion) {
47+
builder.setServiceVersion(serviceVersion);
48+
}
49+
50+
@Override
51+
public String getPagePath() {
52+
return builder.getPagePath();
53+
}
54+
55+
@Override
56+
public void setPagePath(String pagePath) {
57+
builder.setPagePath(pagePath);
58+
}
59+
60+
public int getInpTime() {
61+
return builder.getInpTime();
62+
}
63+
64+
public long getTime() {
65+
return builder.getTime();
66+
}
67+
}

0 commit comments

Comments
 (0)