List of controller configuration keys

This document gives a list of all the configuration keys that can be applied to a Juju controller.

agent-logfile-max-backups

agent-logfile-max-backups is the maximum number of old agent log files to keep (compressed; saved on each unit, synced to the controller).

Type: integer

Default value: 2

Can be changed after bootstrap: yes

agent-logfile-max-size

agent-logfile-max-size is the maximum file size of each agent log file, in MB.

Type: string

Default value: 100M

Can be changed after bootstrap: yes

agent-ratelimit-max

agent-ratelimit-max is the maximum size of the token bucket used to ratelimit the agent connections to the API server.

Type: integer

Default value: 10

Can be changed after bootstrap: yes

agent-ratelimit-rate

agent-ratelimit-rate is the interval at which a new token is added to the token bucket, in milliseconds (ms).

Type: TimeDurationString

Default value: 250ms

Can be changed after bootstrap: yes

allow-model-access

allow-model-access sets whether the controller will allow users to connect to models they have been authorized for, even when they don’t have any access rights to the controller itself.

Type: boolean

Default value: false

Can be changed after bootstrap: no

api-port

api-port is the port used for api connections.

Type: integer

Default value: 17070

Can be changed after bootstrap: no

api-port-open-delay

api-port-open-delay is a duration that the controller will wait between when the controller has been deemed to be ready to open the api-port and when the api-port is actually opened. This value is only used when a controller-api-port value is set.

Type: TimeDurationString

Default value: 2s

Can be changed after bootstrap: yes

application-resource-download-limit

application-resource-download-limit limits the number of concurrent resource download requests from unit agents which will be served. The limit is per application. Use a value of 0 to disable the limit.

Type: integer

Default value: 0

Can be changed after bootstrap: yes

audit-log-capture-args

audit-log-capture-args determines whether the audit log will contain the arguments passed to API methods.

Type: boolean

Default value: false

Can be changed after bootstrap: yes

audit-log-exclude-methods

audit-log-exclude-methods is a list of Facade.Method names that aren’t interesting for audit logging purposes. A conversation with only calls to these will be excluded from the log. (They’ll still appear in conversations that have other interesting calls though.).

Type: string

Can be changed after bootstrap: yes

audit-log-max-backups

audit-log-max-backups is the number of old audit log files to keep (compressed).

Type: integer

Default value: 10

Can be changed after bootstrap: yes

audit-log-max-size

audit-log-max-size is the maximum size for the current audit log file, eg “250M”.

Type: string

Default value: 300M

Can be changed after bootstrap: yes

auditing-enabled

auditing-enabled determines whether the controller will record auditing information.

Type: boolean

Default value: true

Can be changed after bootstrap: yes

autocert-dns-name

autocert-dns-name sets the DNS name of the controller. If a client connects to this name, an official certificate will be automatically requested. Connecting to any other host name will use the usual self-generated certificate.

Type: string

Can be changed after bootstrap: no

autocert-url

autocert-url sets the URL used to obtain official TLS certificates when a client connects to the API. By default, certficates are obtains from LetsEncrypt. A good value for testing is “https://acme-staging.api.letsencrypt.org/directory”.

Type: string

Can be changed after bootstrap: no

ca-cert

ca-cert is the key for the controller’s CA certificate attribute.

Can be changed after bootstrap: no

caas-image-repo

caas-image-repo sets the docker repo to use for the jujud operator and mongo images.

Type: string

Can be changed after bootstrap: yes

caas-operator-image-path

This key is deprecated.

caas-operator-image-path sets the URL of the docker image used for the application operator. Deprecated: use caas-image-repo.

Type: string

Can be changed after bootstrap: no

controller-api-port

controller-api-port is an optional port that may be set for controllers that have a very heavy load. If this port is set, this port is used by the controllers to talk to each other - used for the local API connection as well as the pubsub forwarders. If this value is set, the api-port isn’t opened until the controllers have started properly.

Type: integer

Can be changed after bootstrap: no

controller-name

controller-name is the canonical name for the controller.

Type: non-empty string

Can be changed after bootstrap: no

controller-resource-download-limit

