All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.linecorp.armeria.spring.ArmeriaSettings Maven / Gradle / Ivy

/*
 * Copyright 2017 LINE Corporation
 *
 * LINE Corporation 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:
 *
 *   https://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 com.linecorp.armeria.spring;

import java.util.ArrayList;
import java.util.List;

import javax.annotation.Nullable;

import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.validation.annotation.Validated;

import com.linecorp.armeria.common.SessionProtocol;
import com.linecorp.armeria.server.Server;
import com.linecorp.armeria.server.metric.MetricCollectingService;

/**
 * Settings for armeria servers, e.g.,
 * 
{@code
 * armeria:
 *   ports:
 *     - port: 8080
 *       protocol: HTTP
 *     - ip: 127.0.0.1
 *       port: 8081
 *       protocol:HTTP
 * }
* TODO(ide) Adds SSL and virtualhost settings */ @ConfigurationProperties(prefix = "armeria") @Validated public class ArmeriaSettings { /** * Port and protocol settings. */ public static class Port { /** * IP address to bind to. If not set, will bind to all addresses, e.g. {@code 0.0.0.0}. */ private String ip; /** * Network interface to bind to. If not set, will bind to the first detected network interface. */ private String iface; /** * Port that {@link Server} binds to. */ private int port; /** * Protocol that will be used in this ip/iface and port. */ private SessionProtocol protocol; /** * Returns the IP address {@link Server} uses. */ @Nullable public String getIp() { return ip; } /** * Register an IP address {@link Server} uses. */ public Port setIp(String ip) { this.ip = ip; return this; } /** * Returns the network interface {@link Server} use. */ @Nullable public String getIface() { return iface; } /** * Register a network interface {@link Server} use. */ public Port setIface(String iface) { this.iface = iface; return this; } /** * Returns the port that {@link Server} use. */ public int getPort() { return port; } /** * Register a port that {@link Server} use. */ public Port setPort(int port) { this.port = port; return this; } /** * Returns the {@link SessionProtocol} that {@link Server} use. */ public SessionProtocol getProtocol() { return protocol; } /** * Register a {@link SessionProtocol} that {@link Server} use. */ public Port setProtocol(SessionProtocol protocol) { this.protocol = protocol; return this; } } /** * The ports to listen on for requests. If not specified, will listen on * port 8080 for HTTP (not SSL). */ private List ports = new ArrayList<>(); /** * The path to serve health check requests on. Should correspond to what is * registered in the load balancer. If not set, health check service will not * be registered. */ @Nullable private String healthCheckPath = "/internal/healthcheck"; /** * The path to serve thrift service documentation on. Should not be exposed * to the external network. If not set, documentation service will not be * registered. */ @Nullable private String docsPath = "/internal/docs/"; /** * The path to serve a json dump of instantaneous metrics. Should not be * exposed to the external network. If not set, metrics will not be exported * on an http path (any registered reporters will still function). */ @Nullable private String metricsPath = "/internal/metrics"; /** * The number of milliseconds to wait after the last processed request to * be considered safe for shutdown. This should be set at least as long as * the slowest possible request to guarantee graceful shutdown. If {@code -1}, * graceful shutdown will be disabled. */ private long gracefulShutdownQuietPeriodMillis = 5000; /** * The number of milliseconds to wait after going unhealthy before forcing * the server to shutdown regardless of if it is still processing requests. * This should be set as long as the maximum time for the load balancer to * turn off requests to the server. If {@code -1}, graceful shutdown will * be disabled. */ private long gracefulShutdownTimeoutMillis = 40000; /** * Whether to decorate all services with {@link MetricCollectingService}. * The default is {@code true}. */ private boolean enableMetrics = true; public List getPorts() { return ports; } public void setPorts(List ports) { this.ports = ports; } @Nullable public String getHealthCheckPath() { return healthCheckPath; } public void setHealthCheckPath(@Nullable String healthCheckPath) { this.healthCheckPath = healthCheckPath; } @Nullable public String getDocsPath() { return docsPath; } public void setDocsPath(@Nullable String docsPath) { this.docsPath = docsPath; } @Nullable public String getMetricsPath() { return metricsPath; } public void setMetricsPath(@Nullable String metricsPath) { this.metricsPath = metricsPath; } public long getGracefulShutdownQuietPeriodMillis() { return gracefulShutdownQuietPeriodMillis; } public void setGracefulShutdownQuietPeriodMillis(long gracefulShutdownQuietPeriodMillis) { this.gracefulShutdownQuietPeriodMillis = gracefulShutdownQuietPeriodMillis; } public long getGracefulShutdownTimeoutMillis() { return gracefulShutdownTimeoutMillis; } public void setGracefulShutdownTimeoutMillis(long gracefulShutdownTimeoutMillis) { this.gracefulShutdownTimeoutMillis = gracefulShutdownTimeoutMillis; } public boolean isEnableMetrics() { return enableMetrics; } public void setEnableMetrics(boolean enableMetrics) { this.enableMetrics = enableMetrics; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy