我正在尝试为我的云原生 PostgreSQL (CNPG) 部署配置
BarmanObjectStoreConfiguration
,但遇到 SSL 验证错误。这是我收到的错误消息:
“SSL 验证失败
imageName: ghcr.io/cloudnative-pg/postgresql:16.0
0.19.1
1.21.1
我已在 CNPG 集群 YAML 文件中设置了 barmanObjectStore 配置,如下所示:
apiVersion: postgresql.cnpg.io/v1
kind: Cluster
metadata:
name: cnpg-db
spec:
backup:
barmanObjectStore:
destinationPath: "s3://<BUCKET_NAME>"
endpointURL: https://<ENDPOINT>
endpointCA: # Seems doing nothing ?
name: cnpg-s3-cred-password
key: CA_CERT
s3Credentials:
accessKeyId:
name: cnpg-s3-cred-password
key: ACCESS_KEY_ID
secretAccessKey:
name: cnpg-s3-cred-password
key: ACCESS_SECRET_KEY
wal:
compression: gzip
encryption: AES256
data:
compression: gzip
encryption: AES256
retentionPolicy: 30d
env: # Trying to manually set CA_BUNDLE because params doesn't work
- name: REQUESTS_CA_BUNDLE # Supposed to be used with Azure Blob Storage
valueFrom:
secretKeyRef:
name: cnpg-s3-cred-password
key: CA_CERT
- name: AWS_CA_BUNDLE # Supposed to be used with AWS S3 (or compatible services)
valueFrom:
secretKeyRef:
name: cnpg-s3-cred-password
key: CA_CERT
已验证 cnpg-s3-cred-password 机密包含正确的 CA 证书、访问密钥 ID 和秘密访问密钥。我不确定我错过了什么或做错了什么。
有人可以帮助我解决此 SSL 验证错误并为我的 CNPG 部署成功配置 barmanBackupConfig 吗?任何帮助将不胜感激。谢谢!
我终于找到了问题的解决方案,
AWS_CA_BUNDLE
应该是CA证书文件的路径(根据Boto文档:https://boto3.amazonaws.com/v1/documentation/api/latest/guide /configuration.html#using-environment-variables) 和 endpointCA
参数只负责将 ca 放入 /run/certificates/backup-barman-ca.crt
。
所以解决方案是:
AWS_CA_BUNDLE=/run/certificates/backup-barman-ca.crt
这是更正后的 yaml:
apiVersion: postgresql.cnpg.io/v1
kind: Cluster
metadata:
name: cnpg-db
spec:
backup:
barmanObjectStore:
destinationPath: "s3://<BUCKET_NAME>"
endpointURL: https://<ENDPOINT>
endpointCA:
name: cnpg-s3-cred-password
key: CA_CERT
s3Credentials:
accessKeyId:
name: cnpg-s3-cred-password
key: ACCESS_KEY_ID
secretAccessKey:
name: cnpg-s3-cred-password
key: ACCESS_SECRET_KEY
wal:
compression: gzip
encryption: AES256
data:
compression: gzip
encryption: AES256
retentionPolicy: 30d
env:
- name: AWS_CA_BUNDLE
value: /run/certificates/backup-barman-ca.crt