使用 K8S/Helm 安装 TimescaleDB 时出错:MountVolume.SetUp 卷“证书”失败:未找到秘密“timescaledb-certificate”

Jul*_*oro 2 kubernetes kubernetes-helm timescaledb

我只是尝试在 Ubuntu 20.04 上的 minikube 中使用 Helm 安装 timescaleDB Single。

通过安装后:

helm install timescaledb timescaledb/timescaledb-single --namespace espace-client-v2

我收到消息:

?  ~ helm install timescaledb timescaledb/timescaledb-single  --namespace espace-client-v2
NAME: timescaledb
LAST DEPLOYED: Fri Aug  7 17:17:59 2020
NAMESPACE: espace-client-v2
STATUS: deployed
REVISION: 1
TEST SUITE: None
NOTES:
TimescaleDB can be accessed via port 5432 on the following DNS name from within your cluster:
timescaledb.espace-client-v2.svc.cluster.local

To get your password for superuser run:

    # superuser password
    PGPASSWORD_POSTGRES=$(kubectl get secret --namespace espace-client-v2 timescaledb-credentials -o jsonpath="{.data.PATRONI_SUPERUSER_PASSWORD}" | base64 --decode)

    # admin password
    PGPASSWORD_ADMIN=$(kubectl get secret --namespace espace-client-v2 timescaledb-credentials -o jsonpath="{.data.PATRONI_admin_PASSWORD}" | base64 --decode)

To connect to your database, chose one of these options:

1. Run a postgres pod and connect using the psql cli:
    # login as superuser
    kubectl run -i --tty --rm psql --image=postgres \
      --env "PGPASSWORD=$PGPASSWORD_POSTGRES" \
      --command -- psql -U postgres \
      -h timescaledb.espace-client-v2.svc.cluster.local postgres

    # login as admin
    kubectl run -i --tty --rm psql --image=postgres \
      --env "PGPASSWORD=$PGPASSWORD_ADMIN" \
      --command -- psql -U admin \
      -h timescaledb.espace-client-v2.svc.cluster.local postgres

2. Directly execute a psql session on the master node

   MASTERPOD="$(kubectl get pod -o name --namespace espace-client-v2 -l release=timescaledb,role=master)"
   kubectl exec -i --tty --namespace espace-client-v2 ${MASTERPOD} -- psql -U postgres

Run Code Online (Sandbox Code Playgroud)

它似乎安装得很好。

但是,在执行时:

     PGPASSWORD_POSTGRES=$(kubectl get secret --namespace espace-client-v2 timescaledb-credentials -o jsonpath="{.data.PATRONI_SUPERUSER_PASSWORD}" | base64 --decode)

Error from server (NotFound): secrets "timescaledb-credentials" not found


Run Code Online (Sandbox Code Playgroud)

在那之后,我意识到 pod 甚至还没有被创建,它给了我以下错误

MountVolume.SetUp failed for volume "certificate" : secret "timescaledb-certificate" not found
Run Code Online (Sandbox Code Playgroud)
Unable to attach or mount volumes: unmounted volumes=[certificate], unattached volumes=[storage-volume wal-volume patroni-config timescaledb-scripts certificate socket-directory timescaledb-token-svqqf]: timed out waiting for the condition
Run Code Online (Sandbox Code Playgroud)

我该怎么办 ?

Jul*_*oro 6

我能做到这一点。如果页面https://github.com/timescale/timescaledb-kubernetes没有提供关于安装过程的太多细节,你可以去这里:

https://github.com/timescale/timescaledb-kubernetes/tree/master/charts/timescaledb-single

我不得不使用 kustomize 来生成内容:

./generate_kustomization.sh my-release
Run Code Online (Sandbox Code Playgroud)

然后它生成几个文件:

credentials.conf  kustomization.yaml  pgbackrest.conf  timescaledbMap.yaml  tls.crt  tls.key
Run Code Online (Sandbox Code Playgroud)

然后我做了:

kubectl kustomize ./
Run Code Online (Sandbox Code Playgroud)

它生成了一个 k8s yml 文件,我用名称保存了该文件 timescaledbMap.yaml

最后,我做到了:

kubectl apply -f timescaledbMap.yaml
Run Code Online (Sandbox Code Playgroud)

然后它创建了所有必要的秘密,我可以安装图表

. 希望它可以帮助其他人。