controller-resource-download-limit limits the number of concurrent resource download requests from unit agents which will be served. The limit is for the combined total of all applications on the controller. Use a value of 0 to disable the limit.

Type: integer

Default value: 0

Can be changed after bootstrap: yes

controller-uuid

controller-uuid is the key for the controller UUID attribute.

Can be changed after bootstrap: no

features

features allows a list of runtime changeable features to be updated.

Type: string

Can be changed after bootstrap: yes

identity-public-key

identity-public-key sets the public key of the identity manager. Use this when users should be managed externally rather than created locally on the controller.

Type: string

Can be changed after bootstrap: no

identity-url

identity-url sets the URL of the identity manager. Use this when users should be managed externally rather than created locally on the controller.

Type: string

Can be changed after bootstrap: no

juju-db-snap-channel

juju-db-snap-channel selects the channel to use when installing Mongo snaps for focal or later. The value is ignored for older releases.

Type: string

Default value: 4.4/stable

Can be changed after bootstrap: no

juju-ha-space

juju-ha-space is the network space within which the MongoDB replica-set should communicate.

Type: string

Can be changed after bootstrap: yes

juju-mgmt-space

juju-mgmt-space is the network space that agents should use to communicate with controllers.

Type: string

Can be changed after bootstrap: yes

jujud-controller-snap-source

jujud-controller-snap-source returns the source for the controller snap. Can be set to “legacy”, “snapstore”, “local” or “local-dangerous”. Cannot be changed.

Type: string

Default value: legacy

Can be changed after bootstrap: no

login-token-refresh-url

login-token-refresh-url sets the URL of the login JWT well-known endpoint. Use this when authentication/authorisation is done using a JWT in the login request rather than a username/password or macaroon and a local permissions model.

Type: string

Can be changed after bootstrap: no

max-agent-state-size

max-agent-state-size is the maximum allowed size of internal state data that agents can store to the controller in bytes. A value of 0 disables the quota checks although in principle, mongo imposes a hard (but configurable) limit of 16M.

Type: integer

Default value: 524288

Can be changed after bootstrap: yes

max-charm-state-size

max-charm-state-size is the maximum allowed size of charm-specific per-unit state data that charms can store to the controller in bytes. A value of 0 disables the quota checks although in principle, mongo imposes a hard (but configurable) limit of 16M.

Type: integer

Default value: 2097152

Can be changed after bootstrap: yes

max-debug-log-duration

max-debug-log-duration is used to provide a backstop to the execution of a debug-log command. If someone starts a debug-log session in a remote screen for example, it is very easy to disconnect from the screen while leaving the debug-log process running. This causes unnecessary load on the API server. The max debug-log duration has a default of 24 hours, which should be more than enough time for a debugging session.

Type: TimeDurationString

Default value: 24h0m0s

Can be changed after bootstrap: yes

max-prune-txn-batch-size

This key is deprecated.

max-prune-txn-batch-size (deprecated) is the maximum number of transactions we will evaluate in one go when pruning. Default is 1M transactions. A value <= 0 indicates to do all transactions at once.

Type: integer

Default value: 1000000

Can be changed after bootstrap: yes

max-prune-txn-passes

This key is deprecated.

max-prune-txn-passes (deprecated) is the maximum number of batches that we will process. So total number of transactions that can be processed is max-prune-txn-batch-size * max-prune-txn-passes. A value <= 0 implies ‘do a single pass’. If both max-prune-txn-batch-size and max-prune-txn-passes are 0, then the default value of 1M BatchSize and 100 passes will be used instead.

Type: integer

Default value: 100

Can be changed after bootstrap: yes

max-txn-log-size

max-txn-log-size is the maximum size the of capped txn log collection, eg “10M”.

Type: string

Default value: 10M

Can be changed after bootstrap: no

migration-agent-wait-time

migration-agent-wait-time is the maximum time that the migration-master worker will wait for agents to report for a migration phase when executing a model migration.

Type: TimeDurationString

Default value: 15m0s

Can be changed after bootstrap: yes

model-logfile-max-backups

model-logfile-max-backups is the number of old model log files to keep (compressed).

Type: integer

Default value: 2

Can be changed after bootstrap: yes

model-logfile-max-size

