mirror of
https://github.com/google/nomulus.git
synced 2025-05-01 12:37:52 +02:00
Opened two ports (30010 and 30011 by default) that handles HTTP(S) GET requests. the HTTP request is redirected to the corresponding HTTPS site, whereas the HTTPS request is redirected to a site that supports web WHOIS. The GCLB currently exposes port 80, but not port 443 on its TCP proxy load balancer (see https://cloud.google.com/load-balancing/docs/choosing-load-balancer). As a result, the HTTP traffic has to be routed by the HTTP load balancer, which requires a separate HTTP health check (as opposed to the TCP health check that the TCP proxy LB uses). This CL also added support for HTTP health check. There is not a strong case for adding an end-to-end test for WebWhoisProtocolsModule (like those for EppProtocolModule, etc) as it just assembles standard HTTP codecs used for an HTTP server, plus the WebWhoisRedirectHandler, which is tested. The end-to-end test would just be testing if the Netty provided HTTP handlers correctly parse raw HTTP messages. Sever other small improvement is also included: [1] Use setInt other than set when setting content length in HTTP headers. I don't think it is necessary, but it is nevertheless a better practice to use a more specialized setter. [2] Do not write metrics when running locally. [3] Rename the qualifier @EppCertificates to @ServerSertificate as it now provides the certificate used in HTTPS traffic as well. ------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=206944843
76 lines
2.7 KiB
Java
76 lines
2.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;
|
|
|
|
import com.google.common.collect.ImmutableList;
|
|
import dagger.Module;
|
|
import dagger.Provides;
|
|
import dagger.multibindings.IntoSet;
|
|
import google.registry.proxy.Protocol.FrontendProtocol;
|
|
import google.registry.proxy.handler.HealthCheckHandler;
|
|
import io.netty.channel.ChannelHandler;
|
|
import io.netty.handler.codec.FixedLengthFrameDecoder;
|
|
import javax.inject.Provider;
|
|
import javax.inject.Qualifier;
|
|
import javax.inject.Singleton;
|
|
|
|
/**
|
|
* Module that provides a {@link FrontendProtocol} used for GCP load balancer health checking.
|
|
*
|
|
* <p>The load balancer sends health checking messages to the GCE instances to assess whether they
|
|
* are ready to receive traffic. No relay channel needs to be established for this protocol.
|
|
*/
|
|
@Module
|
|
public class HealthCheckProtocolModule {
|
|
|
|
/** Dagger qualifier to provide health check protocol related handlers and other bindings. */
|
|
@Qualifier
|
|
@interface HealthCheckProtocol {}
|
|
|
|
private static final String PROTOCOL_NAME = "health_check";
|
|
|
|
@Singleton
|
|
@Provides
|
|
@IntoSet
|
|
static FrontendProtocol provideProtocol(
|
|
@HealthCheckProtocol int healthCheckPort,
|
|
@HealthCheckProtocol ImmutableList<Provider<? extends ChannelHandler>> handlerProviders) {
|
|
return Protocol.frontendBuilder()
|
|
.name(PROTOCOL_NAME)
|
|
.port(healthCheckPort)
|
|
.hasBackend(false)
|
|
.handlerProviders(handlerProviders)
|
|
.build();
|
|
}
|
|
|
|
@Provides
|
|
@HealthCheckProtocol
|
|
static ImmutableList<Provider<? extends ChannelHandler>> provideHandlerProviders(
|
|
Provider<FixedLengthFrameDecoder> fixedLengthFrameDecoderProvider,
|
|
Provider<HealthCheckHandler> healthCheckHandlerProvider) {
|
|
return ImmutableList.of(fixedLengthFrameDecoderProvider, healthCheckHandlerProvider);
|
|
}
|
|
|
|
@Provides
|
|
static FixedLengthFrameDecoder provideFixedLengthFrameDecoder(ProxyConfig config) {
|
|
return new FixedLengthFrameDecoder(config.healthCheck.checkRequest.length());
|
|
}
|
|
|
|
@Provides
|
|
static HealthCheckHandler provideHealthCheckHandler(ProxyConfig config) {
|
|
return new HealthCheckHandler(
|
|
config.healthCheck.checkRequest, config.healthCheck.checkResponse);
|
|
}
|
|
}
|