Configuration
While the NATS server has many flags that allow for simple testing of features, the NATS server products provide a flexible configuration format that combines the best of traditional formats and newer styles such as JSON and YAML.
The NATS configuration file supports the following syntax:
Lines can be commented with
#
and//
Values can be assigned to properties with:
Equals sign:
foo = 2
Colon:
foo: 2
Whitespace:
foo 2
Arrays are enclosed in brackets:
["a", "b", "c"]
Maps are enclosed in braces:
{foo: 2}
Maps can be assigned with no key separator
Semicolons can be used as terminators
Strings and Numbers
The configuration parser is very forgiving, as you have seen:
values can be a primitive, or a list, or a map
strings and numbers typically do the right thing
numbers support units such as, 1K for 1000, 1Kb for 1024
String values that start with a digit can create issues. To force such values as strings, quote them.
BAD Config:
Fixed Config:
Variables
Server configurations can specify variables. Variables allow you to reference a value from one or more sections in the configuration.
Variables:
Are block-scoped
Are referenced with a
$
prefix.Can be resolved from environment variables having the same name
If the environment variable value begins with a number you may have trouble resolving it depending on the server version you are running.
A similar configuration, but this time, the value is in the environment:
export TOKEN="hello"; nats-server -c /config/file
Include Directive
The include
directive allows you to split a server configuration into several files. This is useful for separating configuration into chunks that you can easily reuse between different servers.
Includes must use relative paths, and are relative to the main configuration (the one specified via the -c
option):
server.conf:
Note that
include
is not followed by=
or:
, as it is a directive.
auth.conf:
Configuration Properties
Connectivity
Property
Description
Default
host
Host for client connections.
0.0.0.0
port
Port for client connections.
4222
listen
Listen specification <host>:<port>
for client connections. Either use this or the options host
and/or port
.
same as host
, port
client_advertise
Advertise what host
and port
specify.
Configuration map for tls for client and http monitoring.
Connection Timeouts
Property
Description
Default
ping_interval
"2m"
ping_max
After how many unanswered pings the server will allow before closing the connection.
2
write_deadline
"2s"
Limits
Property
Description
Default
max_connections
Maximum number of active client connections.
64K
max_control_line
4Kb
max_payload
1Mb
max_pending
Maximum number of bytes buffered for a connection Applies to client connections.
64Mb
max_subscriptions
Maximum numbers of subscriptions per client and leafnode accounts connection.
0
, unlimited
Authentication and Authorization
Centralized Authentication and Authorization
Property
Description
Configuration map for client authentication/authorization.
Configuration map for multi tenancy via accounts.
Decentralized Authentication and Authorization
The Configuration options here refer to JWT based authentication and authorization.
Property
Description
Path to an operator JWT.
Runtime Configuration
Property
Description
Default
disable_sublist_cache
If true
disable subscription caches for all accounts. This is saves resources in situations where different subjects are used all the time.
false
, cache enabled
lame_duck_duration
"2m"
Monitoring and Tracing
Property
Description
Default
server_name
The servers name, shows up in logging. Defaults to the server's id.
Generated Server ID
trace
If true
enable protocol trace log messages. Excludes the system account.
false
, disabled
trace_verbose
If true
enable protocol trace log messages. Includes the system account.
false
, disabled
debug
If true
enable debug log messages
false
, disabled
logtime
If set to false
, log without timestamps
true
, include timestamp
log_file
Log file name, relative to...
No log file
Size in bytes after the log file rolls over to a new one
0
, unlimited
max_traced_msg_len
Set a limit to the trace of the payload of a message.
0
, unlimited
syslog
Log to syslog.
false
, disabled
remote_syslog
http port for server monitoring.
Listen specification <host>:<port>
for server monitoring.
https port for server monitoring. This is influenced by the tls property.
base path for monitoring endpoints.
/
Listen specification <host>:<port>
for TLS server monitoring.
system_account
pid_file
port_file_dir
Directory to write a file containing the servers open ports to, relative to ...
connect_error_reports
Number of attempts at which a repeated failed route, gateway or leaf node connection is reported. Connect attempts are made once every second.
3600
, approx every hour
reconnect_error_reports
Number of failed attempt to reconnect a route, gateway or leaf node connection. Default is to report every attempt.
1
, every failed attempt
Configuration Reloading
A server can reload most configuration changes without requiring a server restart or clients to disconnect by sending the nats-server a signal:
最后更新于
这有帮助吗?