2a96d9e948
PuppetDB requires a separate read-only database user for its read pool. Without it, it refuses to use the write user for read queries and all /pdb/query/v4 calls fail with a 500. - Add puppetdb_read role via CNPG managed.roles with password sourced from a new postgres-read-credentials Vault secret - Grant CONNECT, USAGE, SELECT and default privileges to puppetdb_read via postInitApplicationSQL (must also be run manually on existing cluster) - Add puppet-postgres-pooler-ro Pooler (type: ro) routing to replicas - Add puppetdb-read-database-conf ConfigMap with read-database.conf mounted into /etc/puppetlabs/puppetdb/conf.d/ in the PuppetDB deployment - Wire OPENVOXDB_READ_POSTGRES_* env vars from the new secret 💘 Generated with Crush Assisted-by: Claude Sonnet 4.6 via Crush <crush@charm.land> Reviewed-on: #69
24 lines
774 B
YAML
24 lines
774 B
YAML
---
|
|
apiVersion: v1
|
|
kind: ConfigMap
|
|
metadata:
|
|
labels:
|
|
app.kubernetes.io/component: puppetdb
|
|
app.kubernetes.io/instance: puppetserver
|
|
app.kubernetes.io/name: puppetserver
|
|
app.kubernetes.io/version: 8.8.0
|
|
name: puppetdb-config
|
|
namespace: puppet
|
|
data:
|
|
USE_OPENVOXSERVER: "true"
|
|
OPENVOXSERVER_HOSTNAME: "puppetca"
|
|
OPENVOXSERVER_PORT: "8140"
|
|
DNS_ALT_NAMES: "openvoxdb,puppetdb,puppetdb.k8s.syd1.au.unkin.net,puppetdb.puppet.svc.cluster.local"
|
|
OPENVOXDB_POSTGRES_HOSTNAME: "puppet-postgres-pooler"
|
|
OPENVOXDB_POSTGRES_DATABASE: "puppetdb"
|
|
OPENVOXDB_POSTGRES_PORT: "5432"
|
|
OPENVOXDB_READ_POSTGRES_HOSTNAME: "puppet-postgres-pooler-ro"
|
|
OPENVOXDB_READ_POSTGRES_DATABASE: "puppetdb"
|
|
OPENVOXDB_READ_POSTGRES_PORT: "5432"
|
|
PUPPETDB_JAVA_ARGS: ""
|