model-logfile-max-size is the maximum size of the log file written out by the controller on behalf of workers running for a model.

Type: string

Default value: 10M

Can be changed after bootstrap: yes

mongo-memory-profile

mongo-memory-profile sets the memory profile for MongoDB. Valid values are:

  • “low”: use the least possible memory

  • “default”: use the default memory profile.

Type: string

Default value: default

Can be changed after bootstrap: yes

object-store-s3-endpoint

object-store-s3-endpoint is the endpoint to use for S3 object stores.

Type: string

Can be changed after bootstrap: yes

object-store-s3-static-key

object-store-s3-static-key is the static key to use for S3 object stores.

Type: string

Can be changed after bootstrap: yes

object-store-s3-static-secret

object-store-s3-static-secret is the static secret to use for S3 object stores.

Type: string

Can be changed after bootstrap: yes

object-store-s3-static-session

object-store-s3-static-session is the static session token to use for S3 object stores.

Type: string

Can be changed after bootstrap: yes

object-store-type

object-store-type is the type of object store to use for storing blobs. This isn’t currently allowed to be changed dynamically, that will come when we support multiple object store types (not including state).

Type: string

Default value: file

Can be changed after bootstrap: yes

open-telemetry-enabled

open-telemetry-enabled returns whether open telemetry is enabled.

Type: boolean

Default value: false

Can be changed after bootstrap: yes

open-telemetry-endpoint

open-telemetry-endpoint returns the endpoint at which the telemetry will be pushed to.

Type: string

Can be changed after bootstrap: yes

open-telemetry-insecure

open-telemetry-insecure returns if the telemetry collector endpoint is insecure or not. Useful for debug or local testing.

Type: boolean

Default value: false

Can be changed after bootstrap: yes

open-telemetry-sample-ratio

open-telemetry-sample-ratio returns the sample ratio for open telemetry.

Type: string

Default value: 0.10

Can be changed after bootstrap: yes

open-telemetry-stack-traces

open-telemetry-stack-traces return whether stack traces should be added per span.

Type: boolean

Default value: false

Can be changed after bootstrap: yes

open-telemetry-tail-sampling-threshold

open-telemetry-tail-sampling-threshold returns the tail sampling threshold for open telemetry as a duration.

Type: TimeDurationString

Default value: 1ms

Can be changed after bootstrap: yes

prune-txn-query-count

prune-txn-query-count is the number of transactions to read in a single query. Minimum of 10, a value of 0 will indicate to use the default value (1000).

Type: integer

Default value: 1000

Can be changed after bootstrap: yes

prune-txn-sleep-time

prune-txn-sleep-time is the amount of time to sleep between processing each batch query. This is used to reduce load on the system, allowing other queries to time to operate. On large controllers, processing 1000 txs seems to take about 100ms, so a sleep time of 10ms represents a 10% slowdown, but allows other systems to operate concurrently. A negative number will indicate to use the default, a value of 0 indicates to not sleep at all.

Type: TimeDurationString

Default value: 10ms

Can be changed after bootstrap: yes

public-dns-address

public-dns-address is the public DNS address (and port) of the controller.

Type: string

Can be changed after bootstrap: yes

query-tracing-enabled

query-tracing-enabled returns whether query tracing is enabled. If so, any queries which take longer than query-tracing-threshold will be logged.

Type: boolean

Default value: false

Can be changed after bootstrap: yes

query-tracing-threshold

query-tracing-threshold returns the “threshold” for query tracing. Any queries which take longer than this value will be logged (if query tracing is enabled). The lower the threshold, the more queries will be output. A value of 0 means all queries will be output.

Type: TimeDurationString

Default value: 1s

Can be changed after bootstrap: yes

set-numa-control-policy

This key is deprecated.

set-numa-control-policy (true/false) is deprecated. Use to configure whether mongo is started with NUMA controller policy turned on.

Type: boolean

Default value: false

Can be changed after bootstrap: no

state-port

state-port is the port used for mongo connections.

Type: integer

Default value: 37017

Can be changed after bootstrap: no

system-ssh-keys

system-ssh-keys returns the set of ssh keys that should be trusted by agents of this controller regardless of the model.

Type: string

Can be changed after bootstrap: no