mirror of https://github.com/status-im/consul.git
docs: update config entry docs for proxy-defaults to follow new template (#12011)
This commit is contained in:
parent
6cecd35e6e
commit
b9e9f1106b
|
@ -9,54 +9,141 @@ description: >-
|
||||||
|
|
||||||
# Proxy Defaults
|
# Proxy Defaults
|
||||||
|
|
||||||
-> **v1.8.4+:** On Kubernetes, the `ProxyDefaults` custom resource is supported in Consul versions 1.8.4+.<br />
|
|
||||||
**v1.5.0+:** On other platforms, this config entry is supported in Consul versions 1.5.0+.
|
|
||||||
|
|
||||||
The `proxy-defaults` config entry kind (`ProxyDefaults` on Kubernetes) allows for configuring global config
|
The `proxy-defaults` configuration entry (`ProxyDefaults` on Kubernetes) allows you
|
||||||
defaults across all services for Connect proxy configuration. Currently, only
|
to configure global defaults across all services for Connect proxy
|
||||||
one global entry is supported.
|
configurations. Only one global entry is supported.
|
||||||
|
|
||||||
## Sample Config Entries
|
## Introduction
|
||||||
|
|
||||||
### Default protocol
|
You can customize some service registration settings for service mesh sidecar
|
||||||
|
proxies centrally using the `proxy-defaults` configuration entry in the `kind`
|
||||||
|
field.
|
||||||
|
|
||||||
Set the default protocol for all sidecar proxies:
|
You can still override this centralized configuration for specific services
|
||||||
|
with the [`service-defaults`](/docs/connect/config-entries/service-defaults)
|
||||||
|
configuration entry `kind` or for individual proxy instances in their [sidecar
|
||||||
|
service definitions](/docs/connect/registration/sidecar-service).
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
The following Consul binaries are supported:
|
||||||
|
* Consul 1.8.4+ on Kubernetes.
|
||||||
|
* Consul 1.5.0+ on other platforms.
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
1. Verify that your datacenter meets the conditions specified in the [Requirements](#requirements).
|
||||||
|
1. Determine the settings you want to implement (see [Configuration](#configuration)). You can create a file containing the configuration or pass them to the state store directly to apply the configuration.
|
||||||
|
1. Apply the configuration using one of the following methods:
|
||||||
|
- Kubernetes CRD: Refer to the [Custom Resource Definitions](/docs/k8s/crds) documentation for details.
|
||||||
|
- Issue the `consul config write` command: Refer to the [Consul Config Write](/commands/config/write) documentation for details.
|
||||||
|
|
||||||
|
## Configuration
|
||||||
|
|
||||||
|
Configure the following parameters to define a `proxy-defaults` configuration entry:
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
<Tab heading="Consul OSS">
|
<Tab heading="Consul OSS">
|
||||||
|
|
||||||
Set the default protocol for all sidecar proxies:
|
<CodeTabs heading="Proxy defaults configuration syntax" tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
||||||
|
<CodeBlockConfig>
|
||||||
<CodeTabs tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
|
||||||
|
|
||||||
```hcl
|
```hcl
|
||||||
Kind = "proxy-defaults"
|
Kind = "proxy-defaults"
|
||||||
Name = "global"
|
Name = "global"
|
||||||
|
Meta {
|
||||||
|
<arbitrary string key> = "<arbitrary string value>"
|
||||||
|
}
|
||||||
Config {
|
Config {
|
||||||
protocol = "http"
|
<arbitrary string key> = <arbitrary value>
|
||||||
|
}
|
||||||
|
Mode = "<name of proxy mode>"
|
||||||
|
TransparentProxy {
|
||||||
|
OutboundListenerPort = <port the proxy should listen on for outbound traffic>
|
||||||
|
DialedDirectly = <true if proxy instances should be dialed directly>
|
||||||
|
}
|
||||||
|
MeshGateway {
|
||||||
|
Mode = "<name of mesh gatweay configuration for all proxies>"
|
||||||
|
}
|
||||||
|
Expose {
|
||||||
|
Checks = <true to expose all HTTP and gRPC checks through Envoy>
|
||||||
|
|
||||||
|
Paths = [
|
||||||
|
{
|
||||||
|
Path = "<the HTTP path to expose>"
|
||||||
|
LocalPathPort = <port where the local service is listening for connections to the path>
|
||||||
|
ListenerPort = <port where the proxy will listen for connections>
|
||||||
|
Protocol = "<protocol of the listener>"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
apiVersion: consul.hashicorp.com/v1alpha1
|
apiVersion: consul.hashicorp.com/v1alpha1
|
||||||
kind: ProxyDefaults
|
kind: ProxyDefaults
|
||||||
metadata:
|
metadata:
|
||||||
name: global
|
name: global
|
||||||
spec:
|
spec:
|
||||||
|
meta:
|
||||||
|
<arbitrary string key>: <arbitrary string value>
|
||||||
config:
|
config:
|
||||||
protocol: http
|
<arbitrary string key>: <arbitrary value>
|
||||||
|
mode: <name of proxy mode>
|
||||||
|
transparentProxy:
|
||||||
|
outboundListenerPort: <port the proxy should listen on for outbound traffic>
|
||||||
|
dialedDirectly: <true if proxy instances should be dialed directly>
|
||||||
|
meshGateway:
|
||||||
|
mode: <name of mesh gatweay configuration for all proxies>
|
||||||
|
expose:
|
||||||
|
checks: <true to expose all HTTP and gRPC checks through Envoy>
|
||||||
|
paths:
|
||||||
|
- path: <the HTTP path to expose>
|
||||||
|
localPathPort: <port where the local service is listening for connections to the path>
|
||||||
|
listenerPort: <port where the proxy will listen for connections>
|
||||||
|
protocol:= <protocol of the listener>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
```json
|
```json
|
||||||
{
|
{
|
||||||
"Kind": "proxy-defaults",
|
"Kind": "proxy-defaults",
|
||||||
"Name": "global",
|
"Name": "global",
|
||||||
|
"Meta": {
|
||||||
|
"<arbitrary string key>": "<arbitrary string value>"
|
||||||
|
},
|
||||||
"Config": {
|
"Config": {
|
||||||
"protocol": "http"
|
"<arbitrary string key>": <arbitrary value>
|
||||||
|
},
|
||||||
|
"Mode": "<name of proxy mode>",
|
||||||
|
"TransparentProxy": {
|
||||||
|
"OutboundListenerPort": <port the proxy should listen on for outbound traffic>,
|
||||||
|
"DialedDirectly": <true if proxy instances should be dialed directly>
|
||||||
|
},
|
||||||
|
"MeshGateway": {
|
||||||
|
"Mode": = "<name of mesh gatweay configuration for all proxies>"
|
||||||
|
},
|
||||||
|
"Expose": {
|
||||||
|
"Checks": <true to expose all HTTP and gRPC checks through Envoy>,
|
||||||
|
"Paths": [
|
||||||
|
{
|
||||||
|
"Path": "<the HTTP path to expose>",
|
||||||
|
"LocalPathPort": <port where the local service is listening for connections to the path>,
|
||||||
|
"ListenerPort": <port where the proxy will listen for connections>,
|
||||||
|
"Protocol": "<protocol of the listener>"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
</CodeTabs>
|
</CodeTabs>
|
||||||
|
|
||||||
</Tab>
|
</Tab>
|
||||||
|
@ -65,17 +152,44 @@ spec:
|
||||||
-> **NOTE:** The `proxy-defaults` config entry can only be created in the `default`
|
-> **NOTE:** The `proxy-defaults` config entry can only be created in the `default`
|
||||||
namespace and it will configure proxies in **all** namespaces.
|
namespace and it will configure proxies in **all** namespaces.
|
||||||
|
|
||||||
<CodeTabs tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
<CodeTabs heading="Proxy defaults configuration syntax" tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
```hcl
|
```hcl
|
||||||
Kind = "proxy-defaults"
|
Kind = "proxy-defaults"
|
||||||
Name = "global"
|
Name = "global"
|
||||||
Namespace = "default" # Can only be set to "default".
|
Namespace = "default" # Can only be set to "default".
|
||||||
|
Meta {
|
||||||
|
<arbitrary string key> = "<arbitrary string value>"
|
||||||
|
}
|
||||||
Config {
|
Config {
|
||||||
protocol = "http"
|
<arbitrary string key> = <arbitrary value>
|
||||||
|
}
|
||||||
|
Mode = "<name of proxy mode>"
|
||||||
|
TransparentProxy {
|
||||||
|
OutboundListenerPort = <port the proxy should listen on for outbound traffic>
|
||||||
|
DialedDirectly = <true if proxy instances should be dialed directly>
|
||||||
|
}
|
||||||
|
MeshGateway {
|
||||||
|
Mode = "<name of mesh gatweay configuration for all proxies>"
|
||||||
|
}
|
||||||
|
Expose {
|
||||||
|
Checks = <true to expose all HTTP and gRPC checks through Envoy>
|
||||||
|
|
||||||
|
Paths = [
|
||||||
|
{
|
||||||
|
Path = "<the HTTP path to expose>"
|
||||||
|
LocalPathPort = <port where the local service is listening for connections to the path>
|
||||||
|
ListenerPort = <port where the proxy will listen for connections>
|
||||||
|
Protocol = "<protocol of the listener>"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
apiVersion: consul.hashicorp.com/v1alpha1
|
apiVersion: consul.hashicorp.com/v1alpha1
|
||||||
kind: ProxyDefaults
|
kind: ProxyDefaults
|
||||||
|
@ -83,102 +197,68 @@ metadata:
|
||||||
name: global
|
name: global
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
|
meta:
|
||||||
|
<arbitrary string key>: <arbitrary string value>
|
||||||
config:
|
config:
|
||||||
protocol: http
|
<arbitrary string key>: <arbitrary value>
|
||||||
|
mode: <name of proxy mode>
|
||||||
|
transparentProxy:
|
||||||
|
outboundListenerPort: <port the proxy should listen on for outbound traffic>
|
||||||
|
dialedDirectly: <true if proxy instances should be dialed directly>
|
||||||
|
meshGateway:
|
||||||
|
mode: <name of mesh gatweay configuration for all proxies>
|
||||||
|
expose:
|
||||||
|
checks: <true to expose all HTTP and gRPC checks through Envoy>
|
||||||
|
paths:
|
||||||
|
- path: <the HTTP path to expose>
|
||||||
|
localPathPort: <port where the local service is listening for connections to the path>
|
||||||
|
listenerPort: <port where the proxy will listen for connections>
|
||||||
|
protocol:= <protocol of the listener>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
```json
|
```json
|
||||||
{
|
{
|
||||||
"Kind": "proxy-defaults",
|
"Kind": "proxy-defaults",
|
||||||
"Name": "global",
|
"Name": "global",
|
||||||
"Namespace": "default",
|
"Namespace": "default",
|
||||||
|
"Meta": {
|
||||||
|
"<arbitrary string key>": "<arbitrary string value>"
|
||||||
|
},
|
||||||
"Config": {
|
"Config": {
|
||||||
"protocol": "http"
|
"<arbitrary string key>": <arbitrary value>
|
||||||
|
},
|
||||||
|
"Mode": "<name of proxy mode>",
|
||||||
|
"TransparentProxy": {
|
||||||
|
"OutboundListenerPort": <port the proxy should listen on for outbound traffic>,
|
||||||
|
"DialedDirectly": <true if proxy instances should be dialed directly>
|
||||||
|
},
|
||||||
|
"MeshGateway": {
|
||||||
|
"Mode": = "<name of mesh gatweay configuration for all proxies>"
|
||||||
|
},
|
||||||
|
"Expose": {
|
||||||
|
"Checks": <true to expose all HTTP and gRPC checks through Envoy>,
|
||||||
|
"Paths": [
|
||||||
|
{
|
||||||
|
"Path": "<the HTTP path to expose>",
|
||||||
|
"LocalPathPort": <port where the local service is listening for connections to the path>,
|
||||||
|
"ListenerPort": <port where the proxy will listen for connections>,
|
||||||
|
"Protocol": "<protocol of the listener>"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
</CodeTabs>
|
</CodeTabs>
|
||||||
|
|
||||||
</Tab>
|
</Tab>
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
|
||||||
### Prometheus
|
### Configuration Parameters
|
||||||
|
|
||||||
Expose prometheus metrics:
|
|
||||||
|
|
||||||
<CodeTabs tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
|
||||||
|
|
||||||
```hcl
|
|
||||||
Kind = "proxy-defaults"
|
|
||||||
Name = "global"
|
|
||||||
Config {
|
|
||||||
envoy_prometheus_bind_addr = "0.0.0.0:9102"
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
apiVersion: consul.hashicorp.com/v1alpha1
|
|
||||||
kind: ProxyDefaults
|
|
||||||
metadata:
|
|
||||||
name: global
|
|
||||||
spec:
|
|
||||||
config:
|
|
||||||
envoy_prometheus_bind_addr: '0.0.0.0:9102'
|
|
||||||
```
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"Kind": "proxy-defaults",
|
|
||||||
"Name": "global",
|
|
||||||
"Config": {
|
|
||||||
"envoy_prometheus_bind_addr": "0.0.0.0:9102"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
</CodeTabs>
|
|
||||||
|
|
||||||
### Proxy-specific defaults
|
|
||||||
|
|
||||||
Set proxy-specific defaults:
|
|
||||||
|
|
||||||
<CodeTabs tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
|
||||||
|
|
||||||
```hcl
|
|
||||||
Kind = "proxy-defaults"
|
|
||||||
Name = "global"
|
|
||||||
Config {
|
|
||||||
local_connect_timeout_ms = 1000
|
|
||||||
handshake_timeout_ms = 10000
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
apiVersion: consul.hashicorp.com/v1alpha1
|
|
||||||
kind: ProxyDefaults
|
|
||||||
metadata:
|
|
||||||
name: global
|
|
||||||
spec:
|
|
||||||
config:
|
|
||||||
local_connect_timeout_ms: 1000
|
|
||||||
handshake_timeout_ms: 10000
|
|
||||||
```
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"Kind": "proxy-defaults",
|
|
||||||
"Name": "global",
|
|
||||||
"Config": {
|
|
||||||
"local_connect_timeout_ms": 1000,
|
|
||||||
"handshake_timeout_ms": 10000
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
</CodeTabs>
|
|
||||||
|
|
||||||
## Available Fields
|
|
||||||
|
|
||||||
<ConfigEntryReference
|
<ConfigEntryReference
|
||||||
keys={[
|
keys={[
|
||||||
|
@ -351,6 +431,198 @@ spec:
|
||||||
]}
|
]}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
|
## Examples
|
||||||
|
|
||||||
|
### Default protocol
|
||||||
|
|
||||||
|
The following example configures the default protocol for all sidecar proxies.
|
||||||
|
|
||||||
|
<Tabs>
|
||||||
|
<Tab heading="Consul OSS">
|
||||||
|
|
||||||
|
<CodeTabs tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
Kind = "proxy-defaults"
|
||||||
|
Name = "global"
|
||||||
|
Config {
|
||||||
|
protocol = "http"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
apiVersion: consul.hashicorp.com/v1alpha1
|
||||||
|
kind: ProxyDefaults
|
||||||
|
metadata:
|
||||||
|
name: global
|
||||||
|
spec:
|
||||||
|
config:
|
||||||
|
protocol: http
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Kind": "proxy-defaults",
|
||||||
|
"Name": "global",
|
||||||
|
"Config": {
|
||||||
|
"protocol": "http"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
</CodeTabs>
|
||||||
|
|
||||||
|
</Tab>
|
||||||
|
<Tab heading="Consul Enterprise">
|
||||||
|
|
||||||
|
-> **NOTE:** The `proxy-defaults` config entry can only be created in the `default`
|
||||||
|
namespace and it will configure proxies in **all** namespaces.
|
||||||
|
|
||||||
|
<CodeTabs tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
Kind = "proxy-defaults"
|
||||||
|
Name = "global"
|
||||||
|
Namespace = "default" # Can only be set to "default".
|
||||||
|
Config {
|
||||||
|
protocol = "http"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
apiVersion: consul.hashicorp.com/v1alpha1
|
||||||
|
kind: ProxyDefaults
|
||||||
|
metadata:
|
||||||
|
name: global
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
config:
|
||||||
|
protocol: http
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Kind": "proxy-defaults",
|
||||||
|
"Name": "global",
|
||||||
|
"Namespace": "default",
|
||||||
|
"Config": {
|
||||||
|
"protocol": "http"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
</CodeTabs>
|
||||||
|
|
||||||
|
</Tab>
|
||||||
|
</Tabs>
|
||||||
|
|
||||||
|
### Prometheus
|
||||||
|
|
||||||
|
The following example configures all sidecar proxies to expose Prometheus metrics.
|
||||||
|
|
||||||
|
<CodeTabs tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
Kind = "proxy-defaults"
|
||||||
|
Name = "global"
|
||||||
|
Config {
|
||||||
|
envoy_prometheus_bind_addr = "0.0.0.0:9102"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
apiVersion: consul.hashicorp.com/v1alpha1
|
||||||
|
kind: ProxyDefaults
|
||||||
|
metadata:
|
||||||
|
name: global
|
||||||
|
spec:
|
||||||
|
config:
|
||||||
|
envoy_prometheus_bind_addr: '0.0.0.0:9102'
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Kind": "proxy-defaults",
|
||||||
|
"Name": "global",
|
||||||
|
"Config": {
|
||||||
|
"envoy_prometheus_bind_addr": "0.0.0.0:9102"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
</CodeTabs>
|
||||||
|
|
||||||
|
### Proxy-specific defaults
|
||||||
|
|
||||||
|
The following example configures some custom default values for all sidecar proxies.
|
||||||
|
|
||||||
|
<CodeTabs tabs={[ "HCL", "Kubernetes YAML", "JSON" ]}>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
Kind = "proxy-defaults"
|
||||||
|
Name = "global"
|
||||||
|
Config {
|
||||||
|
local_connect_timeout_ms = 1000
|
||||||
|
handshake_timeout_ms = 10000
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
apiVersion: consul.hashicorp.com/v1alpha1
|
||||||
|
kind: ProxyDefaults
|
||||||
|
metadata:
|
||||||
|
name: global
|
||||||
|
spec:
|
||||||
|
config:
|
||||||
|
local_connect_timeout_ms: 1000
|
||||||
|
handshake_timeout_ms: 10000
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
<CodeBlockConfig>
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Kind": "proxy-defaults",
|
||||||
|
"Name": "global",
|
||||||
|
"Config": {
|
||||||
|
"local_connect_timeout_ms": 1000,
|
||||||
|
"handshake_timeout_ms": 10000
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
</CodeBlockConfig>
|
||||||
|
</CodeTabs>
|
||||||
|
|
||||||
## ACLs
|
## ACLs
|
||||||
|
|
||||||
Configuration entries may be protected by [ACLs](/docs/security/acl).
|
Configuration entries may be protected by [ACLs](/docs/security/acl).
|
||||||
|
|
Loading…
Reference in New Issue