pgmoneta configuration 
The configuration is loaded from either the path specified by the -c flag or /etc/pgmoneta/pgmoneta.conf.
The configuration of pgmoneta is split into sections using the [ and ] characters.
The main section, called [pgmoneta], is where you configure the overall properties of pgmoneta.
Other sections doesn't have any requirements to their naming so you can give them meaningful names like [primary] for the primary PostgreSQL instance.
All properties are in the format key = value.
The characters # and ; can be used for comments; must be the first character on the line. The Bool data type supports the following values: on, yes, 1, true, off, no, 0 and false.
See a sample configuration for running pgmoneta on localhost.
[pgmoneta] 
| Property | Default | Unit | Required | Description | 
|---|---|---|---|---|
| host | String | Yes | The bind address for pgmoneta | |
| unix_socket_dir | String | Yes | The Unix Domain Socket location. Can interpolate environment variables (e.g., $HOME) | |
| base_dir | String | Yes | The base directory for the backup. Can interpolate environment variables (e.g., $HOME) | |
| metrics | 0 | Int | No | The metrics port (disable = 0) | 
| metrics_cache_max_age | 0 | String | No | The time to keep a Prometheus (metrics) response in cache. If this value is specified without units, it is taken as seconds. Setting this parameter to 0 disables caching. It supports the following units as suffixes: 'S' for seconds (default), 'M' fo | 
| r minutes, 'H' for hours, 'D' for days, and 'W' for weeks. | ||||
| metrics_cache_max_size | 256k | String | No | The maximum amount of data to keep in cache when serving Prometheus responses. Changes require restart. This parameter determines the size of memory allocated for the cache even if metrics_cache_max_ageormetricsare disabled. Its value, however, is taken into account only ifmetrics_cache_max_ageis set to a non-zero value. Supports suffixes: 'B' (bytes), the default if omitted, 'K' or 'KB' (kilobytes), 'M' or 'MB' (megabytes), 'G' or 'GB' (gigabytes). | 
| management | 0 | Int | No | The remote management port (disable = 0) | 
| compression | zstd | String | No | The compression type (none, gzip, client-gzip, server-gzip, zstd, client-zstd, server-zstd, lz4, client-lz4, server-lz4, bzip2, client-bzip2) | 
| compression_level | 3 | Int | No | The compression level | 
| workers | 0 | Int | No | The number of workers that each process can use for its work. Use 0 to disable. Maximum is CPU count | 
| workspace | /tmp/pgmoneta-workspace/ | String | No | The directory for the workspace that incremental backup can use for its work. Can interpolate environment variables (e.g., $HOME) | 
| storage_engine | local | String | No | The storage engine type (local, ssh, s3, azure) | 
| encryption | none | String | No | The encryption mode for encrypt wal and data none: No encryptionaes | aes-256 | aes-256-cbc: AES CBC (Cipher Block Chaining) mode with 256 bit key lengthaes-192 | aes-192-cbc: AES CBC mode with 192 bit key lengthaes-128 | aes-128-cbc: AES CBC mode with 128 bit key lengthaes-256-ctr: AES CTR (Counter) mode with 256 bit key lengthaes-192-ctr: AES CTR mode with 192 bit key lengthaes-128-ctr: AES CTR mode with 128 bit key length | 
| create_slot | no | Bool | No | Create a replication slot for all server. Valid values are: yes, no | 
| ssh_hostname | String | Yes | Defines the hostname of the remote system for connection | |
| ssh_username | String | Yes | Defines the username of the remote system for connection | |
| ssh_base_dir | String | Yes | The base directory for the remote backup | |
| ssh_ciphers | aes-256-ctr, aes-192-ctr, aes-128-ctr | String | No | The supported ciphers for communication. aes | aes-256 | aes-256-cbc: AES CBC (Cipher Block Chaining) mode with 256 bit key lengthaes-192 | aes-192-cbc: AES CBC mode with 192 bit key lengthaes-128 | aes-128-cbc: AES CBC mode with 128 bit key lengthaes-256-ctr: AES CTR (Counter) mode with 256 bit key lengthaes-192-ctr: AES CTR mode with 192 bit key lengthaes-128-ctr: AES CTR mode with 128 bit key length. Otherwise verbatim | 
| s3_aws_region | String | Yes | The AWS region | |
| s3_access_key_id | String | Yes | The IAM access key ID | |
| s3_secret_access_key | String | Yes | The IAM secret access key | |
| s3_bucket | String | Yes | The AWS S3 bucket name | |
| s3_base_dir | String | Yes | The base directory for the S3 bucket | |
| azure_storage_account | String | Yes | The Azure storage account name | |
| azure_container | String | Yes | The Azure container name | |
| azure_shared_key | String | Yes | The Azure storage account key | |
| azure_base_dir | String | Yes | The base directory for the Azure container | |
| retention | 7, - , - , - | Array | No | The retention time in days, weeks, months, years | 
| link | on | Bool | No | Use links to limit backup size | 
| log_type | console | String | No | The logging type (console, file, syslog) | 
| log_level | info | String | No | The logging level, any of the (case insensitive) strings FATAL,ERROR,WARN,INFOandDEBUG(that can be more specific asDEBUG1thruDEBUG5). Debug level greater than 5 will be set toDEBUG5. Not recognized values will make the log_level beINFO | 
| log_path | pgmoneta.log | String | No | The log file location. Can be a strftime(3) compatible string. Can interpolate environment variables (e.g., $HOME) | 
| log_rotation_age | 0 | String | No | The time after which log file rotation is triggered. If this value is specified without units, it is taken as seconds. Setting this parameter to 0 disables log rotation based on time. It supports the following units as suffixes: 'S' for seconds (default) | 
| , 'M' for minutes, 'H' for hours, 'D' for days, and 'W' for weeks. | ||||
| log_rotation_size | 0 | String | No | The size of the log file that will trigger a log rotation. Supports suffixes: 'B' (bytes), the default if omitted, 'K' or 'KB' (kilobytes), 'M' or 'MB' (megabytes), 'G' or 'GB' (gigabytes). A value of 0(with or without suffix) disables. | 
| log_line_prefix | %Y-%m-%d %H:%M:%S | String | No | A strftime(3) compatible string to use as prefix for every log line. Must be quoted if contains spaces. | 
| log_mode | append | String | No | Append to or create the log file (append, create) | 
| blocking_timeout | 30 | Int | No | The number of seconds the process will be blocking for a connection (disable = 0) | 
| tls | off | Bool | No | Enable Transport Layer Security (TLS) | 
| tls_cert_file | String | No | Certificate file for TLS. This file must be owned by either the user running pgmoneta or root. Can interpolate environment variables (e.g., $HOME) | |
| tls_key_file | String | No | Private key file for TLS. This file must be owned by either the user running pgmoneta or root. Additionally permissions must be at least 0640when owned by root or0600otherwise. Can interpolate environment variables (e.g.,$HOME) | |
| tls_ca_file | String | No | Certificate Authority (CA) file for TLS. This file must be owned by either the user running pgmoneta or root. | |
| metrics_cert_file | String | No | Certificate file for TLS for Prometheus metrics. This file must be owned by either the user running pgmoneta or root. | |
| metrics_key_file | String | No | Private key file for TLS for Prometheus metrics. This file must be owned by either the user running pgmoneta or root. Additionally permissions must be at least 0640when owned by root or0600otherwise. | |
| metrics_ca_file | String | No | Certificate Authority (CA) file for TLS for Prometheus metrics. This file must be owned by either the user running pgmoneta or root. | |
| libev | auto | String | No | Select the libev backend to use. Valid options: auto,select,poll,epoll,iouring,devpollandport | 
| buffer_size | 65535 | Int | No | The network buffer size ( SO_RCVBUFandSO_SNDBUF) | 
| backup_max_rate | 0 | Int | No | The number of bytes of tokens added every one second to limit the backup rate | 
| network_max_rate | 0 | Int | No | The number of bytes of tokens added every one second to limit the netowrk backup rate | 
| verification | 0 | Int | No | The time between verification of a backup. If this value is specified without units, it is taken as seconds. Setting this parameter to 0 disables verification. It supports the following units as suffixes: 'S' for seconds (default), 'M' for minutes, 'H' for hours, 'D' for days, and 'W' for weeks. | 
| keep_alive | on | Bool | No | Have SO_KEEPALIVEon sockets | 
| nodelay | on | Bool | No | Have TCP_NODELAYon sockets | 
| non_blocking | on | Bool | No | Have O_NONBLOCKon sockets | 
| backlog | 16 | Int | No | The backlog for listen(). Minimum16 | 
| hugepage | try | String | No | Huge page support ( off,try,on) | 
| pidfile | String | No | Path to the PID file. If not specified, it will be automatically set to unix_socket_dir/pgmoneta.<host>.pidwhere<host>is the value of thehostparameter orallifhost = *. Can interpolate environment variables (e.g.,$HOME) | |
| update_process_title | verbose | String | No | The behavior for updating the operating system process title. Allowed settings are: never(oroff), does not update the process title;strictto set the process title without overriding the existing initial process title length;minimalto set the process title to the base description;verbose(orfull) to set the process title to the full description. Please note thatstrictandminimalare honored only on those systems that do not provide a native way to set the process title (e.g., Linux). On other systems, there is no difference betweenstrictandminimaland the assumed behaviour isminimaleven ifstrictis used.neverandverboseare always honored, on every system. On Linux systems the process title is always trimmed to 255 characters, while on system that provide a natve way to set the process title it can be longer. | 
Server section 
| Property | Default | Unit | Required | Description | 
|---|---|---|---|---|
| host | String | Yes | The address of the PostgreSQL instance | |
| port | Int | Yes | The port of the PostgreSQL instance | |
| user | String | Yes | The replication user name | |
| wal_slot | String | Yes | The replication slot for WAL | |
| create_slot | no | Bool | No | Create a replication slot for this server. Valid values are: yes, no | 
| follow | String | No | Failover to this server if follow server fails | |
| retention | Array | No | The retention for the server in days, weeks, months, years | |
| wal_shipping | String | No | The WAL shipping directory | |
| workspace | /tmp/pgmoneta-workspace/ | String | No | The directory for the workspace that incremental backup can use for its work. Can interpolate environment variables (e.g., $HOME) | 
| hot_standby | String | No | Hot standby directories. Single directory or comma separated directories up to 8 (e.g., /path/to/hot/standby1,/path/to/hot/standby2) | |
| hot_standby_overrides | String | No | Files to override in the hot standby directory. If multiple hot standbys are specified then this setting is separated by a | | |
| hot_standby_tablespaces | String | No | Tablespace mappings for the hot standby. Syntax is [from -> to,?]+. If multiple hot standbys are specified then this setting is separated by a | | |
| workers | -1 | Int | No | The number of workers that each process can use for its work. Use 0 to disable, -1 means use the global settting | 
| backup_max_rate | -1 | Int | No | The number of bytes of tokens added every one second to limit the backup rate. Use 0 to disable, -1 means use the global settting | 
| network_max_rate | -1 | Int | No | The number of bytes of tokens added every one second to limit the netowrk backup rate. Use 0 to disable, -1 means use the global settting | 
| tls_cert_file | String | No | Certificate file for TLS. This file must be owned by either the user running pgmoneta or root. Can interpolate environment variables (e.g., $HOME) | |
| tls_key_file | String | No | Private key file for TLS. This file must be owned by either the user running pgmoneta or root. Additionally permissions must be at least 0640when owned by root or0600otherwise. Can interpolate environment variables (e.g.,$HOME) | |
| tls_ca_file | String | No | Certificate Authority (CA) file for TLS. This file must be owned by either the user running pgmoneta or root. Can interpolate environment variables (e.g., $HOME) | 
The user specified must have the REPLICATION option in order to stream the Write-Ahead Log (WAL), and must have access to the postgres database in order to get the necessary configuration parameters.
Note, that PostgreSQL 13+ is required, as well as having wal_level at replica or logical level.
Note, that if host starts with a / it represents a path and pgmoneta will connect using a Unix Domain Socket.
pgmoneta_users configuration 
The pgmoneta_users configuration defines the users known to the system. This file is created and managed through the pgmoneta-admin tool.
The configuration is loaded from either the path specified by the -u flag or /etc/pgmoneta/pgmoneta_users.conf.
pgmoneta_admins configuration 
The pgmoneta_admins configuration defines the administrators known to the system. This file is created and managed through the pgmoneta-admin tool.
The configuration is loaded from either the path specified by the -A flag or /etc/pgmoneta/pgmoneta_admins.conf.
If pgmoneta has both Transport Layer Security (TLS) and management enabled then pgmoneta-cli can connect with TLS using the files ~/.pgmoneta/pgmoneta.key (must be 0600 permission), ~/.pgmoneta/pgmoneta.crt and ~/.pgmoneta/root.crt.
pgmoneta_walinfo configuration 
The pgmoneta_walinfo configuration defines the info needed for walinfo to work.
The configuration is loaded from either the path specified by the -c flag or /etc/pgmoneta/pgmoneta_walinfo.conf if -c wasn't provided.
[pgmoneta_walinfo] 
| Property | Default | Unit | Required | Description | 
|---|---|---|---|---|
| log_type | console | String | No | The logging type (console, file, syslog) | 
| log_level | info | String | No | The logging level, any of the (case insensitive) strings FATAL,ERROR,WARN,INFOandDEBUG(that can be more specific asDEBUG1thruDEBUG5). Debug level greater than 5 will be set toDEBUG5. Not recognized values will make the log_level beINFO | 
| log_path | pgmoneta.log | String | No | The log file location. Can be a strftime(3) compatible string. Can interpolate environment variables (e.g., $HOME) | 
Server section 
| Property | Default | Unit | Required | Description | 
|---|---|---|---|---|
| host | String | Yes | The address of the PostgreSQL instance | |
| port | Int | Yes | The port of the PostgreSQL instance | |
| user | String | Yes | The replication user name |