• 云原生 PostgreSQL 集群 - PGO:5分钟快速上手


    前提条件

    请确保您的主机上安装了以下实用程序:

    • kubectl
    • git

    安装

    第 1 步:下载示例

    首先,转到 GitHub 并 fork Postgres Operator 示例存储库

    一旦你分叉了这个 repo,你可以使用类似下面的命令将它下载到你的工作环境中:

    YOUR_GITHUB_UN="<your GitHub username>"
    git clone --depth 1 "git@github.com:${YOUR_GITHUB_UN}/postgres-operator-examples.git"
    cd postgres-operator-examples
    

    第 2 步:安装 PGO,即 Postgres Operator

    您可以使用以下命令安装 PGO,即来自 Crunchy DataPostgres Operator

    kubectl apply -k kustomize/install
    

    这将创建一个名为 postgres-operator 的命名空间,并创建部署 PGO 所需的所有对象。

    要检查安装状态,可以运行以下命令:

    kubectl -n postgres-operator get pods \
      --selector=postgres-operator.crunchydata.com/control-plane=postgres-operator \
      --field-selector=status.phase=Running
    

    如果 PGO Pod 运行良好,您应该会看到类似于以下内容的输出:

    NAME                                READY   STATUS    RESTARTS   AGE
    postgres-operator-9dd545d64-t4h8d   1/1     Running   0          3s
    

    创建 Postgres 集群

    让我们创建一个简单的 Postgres 集群。您可以通过执行以下命令来执行此操作:

    kubectl apply -k kustomize/postgres
    

    注意:

    • 注意,你的集群已经有一个默认的 Storage Class

    这将在 postgres-operator 命名空间中创建一个名为 hippoPostgres 集群。 您可以使用以下命令跟踪集群的进度:

    kubectl -n postgres-operator describe postgresclusters.postgres-operator.crunchydata.com hippo
    

    连接到 Postgres 集群

    作为创建 Postgres 集群的一部分,Postgres Operator 创建一个 PostgreSQL 用户帐户。 此帐户的凭据存储在名为 <clusterName>-pguser-<userName>Secret 中。

    Secret 中的属性提供了让您登录 PostgreSQL 集群的信息。这些包括:

    • user: 用户帐户的名称。
    • password: 用户帐户的密码。
    • dbname: 默认情况下用户有权访问的数据库的名称。
    • host: 数据库主机的名称。这引用了主 Postgres 实例的 Service
    • port: 数据库正在侦听的端口。
    • uri: 一个 PostgreSQL 连接 URI,它提供了登录 Postgres 数据库的所有信息。
    • jdbc-uri: 一个 PostgreSQL JDBC 连接 URI,它提供了通过 JDBC driver 登录到 Postgres 数据库的所有信息。

    如果您使用 PgBouncer 连接池部署 Postgres 集群,则用户 Secret 中会填充其他值,包括:

    • pgbouncer-host: PgBouncer 连接池的主机名。这引用了 PgBouncer 连接池的 Service
    • pgbouncer-port: PgBouncer 连接池正在侦听的端口。
    • pgbouncer-uri: 一个 PostgreSQL 连接 URI,它提供了通过 PgBouncer 连接池登录到 Postgres 数据库的所有信息。
    • pgbouncer-jdbc-uri: 一个 PostgreSQL JDBC 连接 URI,它提供了使用 JDBC driver 通过 PgBouncer 连接池登录到 Postgres 数据库的所有信息。

    请注意,所有连接都使用 TLSPGO 为您的 Postgres 集群设置 PKI。 您也可以选择自带 PKI / certificate authority;这将在文档后面介绍。

    PgBouncer

    通过终端中的 psql 连接

    直接连接

    如果您与 PostgreSQL 集群位于同一网络上,则可以使用以下命令直接连接到它:

    psql $(kubectl -n postgres-operator get secrets hippo-pguser-hippo -o go-template='{{.data.uri | base64decode}}')
    

    使用端口转发连接

    在新终端中,创建一个端口转发:

    PG_CLUSTER_PRIMARY_POD=$(kubectl get pod -n postgres-operator -o name \
      -l postgres-operator.crunchydata.com/cluster=hippo,postgres-operator.crunchydata.com/role=master)
    kubectl -n postgres-operator port-forward "${PG_CLUSTER_PRIMARY_POD}" 5432:5432
    

    建立与 PostgreSQL 集群的连接。

    PG_CLUSTER_USER_SECRET_NAME=hippo-pguser-hippo
    
    PGPASSWORD=$(kubectl get secrets -n postgres-operator "${PG_CLUSTER_USER_SECRET_NAME}" -o go-template='{{.data.password | base64decode}}') \
    PGUSER=$(kubectl get secrets -n postgres-operator "${PG_CLUSTER_USER_SECRET_NAME}" -o go-template='{{.data.user | base64decode}}') \
    PGDATABASE=$(kubectl get secrets -n postgres-operator "${PG_CLUSTER_USER_SECRET_NAME}" -o go-template='{{.data.dbname | base64decode}}') \
    psql -h localhost
    

    实战 Keycloak 连接 PostgreSQL 集群

    用户 Secret 中提供的信息将允许您将应用程序直接连接到您的 PostgreSQL 数据库。

    例如,让我们连接 KeycloakKeycloak 是一种流行的开源身份管理工具,由 PostgreSQL 数据库支持。使用我们创建的 hippo 集群,我们可以部署以下清单文件:

    Keycloak

    cat <<EOF >> keycloak.yaml
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: keycloak
      namespace: postgres-operator
      labels:
        app.kubernetes.io/name: keycloak
    spec:
      selector:
        matchLabels:
          app.kubernetes.io/name: keycloak
      template:
        metadata:
          labels:
            app.kubernetes.io/name: keycloak
        spec:
          containers:
          - image: quay.io/keycloak/keycloak:latest
            name: keycloak
            args: ["start-dev"]
            env:
            - name: DB_VENDOR
              value: "postgres"
            - name: DB_ADDR
              valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: host } }
            - name: DB_PORT
              valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: port } }
            - name: DB_DATABASE
              valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: dbname } }
            - name: DB_USER
              valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: user } }
            - name: DB_PASSWORD
              valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: password } }
            - name: KEYCLOAK_ADMIN
              value: "admin"
            - name: KEYCLOAK_ADMIN_PASSWORD
              value: "admin"
            - name: PROXY_ADDRESS_FORWARDING
              value: "true"
            ports:
            - name: http
              containerPort: 8080
            - name: https
              containerPort: 8443
          restartPolicy: Always
    
    EOF
    
    kubectl apply -f keycloak.yaml
    
    
    kubectl -n postgres-operator port-forward ${KEYCLOAK_POD} 8086:8080 --address='0.0.0.0'
    # Forwarding from 0.0.0.0:8086 -> 8080
    

    转到 http://127.0.0.1:8086

    kustomize/keycloak 文件夹中有一个关于如何使用 Postgres Operator 部署 Keycloak 的完整示例。

    注意:

    • quay.io/keycloak/keycloak:latest科学拉取镜像
    • keycloak.yaml 进行了上述修改

    恭喜,您的 Postgres 集群已启动并运行,还连接了一个应用程序! 👏 👏 👏

    您可以通过文档kubectl explain 了解有关 postgresclusters 自定义资源定义的更多信息,即:

    kubectl explain postgresclusters
    

    postgresclusters 自定义资源定义

  • 相关阅读:
    Helm chart仓库操作
    通过JS脚本检查浏览器对视频编码的支持情况
    static学习
    微服务项目:尚融宝(38)(核心业务流程:申请借款额度(2))
    【Prometheus】将windows_exporter注册为系统服务
    高手PM控制项目范围的流程和方法!
    逆向-beginners之字符串数组
    没有杯子的世界:OOP设计思想的应用实践
    k8s学习-Secret(创建、使用、更新、删除等)
    [源码系列:手写spring] IOC第十四节:容器事件和事件监听器
  • 原文地址:https://www.cnblogs.com/hacker-linner/p/15931518.html