mirror of
https://github.com/google/nomulus.git
synced 2025-05-02 21:17:50 +02:00
Dagger updated to 2.13, along with all its dependencies. Also allows us to have multiple config files for different environment (prod, sandbox, alpha, local, etc) and specify which one to use on the command line with a --env flag. Therefore the same binary can be used in all environments. ------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=176551289
99 lines
3.7 KiB
Java
99 lines
3.7 KiB
Java
// Copyright 2017 The Nomulus Authors. All Rights Reserved.
|
|
//
|
|
// Licensed 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 google.registry.proxy.metric;
|
|
|
|
import com.google.common.annotations.VisibleForTesting;
|
|
import com.google.common.collect.ImmutableList;
|
|
import com.google.common.collect.ImmutableMap;
|
|
import com.google.common.collect.ImmutableSet;
|
|
import google.registry.monitoring.metrics.IncrementableMetric;
|
|
import google.registry.monitoring.metrics.LabelDescriptor;
|
|
import google.registry.monitoring.metrics.Metric;
|
|
import google.registry.monitoring.metrics.MetricRegistryImpl;
|
|
import google.registry.util.NonFinalForTesting;
|
|
import io.netty.channel.Channel;
|
|
import io.netty.channel.group.ChannelGroup;
|
|
import io.netty.channel.group.DefaultChannelGroup;
|
|
import io.netty.util.concurrent.GlobalEventExecutor;
|
|
import java.util.Map;
|
|
import java.util.concurrent.ConcurrentHashMap;
|
|
import java.util.concurrent.ConcurrentMap;
|
|
import javax.inject.Inject;
|
|
|
|
/** Frontend metrics instrumentation. */
|
|
public class FrontendMetrics {
|
|
|
|
private static final ImmutableSet<LabelDescriptor> LABELS =
|
|
ImmutableSet.of(
|
|
LabelDescriptor.create("protocol", "Name of the protocol."),
|
|
LabelDescriptor.create(
|
|
"client_cert_hash", "SHA256 hash of the client certificate, if available."));
|
|
|
|
private static final ConcurrentMap<ImmutableList<String>, ChannelGroup> activeConnections =
|
|
new ConcurrentHashMap<>();
|
|
|
|
static final Metric<Long> activeConnectionsGauge =
|
|
MetricRegistryImpl.getDefault()
|
|
.newGauge(
|
|
"/proxy/frontend/active_connections",
|
|
"Number of active connections from clients to the proxy.",
|
|
"Connections",
|
|
LABELS,
|
|
() ->
|
|
activeConnections
|
|
.entrySet()
|
|
.stream()
|
|
.collect(
|
|
ImmutableMap.toImmutableMap(
|
|
Map.Entry::getKey, entry -> (long) entry.getValue().size())),
|
|
Long.class);
|
|
|
|
static final IncrementableMetric totalConnectionsCounter =
|
|
MetricRegistryImpl.getDefault()
|
|
.newIncrementableMetric(
|
|
"/proxy/frontend/total_connections",
|
|
"Total number connections ever made from clients to the proxy.",
|
|
"Connections",
|
|
LABELS);
|
|
|
|
@Inject
|
|
public FrontendMetrics() {}
|
|
|
|
/**
|
|
* Resets all frontend metrics.
|
|
*
|
|
* <p>This should only be used in tests to reset states. Production code should not call this
|
|
* method.
|
|
*/
|
|
@VisibleForTesting
|
|
void resetMetrics() {
|
|
totalConnectionsCounter.reset();
|
|
activeConnections.clear();
|
|
}
|
|
|
|
@NonFinalForTesting
|
|
public void registerActiveConnection(String protocol, String certHash, Channel channel) {
|
|
totalConnectionsCounter.increment(protocol, certHash);
|
|
ImmutableList<String> labels = ImmutableList.of(protocol, certHash);
|
|
ChannelGroup channelGroup;
|
|
if (activeConnections.containsKey(labels)) {
|
|
channelGroup = activeConnections.get(labels);
|
|
} else {
|
|
channelGroup = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);
|
|
activeConnections.put(labels, channelGroup);
|
|
}
|
|
channelGroup.add(channel);
|
|
}
|
|
}
|