Configuration
See torero.conf for using a config file.
Descriptions for each configuration variable can be seen below.
TORERO_APPLICATION_MODE
More information about this very important configuration variable can be found within the application modes documentation.
File
Section: application Key: application_mode
Default
local
All in one server that runs without server and client.
Possible Values
["local", "client", "server"]
TORERO_APPLICATION_AUTO_ACCEPT_EULA
To use torero you must accept the EULA that can be found at: https://torero.dev/licenses/eula. If you
want to accept this without having to interact with acceptance on command line, this can be set to
true
. This is useful in situations where running in a non-interactive mode such as server deployments.
Environment Variable
TORERO_APPLICATION_AUTO_ACCEPT_EULA
File
Section: application Key: auto_accept_eula
Default
false
TORERO_APPLICATION_CA_CERTIFICATE_FILE
When using certificates with TLS this allows to set the application CA. This is set on the application level due to that the CA should be used for all runner, server, and client implementations.
Environment Variable
TORERO_APPLICATION_CA_CERTIFICATE_FILE
File
Section: application Key: ca_certificate_file
Default
No default value provided
TORERO_APPLICATION_CLUSTER_ID
The ID that uniquely identifies a cluster of a torero core servers with torero runner nodes. It should be noted that torero
saves all resources within the same cluster to a specific namespace for that cluster within the database. This means that
if you change your cluster ID, torero will fetch/save resources from a different section of the database. Consider running
using the torero db export
and torero db import
commands to migrate data resources clusters.
Environment Variable
TORERO_APPLICATION_CLUSTER_ID
File
Section: application Key: cluster_id
Default
No default value provided
TORERO_APPLICATION_WORKING_DIR
The location where torero will store various files that it will work off of.
Examples include torero's database when TORERO_STORE_BACKEND=local
, the
torero.log
file when torero is being run as a client, and the ssh
known_hosts file.
Environment Variable
TORERO_APPLICATION_WORKING_DIR
File
Section: application Key: working_dir
Default
~/.torero.d
(Home directory of user running torero)
TORERO_CLIENT_CERTIFICATE_FILE
The full path to the certificate file to used by the torero client when
communicating with a torero server. Required when TORERO_CLIENT_USE_TLS
is
enabled.
Environment Variable
TORERO_CLIENT_CERTIFICATE_FILE
File
Section: client Key: certificate_file
Default
No default value provided
TORERO_CLIENT_HOST
The host address of a torero server that a torero client will attempt to connect to when TORERO_APPLICATION_MODE is set to 'client'.
Environment Variable
TORERO_CLIENT_HOST
File
Section: client Key: host
Default
No default value provided
TORERO_CLIENT_PORT
The port of a torero server that a torero client will attempt to connect to.
Environment Variable
TORERO_CLIENT_PORT
File
Section: client Key: port
Default
50051
TORERO_CLIENT_PRIVATE_KEY_FILE
The full path to the private key file that is used by the torero client when
connecting to a torero server. Required when TORERO_CLIENT_USE_TLS
is
enabled.
Environment Variable
TORERO_CLIENT_PRIVATE_KEY_FILE
File
Section: client Key: private_key_file
Default
No default value provided
TORERO_CLIENT_USE_TLS
Whether or not a torero client will use TLS when connecting to a torero server.
Environment Variable
TORERO_CLIENT_USE_TLS
File
Section: client Key: use_tls
Default
true
TORERO_FEATURES_ANSIBLE_ENABLED
A flag to enable or disable all Ansible features. This flag can disable the management of Ansible playbooks on a torero as well as the execution of Ansible services.
Environment Variable
TORERO_FEATURES_ANSIBLE_ENABLED
File
Section: features Key: ansible_enabled
Default
true
TORERO_FEATURES_HOSTKEYS_ENABLED
A flag to enable or disable the hostkeys feature. This flag can disable the hostkeys management commands.
Environment Variable
TORERO_FEATURES_HOSTKEYS_ENABLED
File
Section: features Key: hostkeys_enabled
Default
true
TORERO_FEATURES_OPENTOFU_ENABLED
A flag to enable or disable all OpenTofu features. This flag can disable the management of OpenTofu plans on a torero as well as the execution of OpenTofu services.
Environment Variable
TORERO_FEATURES_OPENTOFU_ENABLED
File
Section: features Key: opentofu_enabled
Default
true
TORERO_FEATURES_PYTHON_ENABLED
A flag to enable or disable all Python features. This flag can disable the management of Python scripts on a torero as well as the execution of Python services.
Environment Variable
TORERO_FEATURES_PYTHON_ENABLED
File
Section: features Key: python_enabled
Default
true
TORERO_LOG_CONSOLE_JSON
Whether the console logs should be displayed in the default format shown here
2024-02-14T09:18:28-06:00 INF grpc server is starting up
.
or in JSON as shown here
{"level":"info","time":"2024-02-14T09:18:28-06:00","message":"grpc server is starting up"}
Environment Variable
TORERO_LOG_CONSOLE_JSON
File
Section: log Key: console_json
Default
false
TORERO_LOG_FILE_ENABLED
Controls whether or not torero should write to a log file.
Environment Variable
TORERO_LOG_FILE_ENABLED
File
Section: log Key: file_enabled
Default
true
TORERO_LOG_FILE_JSON
Whether the file logs should be displayed in the default format shown here
2024-02-14T09:18:28-06:00 INF grpc server is starting up
.
or in JSON as shown here
{"level":"info","time":"2024-02-14T09:18:28-06:00","message":"grpc server is starting up"}
Environment Variable
TORERO_LOG_FILE_JSON
File
Section: log Key: file_json
Default
false
TORERO_LOG_LEVEL
The verbosity of the logs that torero will display to the console and file logs.
Environment Variable
TORERO_LOG_LEVEL
File
Section: log Key: level
Default
INFO
Possible Values
["TRACE", "DEBUG", "INFO", "WARN", "ERROR"]
TORERO_LOG_SERVER_DIR
The directory to place torero's torero.log
file when launched as a server.
When torero is not launched as a server or a runner, logs will be placed in
TORERO_APPLICATION_WORKING_DIR
.
Environment Variable
TORERO_LOG_SERVER_DIR
File
Section: log Key: server_dir
Default
/var/log/torero
TORERO_LOG_TIMESTAMP_TIMEZONE
Allows a user to specify a timezone that timestamps will be displayed within torero logs. e.g.
2024-05-03T10:36:55-05:00 INF using local connection
Timezones will be shown in UTC by default. If local
is set, torero will use your machine's timezone. Additionally, one
can set a tz identifier such as America/New_York
.
Environment Variable
TORERO_LOG_TIMESTAMP_TIMEZONE
File
Section: log Key: timestamp_timezone
Default
utc
Possible Values
["utc", "local", ...any tz identifier]
TORERO_RUNNER_ANNOUNCEMENT_ADDRESS
The address that a torero runner will register to its cluster when coming online. When a torero core server attempts to send a service execution request to a torero runner, it will send it to this address. If this variable is left unset, the torero runner will attempt to identify its own ip address and register it to the cluster.
Environment Variable
TORERO_RUNNER_ANNOUNCEMENT_ADDRESS
File
Section: runner Key: announcement_address
Default
No default value provided
TORERO_RUNNER_CLIENT_CERT_AUTH
If set to true, torero will require requests sent from a torero server to a torero runner use 'Client-to-server authentication' where mutual TLS authentication will be used.
Mutual TLS ensures that a client and server mutually trust the signing CA when communicating.
Environment Variable
TORERO_RUNNER_CLIENT_CERT_AUTH
File
Section: runner Key: client_cert_auth
Default
false
TORERO_RUNNER_CERTIFICATE_FILE
The full path to the certificate file that the torero runner will use when connecting to a torero server when
TORERO_RUNNER_USE_TLS
is enabled.
Environment Variable
TORERO_RUNNER_CERTIFICATE_FILE
File
Section: runner Key: certificate_file
Default
/etc/torero/torero.crt
TORERO_RUNNER_LISTEN_ADDRESS
The listen address that a torero runner will listen for service execution requests from a torero server core node from.
Environment Variable
TORERO_RUNNER_LISTEN_ADDRESS
File
Section: runner Key: listen_address
Default
127.0.0.1
TORERO_RUNNER_PORT
The port that a torero runner will listen for requests from a core torero node from.
Environment Variable
TORERO_RUNNER_PORT
File
Section: runner Key: port
Default
50051
TORERO_RUNNER_PRIVATE_KEY_FILE
The full path to the private key file that the torero runner will use when connecting to a torero core server node
when TORERO_RUNNER_USE_TLS
is enabled.
Environment Variable
TORERO_RUNNER_PRIVATE_KEY_FILE
File
Section: runner Key: private_key_file
Default
/etc/torero/torero.key
TORERO_RUNNER_RUNTIME_DATA_DIR
The location where torero will store the virtual environments that are created when executing Python and Ansible services
when TORERO_APPLICATION_MODE
is set to runner.
Environment Variable
TORERO_RUNNER_RUNTIME_DATA_DIR
File
Section: runner Key: runtime_data_dir
Default
/var/lib/torero
TORERO_RUNNER_USE_TLS
Whether or not a torero runner will require TLS when connecting to a torero core server node.
Environment Variable
TORERO_RUNNER_USE_TLS
File
Section: runner Key: use_tls
Default
true
TORERO_SECRETS_ENCRYPT_KEY_FILE
The location of the file used to locally encrypt/decrypt secrets.
Environment Variable
TORERO_SECRETS_ENCRYPT_KEY_FILE
File
Section: secrets Key: encrypt_key_file
Default
No default value provided
TORERO_SERVER_API_KEY_EXPIRATION
The amount of time in minutes before a user API key expires.
Environment Variable
TORERO_SERVER_API_KEY_EXPIRATION
File
Section: server Key: api_key_expiration
Default
1440
TORERO_SERVER_CLIENT_CERT_AUTH
If set to true, a torero server will require requests sent from a torero client to use 'Client-to-server authentication' where mutual TLS authentication will be used.
Mutual TLS ensures that a client and server mutually trust the signing CA when communicating.
Environment Variable
TORERO_SERVER_CLIENT_CERT_AUTH
File
Section: server Key: client_cert_auth
Default
false
TORERO_SERVER_CERTIFICATE_FILE
The full path to the certificate file that the torero server will use when serving connections to torero clients
when TORERO_SERVER_USE_TLS
is enabled.
Environment Variable
TORERO_SERVER_CERTIFICATE_FILE
File
Section: server Key: certificate_file
Default
/etc/torero/torero.crt
TORERO_SERVER_DISTRIBUTED_EXECUTION
Determines if a server node is an 'all in one' deployment where services are run on the same node as the actual server itself. If you are deploying a torero architecture where you have separate runner nodes to execute services, you will want to set this to true.
Environment Variable
TORERO_SERVER_DISTRIBUTED_EXECUTION
File
Section: server Key: distributed_execution
Default
false
TORERO_SERVER_LISTEN_ADDRESS
The address that a torero server will listen from.
Environment Variable
TORERO_SERVER_LISTEN_ADDRESS
File
Section: server Key: listen_address
Default
127.0.0.1
TORERO_SERVER_PORT
The port that a torero server will listen from.
Environment Variable
TORERO_SERVER_PORT
File
Section: server Key: port
Default
50051
TORERO_SERVER_PRIVATE_KEY_FILE
The full path to the private key file that the torero server will use when
serving connections to torero clients. Required when TORERO_SERVER_USE_TLS
is enabled.
Environment Variable
TORERO_SERVER_PRIVATE_KEY_FILE
File
Section: server Key: private_key_file
Default
/etc/torero/torero.key
TORERO_SERVER_RUNTIME_DATA_DIR
The location where torero will store the virtual environments that are created when executing Python and Ansible services
when TORERO_APPLICATION_MODE
is set to server.
Environment Variable
TORERO_SERVER_RUNTIME_DATA_DIR
File
Section: server Key: runtime_data_dir
Default
/var/lib/torero
TORERO_SERVER_USE_TLS
Whether or not a torero server will require TLS when serving connections to torero clients.
Environment Variable
TORERO_SERVER_USE_TLS
File
Section: server Key: use_tls
Default
true
TORERO_STORE_BACKEND
Whether or place store torero's persistent data 'locally' at
TORERO_APPLICATION_WORKING_DIR/torero.db
or in memory. More information can be found
at docs/store.md
Environment Variable
TORERO_STORE_BACKEND
File
Section: store Key: backend
Default
local
Possible Values
["local", "memory", "etcd"]
TORERO_STORE_ETCD_CLIENT_CERT_AUTH
When running torero with TORERO_STORE_BACKEND
set to etcd
, with TORERO_STORE_ETCD_USE_TLS
set to true, this
configuration variable modifies what type of TLS authentication method will be used.
If set to false, torero will attempt to connect to etcd using 'Client-to-server transport security' where the only
required certificate on torero's side will be from TORERO_STORE_ETCD_CA_CERTIFICATE_FILE
. This is the similar to the
'Example 1: Client-to-server transport security with HTTPS' section on etcd's security page.
If set to true, torero will attempt to connect to etcd using 'Client-to-server authentication' where mutual TLS authentication
will occur between your torero instance as well as the etcd server. This will require you to set
TORERO_STORE_ETCD_CA_CERTIFICATE_FILE
, TORERO_STORE_ETCD_CERTIFICATE_FILE
, and TORERO_STORE_ETCD_PRIVATE_KEY_FILE
.
This is similar to the 'Example 3: Transport security & client certificates in a cluster' section on etcd's security page.
Environment Variable
TORERO_STORE_ETCD_CLIENT_CERT_AUTH
File
Section: store Key: etcd_client_cert_auth
Default
false
TORERO_STORE_ETCD_HOSTS
When running torero with TORERO_STORE_BACKEND
set to etcd
, this configuration variable allows you to set the etcd
host(s) that torero should connect to for its backend storage. A host entry consists of an address and a port. e.g. hostname:port
.
If there is more than one host in the etcd cluster, the hosts should be separated by spaces e.g. hostname1:port hostname2:port
.
Environment Variable
TORERO_STORE_ETCD_HOSTS
File
Section: store Key: etcd_hosts
Default
localhost:2379
TORERO_STORE_ETCD_USE_TLS
Controls whether or not torero will utilize TLS authentication when connecting to the etcd cluster. More information on configuring TLS on an etcd cluster can be found on the security section of the etcd document
Environment Variable
TORERO_STORE_ETCD_USE_TLS
File
Section: store Key: etcd_use_tls
Default
true
TORERO_STORE_ETCD_CA_CERTIFICATE_FILE
The certificate authority certificate file to use when connecting to etcd.
Environment Variable
TORERO_STORE_ETCD_CA_CERTIFICATE_FILE
File
Section: store Key: etcd_ca_certificate_file
Default
No default value provided
TORERO_STORE_ETCD_CERTIFICATE_FILE
The public certificate file to use when connecting to etcd.
Environment Variable
TORERO_STORE_ETCD_CERTIFICATE_FILE
File
Section: store Key: etcd_certificate_file
Default
No default value provided
TORERO_STORE_ETCD_PRIVATE_KEY_FILE
The private key file to use when connecting to etcd.
Environment Variable
TORERO_STORE_ETCD_PRIVATE_KEY_FILE
File
Section: store Key: etcd_private_key_file
Default
No default value provided
TORERO_TERMINAL_NO_COLOR
Whether or not console outputs as well as logs can have color in their outputs.
Environment Variable
TORERO_TERMINAL_NO_COLOR
File
Section: terminal Key: no_color
Default
false
TORERO_TERMINAL_TIMESTAMP_TIMEZONE
Allows a user to specify a timezone that timestamps will be displayed on torero terminal outputs such as when running services. e.g.
>_ torero run ansible-playbook hello-world
Start Time: 2024-05-03T10:35:44-05:00
End Time: 2024-05-03T10:35:46-05:00
Elapsed Time: 2.276147s
Timezones will be shown in UTC by default. If local
is set, torero will use your machine's timezone. Additionally, one can set a
tz identifier such as America/New_York
.
Environment Variable
TORERO_TERMINAL_TIMESTAMP_TIMEZONE
File
Section: terminal Key: timestamp_timezone
Default
utc
Possible Values
["utc", "local", ...any tz identifier]