Files
zulip/puppet/zulip/templates/postgresql/zulip.conf.template.erb
2025-05-12 11:12:45 -07:00

84 lines
2.7 KiB
Plaintext

<% unless @listen_addresses.nil? -%>
# Bind to specific address
listen_addresses = <%= @listen_addresses %>
<% end -%>
# This has an improved set of stopwords.
default_text_search_config = 'zulip.english_us_search'
# Provide more comprehensive on-disk logs
logging_collector = on
log_directory = '/var/log/postgresql'
log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log'
log_rotation_age = 7d
log_rotation_size = 100MB
log_min_duration_statement = 500
log_line_prefix = '%m [%c]: [%l-1] '
log_checkpoints = on
log_lock_waits = on
log_temp_files = 0
log_autovacuum_min_duration = 100
# Adjust autovacuum for having many mostly-append-only tables
autovacuum_freeze_max_age = 2000000000
vacuum_freeze_min_age = 1000000000
vacuum_freeze_table_age = 1800000000
# Performance settings
max_connections = 1000
maintenance_work_mem = <%= @maintenance_work_mem %>
effective_cache_size = <%= @effective_cache_size %>
work_mem = <%= @work_mem %>
shared_buffers = <%= @shared_buffers %>
<% unless @wal_buffers.nil? -%>
wal_buffers = <%= @wal_buffers %>
<% end -%>
<% unless @min_wal_size.nil? -%>
min_wal_size = <%= @min_wal_size %>
<% end -%>
<% unless @max_wal_size.nil? -%>
max_wal_size = <%= @max_wal_size %>
<% end -%>
<% unless @random_page_cost.nil? -%>
random_page_cost = <%= @random_page_cost %>
<% end -%>
<% unless @effective_io_concurrency.nil? -%>
effective_io_concurrency = <%= @effective_io_concurrency %>
<% end -%>
<% unless @max_worker_processes.nil? -%>
max_worker_processes = <%= @max_worker_processes %>
<% end -%>
<% unless @max_parallel_workers_per_gather.nil? -%>
max_parallel_workers_per_gather = <%= @max_parallel_workers_per_gather %>
<% end -%>
<% unless @max_parallel_workers.nil? -%>
max_parallel_workers = <%= @max_parallel_workers %>
<% end -%>
<% unless @max_parallel_maintenance_workers.nil? -%>
max_parallel_maintenance_workers = <%= @max_parallel_maintenance_workers %>
<% end -%>
<% if @s3_backups_bucket != '' -%>
# WAL backups to S3 (may also be used for replication)
archive_mode = on
archive_command = '/usr/bin/timeout 10m /usr/local/bin/env-wal-g wal-push %p'
restore_command = '/usr/local/bin/env-wal-g wal-fetch "%f" "%p"'
<% end -%>
<% unless @replication_primary.nil? || @replication_user.nil? -%>
# Streaming replication
primary_conninfo = 'host=<%= @replication_primary %> user=<%= @replication_user -%>
<% if @replication_password != '' %> password=<%= @replication_password %><% end -%>
<% unless @ssl_mode.nil? %> sslmode=<%= @ssl_mode %><% end -%>
'
<% end -%>
<% unless @ssl_cert_file.nil? -%>
ssl_cert_file = '<%= @ssl_cert_file %>'
<% end -%>
<% unless @ssl_key_file.nil? -%>
ssl_key_file = '<%= @ssl_key_file %>'
<% end -%>
<% unless @ssl_ca_file.nil? -%>
ssl_ca_file = '<%= @ssl_ca_file %>'
<% end -%>