postgres job from postgres/40
The Postgres server provides a single instance Postgres database that can be used with the Cloud Controller or the UAA. It does not provide highly-available configuration.
              Github source:
              f7d21e3 or
              master branch
            
Properties¶
databases¶
  
  
    
additional_config¶A map of additional key/value pairs to include as extra configuration properties
- Example
|+ shared_buffers: 4GB
collect_statement_statistics¶Enable the
pg_stat_statementsextension and collect statement execution statistics
- Default
false
databases¶A list of databases and associated properties to create
- Example
|+ - name: sandbox citext: true - name: sandbox2 citext: false
enable_trace¶Print additional traces in control scripts
- Default
false
hooks¶
post_start¶Script to run after PostgreSQL has started
- Default
""
- Example
|+ #!/bin/bash echo "The following databases are available:" ${PACKAGE_DIR}/bin/psql -p ${PORT} -U vcap postgres -c "\l"
post_stop¶Script to run after PostgreSQL has stopped
- Default
""
pre_start¶Script to run before starting PostgreSQL
- Default
""
- Example
|+ #!/bin/bash echo "Going to start Postgres" echo "PostgreSQL data directory is ${DATA_DIR}" echo "PostgreSQL port is ${PORT}" echo "Package directory is ${PACKAGE_DIR}"
pre_stop¶Script to run before stopping PostgreSQL
- Default
""
timeout¶Time limit in seconds for the hook script. By default it’s set to 0 that means no time limit
- Default
0
log_line_prefix¶The postgres
printfstyle string that is output at the beginning of each log line
- Default
'%m: '
max_connections¶Maximum number of database connections
- Default
500
monit_timeout¶Monit timout in seconds for the postgres job start. If not specified, no timeout statement will be added so that the global monit timeout applies.
- Default
90
port¶The database port
- Default
5432
roles¶A list of database roles and associated properties to create
- Example
|+ - name: pgadmin password: passwd permissions: - "CONNECTION LIMIT 33" - name: bud_spencer common_name: "Carlo Pedersoli"
skip_data_copy_in_minor¶If false, during a PostgreSQL minor upgrade a copy of the data directory is created.
- Default
false
tls¶
ca¶PEM-encoded certification authority for secure TLS communication
- Default
""
certificate¶PEM-encoded certificate for secure TLS communication
- Default
""
private_key¶PEM-encoded key for secure TLS communication
- Default
""
trust_local_connections¶Whether to trust or not local connections. Note that vcap is always trusted.
- Default
true
janitor¶
  
  
    
interval¶Interval in seconds between two invocations of the janitor script. By default it’s set to 1 day.
- Default
86400
script¶If specified, janitor would periodically run this script
- Default
""
- Example
|+ #!/bin/bash echo "Run VACUUM" ${PACKAGE_DIR}/bin/psql -p ${PORT} -U vcap sandbox -c "VACUUM ANALYZE"
timeout¶Time limit in seconds for the janitor script. By default it’s set to 0 that means no time limit
- Default
0
Templates¶
            Templates are rendered and placed onto corresponding
            instances during the deployment process. This job's templates
            will be placed into /var/vcap/jobs/postgres/ directory
            (learn more).
          
- bin/hooks/call-hooks.sh(from- hooks/call-hooks.sh.erb)
- bin/hooks/janitor.sh(from- hooks/janitor.sh.erb)
- bin/hooks/postgres-post-start.sh(from- hooks/postgres-post-start.sh.erb)
- bin/hooks/postgres-post-stop.sh(from- hooks/postgres-post-stop.sh.erb)
- bin/hooks/postgres-pre-start.sh(from- hooks/postgres-pre-start.sh.erb)
- bin/hooks/postgres-pre-stop.sh(from- hooks/postgres-pre-stop.sh.erb)
- bin/pg_janitor.sh(from- pg_janitor.sh.erb)
- bin/pg_janitor_ctl(from- pg_janitor_ctl.sh.erb)
- bin/pgconfig.sh(from- pgconfig.sh.erb)
- bin/postgres_ctl(from- postgres_ctl.sh.erb)
- bin/postgres_start.sh(from- postgres_start.sh.erb)
- bin/pre-start(from- pre-start.sh.erb)
- bin/utils.sh(from- utils.sh.erb)
- config/certificates/server.ca_cert(from- server.ca_cert.erb)
- config/certificates/server.private_key(from- server.private_key.erb)
- config/certificates/server.public_cert(from- server.public_cert.erb)
- config/pg_hba.conf(from- pg_hba.conf.erb)
- config/pg_ident.conf(from- pg_ident.conf.erb)
- config/postgresql.conf(from- postgresql.conf.erb)
- config/roles.sql(from- roles.sql.erb)
Packages¶
            Packages are compiled and placed onto corresponding
            instances during the deployment process. Packages will be
            placed into /var/vcap/packages/ directory.