From acd01d0d4802372f32d0617cc2d49770857663fe Mon Sep 17 00:00:00 2001 From: Nick Dimiduk Date: Tue, 16 Nov 2021 09:36:26 -0800 Subject: [PATCH 1/3] HBASE-26471 Move tracing semantic attributes to their own class --- .../hbase/client/AsyncConnectionImpl.java | 5 +- .../hbase/client/AsyncRegionLocator.java | 4 +- .../hadoop/hbase/ipc/AbstractRpcClient.java | 13 +++-- .../client/TestAsyncConnectionTracing.java | 4 +- .../client/TestAsyncRegionLocatorTracing.java | 20 ++++---- .../hbase/client/TestAsyncTableTracing.java | 9 ++-- .../hbase/trace/HBaseSemanticAttributes.java | 48 +++++++++++++++++++ .../apache/hadoop/hbase/trace/TraceUtil.java | 34 ++----------- .../apache/hadoop/hbase/ipc/CallRunner.java | 7 ++- .../hadoop/hbase/regionserver/HRegion.java | 9 ++-- .../hbase/regionserver/wal/AbstractFSWAL.java | 4 +- .../hadoop/hbase/ipc/AbstractTestIPC.java | 10 ++-- .../regionserver/TestHRegionTracing.java | 4 +- 13 files changed, 105 insertions(+), 66 deletions(-) create mode 100644 hbase-common/src/main/java/org/apache/hadoop/hbase/trace/HBaseSemanticAttributes.java diff --git a/hbase-client/src/main/java/org/apache/hadoop/hbase/client/AsyncConnectionImpl.java b/hbase-client/src/main/java/org/apache/hadoop/hbase/client/AsyncConnectionImpl.java index 28e3456c90e8..1ba4d6d6489f 100644 --- a/hbase-client/src/main/java/org/apache/hadoop/hbase/client/AsyncConnectionImpl.java +++ b/hbase-client/src/main/java/org/apache/hadoop/hbase/client/AsyncConnectionImpl.java @@ -1,4 +1,4 @@ -/** +/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information @@ -25,6 +25,7 @@ import static org.apache.hadoop.hbase.client.ConnectionUtils.getStubKey; import static org.apache.hadoop.hbase.client.MetricsConnection.CLIENT_SIDE_METRICS_ENABLED_KEY; import static org.apache.hadoop.hbase.client.NonceGenerator.CLIENT_NONCES_ENABLED_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.SERVER_NAME_KEY; import static org.apache.hadoop.hbase.util.FutureUtils.addListener; import io.opentelemetry.api.trace.Span; @@ -410,7 +411,7 @@ public Connection toConnection() { } private Hbck getHbckInternal(ServerName masterServer) { - Span.current().setAttribute(TraceUtil.SERVER_NAME_KEY, masterServer.getServerName()); + Span.current().setAttribute(SERVER_NAME_KEY, masterServer.getServerName()); // we will not create a new connection when creating a new protobuf stub, and for hbck there // will be no performance consideration, so for simplification we will create a new stub every // time instead of caching the stub here. diff --git a/hbase-client/src/main/java/org/apache/hadoop/hbase/client/AsyncRegionLocator.java b/hbase-client/src/main/java/org/apache/hadoop/hbase/client/AsyncRegionLocator.java index 716598af432f..5110b46d2257 100644 --- a/hbase-client/src/main/java/org/apache/hadoop/hbase/client/AsyncRegionLocator.java +++ b/hbase-client/src/main/java/org/apache/hadoop/hbase/client/AsyncRegionLocator.java @@ -18,8 +18,8 @@ package org.apache.hadoop.hbase.client; import static org.apache.hadoop.hbase.TableName.META_TABLE_NAME; -import static org.apache.hadoop.hbase.trace.TraceUtil.REGION_NAMES_KEY; -import static org.apache.hadoop.hbase.trace.TraceUtil.SERVER_NAME_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.REGION_NAMES_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.SERVER_NAME_KEY; import static org.apache.hadoop.hbase.trace.TraceUtil.createSpan; import static org.apache.hadoop.hbase.trace.TraceUtil.createTableSpan; import static org.apache.hadoop.hbase.util.FutureUtils.addListener; diff --git a/hbase-client/src/main/java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java b/hbase-client/src/main/java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java index ee516ae9dd67..08bba5ce9876 100644 --- a/hbase-client/src/main/java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java +++ b/hbase-client/src/main/java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java @@ -20,6 +20,10 @@ import static org.apache.hadoop.hbase.ipc.IPCUtil.toIOE; import static org.apache.hadoop.hbase.ipc.IPCUtil.wrapException; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.REMOTE_HOST_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.REMOTE_PORT_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.RPC_METHOD_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.RPC_SERVICE_KEY; import io.opentelemetry.api.trace.Span; import io.opentelemetry.api.trace.StatusCode; @@ -41,6 +45,7 @@ import org.apache.hadoop.hbase.net.Address; import org.apache.hadoop.hbase.security.User; import org.apache.hadoop.hbase.security.UserProvider; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.trace.TraceUtil; import org.apache.hadoop.hbase.util.EnvironmentEdgeManager; import org.apache.hadoop.hbase.util.PoolMap; @@ -396,10 +401,10 @@ private Call callMethod(final Descriptors.MethodDescriptor md, final HBaseRpcCon final Message param, Message returnType, final User ticket, final Address addr, final RpcCallback callback) { Span span = TraceUtil.createClientSpan("RpcClient.callMethod") - .setAttribute(TraceUtil.RPC_SERVICE_KEY, md.getService().getName()) - .setAttribute(TraceUtil.RPC_METHOD_KEY, md.getName()) - .setAttribute(TraceUtil.REMOTE_HOST_KEY, addr.getHostName()) - .setAttribute(TraceUtil.REMOTE_PORT_KEY, addr.getPort()); + .setAttribute(RPC_SERVICE_KEY, md.getService().getName()) + .setAttribute(RPC_METHOD_KEY, md.getName()) + .setAttribute(REMOTE_HOST_KEY, addr.getHostName()) + .setAttribute(REMOTE_PORT_KEY, addr.getPort()); try (Scope scope = span.makeCurrent()) { final MetricsConnection.CallStats cs = MetricsConnection.newCallStats(); cs.setStartTime(EnvironmentEdgeManager.currentTime()); diff --git a/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncConnectionTracing.java b/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncConnectionTracing.java index eef0b1392f7d..b344ff5febc5 100644 --- a/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncConnectionTracing.java +++ b/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncConnectionTracing.java @@ -33,7 +33,7 @@ import org.apache.hadoop.hbase.security.UserProvider; import org.apache.hadoop.hbase.testclassification.ClientTests; import org.apache.hadoop.hbase.testclassification.MediumTests; -import org.apache.hadoop.hbase.trace.TraceUtil; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.util.EnvironmentEdgeManager; import org.junit.After; import org.junit.Before; @@ -89,7 +89,7 @@ private void assertTrace(String methodName, ServerName serverName) { assertEquals(StatusCode.OK, data.getStatus().getStatusCode()); if (serverName != null) { assertEquals(serverName.getServerName(), - data.getAttributes().get(TraceUtil.SERVER_NAME_KEY)); + data.getAttributes().get(HBaseSemanticAttributes.SERVER_NAME_KEY)); } } diff --git a/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncRegionLocatorTracing.java b/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncRegionLocatorTracing.java index 15b00f6e65f0..83a71db3b960 100644 --- a/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncRegionLocatorTracing.java +++ b/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncRegionLocatorTracing.java @@ -38,7 +38,7 @@ import org.apache.hadoop.hbase.security.UserProvider; import org.apache.hadoop.hbase.testclassification.ClientTests; import org.apache.hadoop.hbase.testclassification.MediumTests; -import org.apache.hadoop.hbase.trace.TraceUtil; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.util.EnvironmentEdgeManager; import org.junit.After; import org.junit.Before; @@ -109,7 +109,7 @@ public void testClearCacheServerName() { conn.getLocator().clearCache(sn); SpanData span = waitSpan("AsyncRegionLocator.clearCache"); assertEquals(StatusCode.OK, span.getStatus().getStatusCode()); - assertEquals(sn.toString(), span.getAttributes().get(TraceUtil.SERVER_NAME_KEY)); + assertEquals(sn.toString(), span.getAttributes().get(HBaseSemanticAttributes.SERVER_NAME_KEY)); } @Test @@ -118,9 +118,9 @@ public void testClearCacheTableName() { SpanData span = waitSpan("AsyncRegionLocator.clearCache"); assertEquals(StatusCode.OK, span.getStatus().getStatusCode()); assertEquals(TableName.META_TABLE_NAME.getNamespaceAsString(), - span.getAttributes().get(TraceUtil.NAMESPACE_KEY)); + span.getAttributes().get(HBaseSemanticAttributes.NAMESPACE_KEY)); assertEquals(TableName.META_TABLE_NAME.getNameAsString(), - span.getAttributes().get(TraceUtil.TABLE_KEY)); + span.getAttributes().get(HBaseSemanticAttributes.TABLE_KEY)); } @Test @@ -130,10 +130,10 @@ public void testGetRegionLocation() { SpanData span = waitSpan("AsyncRegionLocator.getRegionLocation"); assertEquals(StatusCode.OK, span.getStatus().getStatusCode()); assertEquals(TableName.META_TABLE_NAME.getNamespaceAsString(), - span.getAttributes().get(TraceUtil.NAMESPACE_KEY)); + span.getAttributes().get(HBaseSemanticAttributes.NAMESPACE_KEY)); assertEquals(TableName.META_TABLE_NAME.getNameAsString(), - span.getAttributes().get(TraceUtil.TABLE_KEY)); - List regionNames = span.getAttributes().get(TraceUtil.REGION_NAMES_KEY); + span.getAttributes().get(HBaseSemanticAttributes.TABLE_KEY)); + List regionNames = span.getAttributes().get(HBaseSemanticAttributes.REGION_NAMES_KEY); assertEquals(1, regionNames.size()); assertEquals(locs.getDefaultRegionLocation().getRegion().getRegionNameAsString(), regionNames.get(0)); @@ -146,10 +146,10 @@ public void testGetRegionLocations() { SpanData span = waitSpan("AsyncRegionLocator.getRegionLocations"); assertEquals(StatusCode.OK, span.getStatus().getStatusCode()); assertEquals(TableName.META_TABLE_NAME.getNamespaceAsString(), - span.getAttributes().get(TraceUtil.NAMESPACE_KEY)); + span.getAttributes().get(HBaseSemanticAttributes.NAMESPACE_KEY)); assertEquals(TableName.META_TABLE_NAME.getNameAsString(), - span.getAttributes().get(TraceUtil.TABLE_KEY)); - List regionNames = span.getAttributes().get(TraceUtil.REGION_NAMES_KEY); + span.getAttributes().get(HBaseSemanticAttributes.TABLE_KEY)); + List regionNames = span.getAttributes().get(HBaseSemanticAttributes.REGION_NAMES_KEY); assertEquals(3, regionNames.size()); for (int i = 0; i < 3; i++) { assertEquals(locs.getRegionLocation(i).getRegion().getRegionNameAsString(), diff --git a/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncTableTracing.java b/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncTableTracing.java index 0be9bdbd82e2..4e38fca3efc9 100644 --- a/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncTableTracing.java +++ b/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncTableTracing.java @@ -17,6 +17,8 @@ */ package org.apache.hadoop.hbase.client; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.NAMESPACE_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.TABLE_KEY; import static org.junit.Assert.assertEquals; import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.anyInt; @@ -48,7 +50,7 @@ import org.apache.hadoop.hbase.security.UserProvider; import org.apache.hadoop.hbase.testclassification.ClientTests; import org.apache.hadoop.hbase.testclassification.MediumTests; -import org.apache.hadoop.hbase.trace.TraceUtil; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.util.Bytes; import org.junit.After; import org.junit.Before; @@ -227,9 +229,8 @@ private void assertTrace(String methodName) { .filter(s -> s.getName().equals("AsyncTable." + methodName)).findFirst().get(); assertEquals(StatusCode.OK, data.getStatus().getStatusCode()); TableName tableName = table.getName(); - assertEquals(tableName.getNamespaceAsString(), - data.getAttributes().get(TraceUtil.NAMESPACE_KEY)); - assertEquals(tableName.getNameAsString(), data.getAttributes().get(TraceUtil.TABLE_KEY)); + assertEquals(tableName.getNamespaceAsString(), data.getAttributes().get(NAMESPACE_KEY)); + assertEquals(tableName.getNameAsString(), data.getAttributes().get(TABLE_KEY)); } @Test diff --git a/hbase-common/src/main/java/org/apache/hadoop/hbase/trace/HBaseSemanticAttributes.java b/hbase-common/src/main/java/org/apache/hadoop/hbase/trace/HBaseSemanticAttributes.java new file mode 100644 index 000000000000..1eb5d820d998 --- /dev/null +++ b/hbase-common/src/main/java/org/apache/hadoop/hbase/trace/HBaseSemanticAttributes.java @@ -0,0 +1,48 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.apache.hadoop.hbase.trace; + +import io.opentelemetry.api.common.AttributeKey; +import io.opentelemetry.semconv.trace.attributes.SemanticAttributes; +import java.util.List; +import org.apache.yetus.audience.InterfaceAudience; + +/** + * The constants in this class correspond with the guidance outlined by the OpenTelemetry + * Semantic Conventions. +*/ +@InterfaceAudience.Private +public final class HBaseSemanticAttributes { + public static final AttributeKey NAMESPACE_KEY = SemanticAttributes.DB_HBASE_NAMESPACE; + public static final AttributeKey TABLE_KEY = AttributeKey.stringKey("db.hbase.table"); + public static final AttributeKey> REGION_NAMES_KEY = + AttributeKey.stringArrayKey("db.hbase.regions"); + public static final AttributeKey RPC_SERVICE_KEY = + AttributeKey.stringKey("db.hbase.rpc.service"); + public static final AttributeKey RPC_METHOD_KEY = + AttributeKey.stringKey("db.hbase.rpc.method"); + public static final AttributeKey SERVER_NAME_KEY = + AttributeKey.stringKey("db.hbase.server.name"); + public static final AttributeKey REMOTE_HOST_KEY = SemanticAttributes.NET_PEER_NAME; + public static final AttributeKey REMOTE_PORT_KEY = SemanticAttributes.NET_PEER_PORT; + public static final AttributeKey ROW_LOCK_READ_LOCK_KEY = + AttributeKey.booleanKey("db.hbase.rowlock.readlock"); + public static final AttributeKey WAL_IMPL = AttributeKey.stringKey("db.hbase.wal.impl"); + + private HBaseSemanticAttributes() { } +} diff --git a/hbase-common/src/main/java/org/apache/hadoop/hbase/trace/TraceUtil.java b/hbase-common/src/main/java/org/apache/hadoop/hbase/trace/TraceUtil.java index 74e6daa1ed77..e360705916dd 100644 --- a/hbase-common/src/main/java/org/apache/hadoop/hbase/trace/TraceUtil.java +++ b/hbase-common/src/main/java/org/apache/hadoop/hbase/trace/TraceUtil.java @@ -1,4 +1,4 @@ -/** +/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information @@ -17,15 +17,15 @@ */ package org.apache.hadoop.hbase.trace; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.NAMESPACE_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.TABLE_KEY; import io.opentelemetry.api.GlobalOpenTelemetry; -import io.opentelemetry.api.common.AttributeKey; import io.opentelemetry.api.trace.Span; import io.opentelemetry.api.trace.SpanKind; import io.opentelemetry.api.trace.StatusCode; import io.opentelemetry.api.trace.Tracer; import io.opentelemetry.context.Context; import io.opentelemetry.context.Scope; -import io.opentelemetry.semconv.trace.attributes.SemanticAttributes; import java.io.IOException; import java.util.List; import java.util.concurrent.CompletableFuture; @@ -38,31 +38,6 @@ @InterfaceAudience.Private public final class TraceUtil { - public static final AttributeKey NAMESPACE_KEY = SemanticAttributes.DB_HBASE_NAMESPACE; - - public static final AttributeKey TABLE_KEY = AttributeKey.stringKey("db.hbase.table"); - - public static final AttributeKey> REGION_NAMES_KEY = - AttributeKey.stringArrayKey("db.hbase.regions"); - - public static final AttributeKey RPC_SERVICE_KEY = - AttributeKey.stringKey("db.hbase.rpc.service"); - - public static final AttributeKey RPC_METHOD_KEY = - AttributeKey.stringKey("db.hbase.rpc.method"); - - public static final AttributeKey SERVER_NAME_KEY = - AttributeKey.stringKey("db.hbase.server.name"); - - public static final AttributeKey REMOTE_HOST_KEY = SemanticAttributes.NET_PEER_NAME; - - public static final AttributeKey REMOTE_PORT_KEY = SemanticAttributes.NET_PEER_PORT; - - public static final AttributeKey ROW_LOCK_READ_LOCK_KEY = - AttributeKey.booleanKey("db.hbase.rowlock.readlock"); - - public static final AttributeKey WAL_IMPL = AttributeKey.stringKey("db.hbase.wal.impl"); - private TraceUtil() { } @@ -81,7 +56,8 @@ public static Span createSpan(String name) { * Create a {@link SpanKind#INTERNAL} span and set table related attributes. */ public static Span createTableSpan(String spanName, TableName tableName) { - return createSpan(spanName).setAttribute(NAMESPACE_KEY, tableName.getNamespaceAsString()) + return createSpan(spanName) + .setAttribute(NAMESPACE_KEY, tableName.getNamespaceAsString()) .setAttribute(TABLE_KEY, tableName.getNameAsString()); } diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/ipc/CallRunner.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/ipc/CallRunner.java index 6e2c37e3a8c5..17367a21f2d5 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/ipc/CallRunner.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/ipc/CallRunner.java @@ -17,6 +17,8 @@ */ package org.apache.hadoop.hbase.ipc; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.RPC_METHOD_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.RPC_SERVICE_KEY; import io.opentelemetry.api.trace.Span; import io.opentelemetry.api.trace.StatusCode; import io.opentelemetry.context.Context; @@ -30,6 +32,7 @@ import org.apache.hadoop.hbase.exceptions.TimeoutIOException; import org.apache.hadoop.hbase.monitoring.MonitoredRPCHandler; import org.apache.hadoop.hbase.security.User; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.trace.TraceUtil; import org.apache.hadoop.hbase.util.EnvironmentEdgeManager; import org.apache.hadoop.hbase.util.Pair; @@ -124,8 +127,8 @@ public void run() { String methodName = getMethodName(); Span span = TraceUtil.getGlobalTracer().spanBuilder("RpcServer.callMethod") .setParent(Context.current().with(((ServerCall) call).getSpan())).startSpan() - .setAttribute(TraceUtil.RPC_SERVICE_KEY, serviceName) - .setAttribute(TraceUtil.RPC_METHOD_KEY, methodName); + .setAttribute(RPC_SERVICE_KEY, serviceName) + .setAttribute(RPC_METHOD_KEY, methodName); try (Scope traceScope = span.makeCurrent()) { if (!this.rpcServer.isStarted()) { InetSocketAddress address = rpcServer.getListenerAddress(); diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java index b534f6847403..77539a9d6535 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java @@ -19,6 +19,8 @@ import static org.apache.hadoop.hbase.HConstants.REPLICATION_SCOPE_LOCAL; import static org.apache.hadoop.hbase.regionserver.HStoreFile.MAJOR_COMPACTION_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.REGION_NAMES_KEY; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.ROW_LOCK_READ_LOCK_KEY; import static org.apache.hadoop.hbase.util.ConcurrentMapUtils.computeIfAbsent; import edu.umd.cs.findbugs.annotations.Nullable; @@ -155,6 +157,7 @@ import org.apache.hadoop.hbase.security.User; import org.apache.hadoop.hbase.snapshot.SnapshotDescriptionUtils; import org.apache.hadoop.hbase.snapshot.SnapshotManifest; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.trace.TraceUtil; import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.CancelableProgressable; @@ -6591,8 +6594,8 @@ public RowLock getRowLock(byte[] row, boolean readLock) throws IOException { } Span createRegionSpan(String name) { - return TraceUtil.createSpan(name).setAttribute(TraceUtil.REGION_NAMES_KEY, - Arrays.asList(getRegionInfo().getRegionNameAsString())); + return TraceUtil.createSpan(name).setAttribute(REGION_NAMES_KEY, + Collections.singletonList(getRegionInfo().getRegionNameAsString())); } // will be override in tests @@ -6679,7 +6682,7 @@ protected RowLock getRowLockInternal(byte[] row, boolean readLock, RowLock prevR private RowLock getRowLock(byte[] row, boolean readLock, final RowLock prevRowLock) throws IOException { return TraceUtil.trace(() -> getRowLockInternal(row, readLock, prevRowLock), - () -> createRegionSpan("Region.getRowLock").setAttribute(TraceUtil.ROW_LOCK_READ_LOCK_KEY, + () -> createRegionSpan("Region.getRowLock").setAttribute(ROW_LOCK_READ_LOCK_KEY, readLock)); } diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java index 002d9b776dc4..f5232ab22bb1 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java @@ -20,6 +20,7 @@ import static org.apache.hadoop.hbase.regionserver.wal.WALActionsListener.RollRequestReason.ERROR; import static org.apache.hadoop.hbase.regionserver.wal.WALActionsListener.RollRequestReason.LOW_REPLICATION; import static org.apache.hadoop.hbase.regionserver.wal.WALActionsListener.RollRequestReason.SLOW_SYNC; +import static org.apache.hadoop.hbase.trace.HBaseSemanticAttributes.WAL_IMPL; import static org.apache.hadoop.hbase.wal.AbstractFSWALProvider.WAL_FILE_NAME_DELIMITER; import static org.apache.hbase.thirdparty.com.google.common.base.Preconditions.checkArgument; import static org.apache.hbase.thirdparty.com.google.common.base.Preconditions.checkNotNull; @@ -69,6 +70,7 @@ import org.apache.hadoop.hbase.log.HBaseMarkers; import org.apache.hadoop.hbase.regionserver.HRegion; import org.apache.hadoop.hbase.regionserver.MultiVersionConcurrencyControl; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.trace.TraceUtil; import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.CommonFSUtils; @@ -841,7 +843,7 @@ protected final void logRollAndSetupWalProps(Path oldPath, Path newPath, long ol } private Span createSpan(String name) { - return TraceUtil.createSpan(name).setAttribute(TraceUtil.WAL_IMPL, implClassName); + return TraceUtil.createSpan(name).setAttribute(WAL_IMPL, implClassName); } /** diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java index ce753430b333..c1fbfed4e4f6 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java @@ -53,7 +53,7 @@ import org.apache.hadoop.hbase.Server; import org.apache.hadoop.hbase.Waiter; import org.apache.hadoop.hbase.ipc.RpcServer.BlockingServiceAndInterface; -import org.apache.hadoop.hbase.trace.TraceUtil; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.io.compress.GzipCodec; import org.apache.hadoop.util.StringUtils; @@ -459,11 +459,11 @@ private SpanData waitSpan(String name) { private void assertRpcAttribute(SpanData data, String methodName, InetSocketAddress addr, SpanKind kind) { assertEquals(SERVICE.getDescriptorForType().getName(), - data.getAttributes().get(TraceUtil.RPC_SERVICE_KEY)); - assertEquals(methodName, data.getAttributes().get(TraceUtil.RPC_METHOD_KEY)); + data.getAttributes().get(HBaseSemanticAttributes.RPC_SERVICE_KEY)); + assertEquals(methodName, data.getAttributes().get(HBaseSemanticAttributes.RPC_METHOD_KEY)); if (addr != null) { - assertEquals(addr.getHostName(), data.getAttributes().get(TraceUtil.REMOTE_HOST_KEY)); - assertEquals(addr.getPort(), data.getAttributes().get(TraceUtil.REMOTE_PORT_KEY).intValue()); + assertEquals(addr.getHostName(), data.getAttributes().get(HBaseSemanticAttributes.REMOTE_HOST_KEY)); + assertEquals(addr.getPort(), data.getAttributes().get(HBaseSemanticAttributes.REMOTE_PORT_KEY).intValue()); } assertEquals(kind, data.getKind()); } diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestHRegionTracing.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestHRegionTracing.java index 0b4ec8f6a99a..62f8a150bcf4 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestHRegionTracing.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestHRegionTracing.java @@ -43,7 +43,7 @@ import org.apache.hadoop.hbase.client.TableDescriptorBuilder; import org.apache.hadoop.hbase.testclassification.MediumTests; import org.apache.hadoop.hbase.testclassification.RegionServerTests; -import org.apache.hadoop.hbase.trace.TraceUtil; +import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.wal.WAL; import org.junit.After; @@ -115,7 +115,7 @@ private void assertSpan(String spanName) { if (!span.getName().equals(spanName)) { return false; } - List regionNames = span.getAttributes().get(TraceUtil.REGION_NAMES_KEY); + List regionNames = span.getAttributes().get(HBaseSemanticAttributes.REGION_NAMES_KEY); return regionNames != null && regionNames.size() == 1 && regionNames.get(0).equals(region.getRegionInfo().getRegionNameAsString()); })); From b500e8526db04d43f941d4e958a8d03ac06660fa Mon Sep 17 00:00:00 2001 From: Nick Dimiduk Date: Tue, 30 Nov 2021 07:16:10 -0800 Subject: [PATCH 2/3] fix checkstyle nits --- .../java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java | 3 +-- .../org/apache/hadoop/hbase/client/TestAsyncTableTracing.java | 3 +-- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/hbase-client/src/main/java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java b/hbase-client/src/main/java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java index 08bba5ce9876..9b50ae2c70e9 100644 --- a/hbase-client/src/main/java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java +++ b/hbase-client/src/main/java/org/apache/hadoop/hbase/ipc/AbstractRpcClient.java @@ -1,4 +1,4 @@ -/** +/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information @@ -45,7 +45,6 @@ import org.apache.hadoop.hbase.net.Address; import org.apache.hadoop.hbase.security.User; import org.apache.hadoop.hbase.security.UserProvider; -import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.trace.TraceUtil; import org.apache.hadoop.hbase.util.EnvironmentEdgeManager; import org.apache.hadoop.hbase.util.PoolMap; diff --git a/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncTableTracing.java b/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncTableTracing.java index 4e38fca3efc9..a1770e7004ab 100644 --- a/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncTableTracing.java +++ b/hbase-client/src/test/java/org/apache/hadoop/hbase/client/TestAsyncTableTracing.java @@ -1,4 +1,4 @@ -/** +/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information @@ -50,7 +50,6 @@ import org.apache.hadoop.hbase.security.UserProvider; import org.apache.hadoop.hbase.testclassification.ClientTests; import org.apache.hadoop.hbase.testclassification.MediumTests; -import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.util.Bytes; import org.junit.After; import org.junit.Before; From 70f6af4f3b59d70aeed3710aeb6dc9fae65f02da Mon Sep 17 00:00:00 2001 From: Nick Dimiduk Date: Tue, 30 Nov 2021 08:36:53 -0800 Subject: [PATCH 3/3] fix checkstyle nits --- .../main/java/org/apache/hadoop/hbase/ipc/CallRunner.java | 3 +-- .../org/apache/hadoop/hbase/regionserver/HRegion.java | 3 +-- .../hadoop/hbase/regionserver/wal/AbstractFSWAL.java | 3 +-- .../java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java | 8 ++++++-- 4 files changed, 9 insertions(+), 8 deletions(-) diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/ipc/CallRunner.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/ipc/CallRunner.java index 17367a21f2d5..ef37247f412f 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/ipc/CallRunner.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/ipc/CallRunner.java @@ -1,4 +1,4 @@ -/** +/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information @@ -32,7 +32,6 @@ import org.apache.hadoop.hbase.exceptions.TimeoutIOException; import org.apache.hadoop.hbase.monitoring.MonitoredRPCHandler; import org.apache.hadoop.hbase.security.User; -import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.trace.TraceUtil; import org.apache.hadoop.hbase.util.EnvironmentEdgeManager; import org.apache.hadoop.hbase.util.Pair; diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java index 77539a9d6535..63992dc97a46 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java @@ -1,4 +1,4 @@ -/** +/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information @@ -157,7 +157,6 @@ import org.apache.hadoop.hbase.security.User; import org.apache.hadoop.hbase.snapshot.SnapshotDescriptionUtils; import org.apache.hadoop.hbase.snapshot.SnapshotManifest; -import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.trace.TraceUtil; import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.CancelableProgressable; diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java index f5232ab22bb1..2e99fa8a13f1 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java @@ -1,4 +1,4 @@ -/** +/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information @@ -70,7 +70,6 @@ import org.apache.hadoop.hbase.log.HBaseMarkers; import org.apache.hadoop.hbase.regionserver.HRegion; import org.apache.hadoop.hbase.regionserver.MultiVersionConcurrencyControl; -import org.apache.hadoop.hbase.trace.HBaseSemanticAttributes; import org.apache.hadoop.hbase.trace.TraceUtil; import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.CommonFSUtils; diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java index c1fbfed4e4f6..030b052cb1e4 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/ipc/AbstractTestIPC.java @@ -462,8 +462,12 @@ private void assertRpcAttribute(SpanData data, String methodName, InetSocketAddr data.getAttributes().get(HBaseSemanticAttributes.RPC_SERVICE_KEY)); assertEquals(methodName, data.getAttributes().get(HBaseSemanticAttributes.RPC_METHOD_KEY)); if (addr != null) { - assertEquals(addr.getHostName(), data.getAttributes().get(HBaseSemanticAttributes.REMOTE_HOST_KEY)); - assertEquals(addr.getPort(), data.getAttributes().get(HBaseSemanticAttributes.REMOTE_PORT_KEY).intValue()); + assertEquals( + addr.getHostName(), + data.getAttributes().get(HBaseSemanticAttributes.REMOTE_HOST_KEY)); + assertEquals( + addr.getPort(), + data.getAttributes().get(HBaseSemanticAttributes.REMOTE_PORT_KEY).intValue()); } assertEquals(kind, data.getKind()); }