2018-01-09 18:57:14 +00:00
|
|
|
/*
|
|
|
|
*
|
2018-07-18 14:47:22 +00:00
|
|
|
* Copyright 2018 gRPC authors.
|
2018-01-09 18:57:14 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2018-11-26 18:23:56 +00:00
|
|
|
// Package envconfig contains grpc settings configured by environment variables.
|
|
|
|
package envconfig
|
2018-01-09 18:57:14 +00:00
|
|
|
|
2018-07-18 14:47:22 +00:00
|
|
|
import (
|
|
|
|
"os"
|
2023-02-13 21:00:11 +00:00
|
|
|
"strconv"
|
2018-07-18 14:47:22 +00:00
|
|
|
"strings"
|
|
|
|
)
|
2018-01-09 18:57:14 +00:00
|
|
|
|
2018-07-18 14:47:22 +00:00
|
|
|
var (
|
2021-02-10 06:51:30 +00:00
|
|
|
// TXTErrIgnore is set if TXT errors should be ignored ("GRPC_GO_IGNORE_TXT_ERRORS" is not "false").
|
2023-02-13 21:00:11 +00:00
|
|
|
TXTErrIgnore = boolFromEnv("GRPC_GO_IGNORE_TXT_ERRORS", true)
|
|
|
|
// RingHashCap indicates the maximum ring size which defaults to 4096
|
|
|
|
// entries but may be overridden by setting the environment variable
|
|
|
|
// "GRPC_RING_HASH_CAP". This does not override the default bounds
|
|
|
|
// checking which NACKs configs specifying ring sizes > 8*1024*1024 (~8M).
|
|
|
|
RingHashCap = uint64FromEnv("GRPC_RING_HASH_CAP", 4096, 1, 8*1024*1024)
|
2023-09-11 20:46:57 +00:00
|
|
|
// LeastRequestLB is set if we should support the least_request_experimental
|
|
|
|
// LB policy, which can be enabled by setting the environment variable
|
|
|
|
// "GRPC_EXPERIMENTAL_ENABLE_LEAST_REQUEST" to "true".
|
|
|
|
LeastRequestLB = boolFromEnv("GRPC_EXPERIMENTAL_ENABLE_LEAST_REQUEST", false)
|
2023-07-31 20:48:48 +00:00
|
|
|
// ALTSMaxConcurrentHandshakes is the maximum number of concurrent ALTS
|
|
|
|
// handshakes that can be performed.
|
|
|
|
ALTSMaxConcurrentHandshakes = uint64FromEnv("GRPC_ALTS_MAX_CONCURRENT_HANDSHAKES", 100, 1, 100)
|
2024-07-09 12:01:10 +00:00
|
|
|
// EnforceALPNEnabled is set if TLS connections to servers with ALPN disabled
|
|
|
|
// should be rejected. The HTTP/2 protocol requires ALPN to be enabled, this
|
|
|
|
// option is present for backward compatibility. This option may be overridden
|
|
|
|
// by setting the environment variable "GRPC_ENFORCE_ALPN_ENABLED" to "true"
|
|
|
|
// or "false".
|
2024-09-23 20:18:46 +00:00
|
|
|
EnforceALPNEnabled = boolFromEnv("GRPC_ENFORCE_ALPN_ENABLED", true)
|
2024-09-02 20:06:42 +00:00
|
|
|
// XDSFallbackSupport is the env variable that controls whether support for
|
|
|
|
// xDS fallback is turned on. If this is unset or is false, only the first
|
|
|
|
// xDS server in the list of server configs will be used.
|
|
|
|
XDSFallbackSupport = boolFromEnv("GRPC_EXPERIMENTAL_XDS_FALLBACK", false)
|
2018-07-18 14:47:22 +00:00
|
|
|
)
|
2023-02-13 21:00:11 +00:00
|
|
|
|
|
|
|
func boolFromEnv(envVar string, def bool) bool {
|
|
|
|
if def {
|
|
|
|
// The default is true; return true unless the variable is "false".
|
|
|
|
return !strings.EqualFold(os.Getenv(envVar), "false")
|
|
|
|
}
|
|
|
|
// The default is false; return false unless the variable is "true".
|
|
|
|
return strings.EqualFold(os.Getenv(envVar), "true")
|
|
|
|
}
|
|
|
|
|
|
|
|
func uint64FromEnv(envVar string, def, min, max uint64) uint64 {
|
|
|
|
v, err := strconv.ParseUint(os.Getenv(envVar), 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
return def
|
|
|
|
}
|
|
|
|
if v < min {
|
|
|
|
return min
|
|
|
|
}
|
|
|
|
if v > max {
|
|
|
|
return max
|
|
|
|
}
|
|
|
|
return v
|
|
|
|
}
|