envconfig.go

 1/*
 2 *
 3 * Copyright 2018 gRPC authors.
 4 *
 5 * Licensed under the Apache License, Version 2.0 (the "License");
 6 * you may not use this file except in compliance with the License.
 7 * You may obtain a copy of the License at
 8 *
 9 *     http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 */
18
19// Package envconfig contains grpc settings configured by environment variables.
20package envconfig
21
22import (
23	"os"
24	"strconv"
25	"strings"
26)
27
28var (
29	// TXTErrIgnore is set if TXT errors should be ignored ("GRPC_GO_IGNORE_TXT_ERRORS" is not "false").
30	TXTErrIgnore = boolFromEnv("GRPC_GO_IGNORE_TXT_ERRORS", true)
31	// RingHashCap indicates the maximum ring size which defaults to 4096
32	// entries but may be overridden by setting the environment variable
33	// "GRPC_RING_HASH_CAP".  This does not override the default bounds
34	// checking which NACKs configs specifying ring sizes > 8*1024*1024 (~8M).
35	RingHashCap = uint64FromEnv("GRPC_RING_HASH_CAP", 4096, 1, 8*1024*1024)
36	// LeastRequestLB is set if we should support the least_request_experimental
37	// LB policy, which can be enabled by setting the environment variable
38	// "GRPC_EXPERIMENTAL_ENABLE_LEAST_REQUEST" to "true".
39	LeastRequestLB = boolFromEnv("GRPC_EXPERIMENTAL_ENABLE_LEAST_REQUEST", false)
40	// ALTSMaxConcurrentHandshakes is the maximum number of concurrent ALTS
41	// handshakes that can be performed.
42	ALTSMaxConcurrentHandshakes = uint64FromEnv("GRPC_ALTS_MAX_CONCURRENT_HANDSHAKES", 100, 1, 100)
43	// EnforceALPNEnabled is set if TLS connections to servers with ALPN disabled
44	// should be rejected. The HTTP/2 protocol requires ALPN to be enabled, this
45	// option is present for backward compatibility. This option may be overridden
46	// by setting the environment variable "GRPC_ENFORCE_ALPN_ENABLED" to "true"
47	// or "false".
48	EnforceALPNEnabled = boolFromEnv("GRPC_ENFORCE_ALPN_ENABLED", true)
49	// XDSFallbackSupport is the env variable that controls whether support for
50	// xDS fallback is turned on. If this is unset or is false, only the first
51	// xDS server in the list of server configs will be used.
52	XDSFallbackSupport = boolFromEnv("GRPC_EXPERIMENTAL_XDS_FALLBACK", true)
53	// NewPickFirstEnabled is set if the new pickfirst leaf policy is to be used
54	// instead of the exiting pickfirst implementation. This can be enabled by
55	// setting the environment variable "GRPC_EXPERIMENTAL_ENABLE_NEW_PICK_FIRST"
56	// to "true".
57	NewPickFirstEnabled = boolFromEnv("GRPC_EXPERIMENTAL_ENABLE_NEW_PICK_FIRST", false)
58)
59
60func boolFromEnv(envVar string, def bool) bool {
61	if def {
62		// The default is true; return true unless the variable is "false".
63		return !strings.EqualFold(os.Getenv(envVar), "false")
64	}
65	// The default is false; return false unless the variable is "true".
66	return strings.EqualFold(os.Getenv(envVar), "true")
67}
68
69func uint64FromEnv(envVar string, def, min, max uint64) uint64 {
70	v, err := strconv.ParseUint(os.Getenv(envVar), 10, 64)
71	if err != nil {
72		return def
73	}
74	if v < min {
75		return min
76	}
77	if v > max {
78		return max
79	}
80	return v
81}