加入收藏 | 设为首页 | 会员中心 | 我要投稿 核心网 (https://www.hxwgxz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 云计算 > 正文

云原生 PostgreSQL 集群 - PGO 五分钟迅速上手

发布时间:2022-03-02 12:23:02 所属栏目:云计算 来源:互联网
导读:前提条件 请确保您的主机上安装了以下实用程序: kubectl git 安装 第 1 步:下载示例 首先,转到 GitHub 并 fork Postgres Operator 示例存储库: 一旦你分叉了这个 repo,你可以使用类似下面的命令将它下载到你的工作环境中: 复制 YOUR_GITHUB_UN=your Gi
        前提条件
        请确保您的主机上安装了以下实用程序:
 
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 Data 的 Postgres 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
1.
注意:
 
注意,你的集群已经有一个默认的 Storage Class
这将在 postgres-operator 命名空间中创建一个名为 hippo 的 Postgres 集群。您可以使用以下命令跟踪集群的进度:
 
复制
kubectl -n postgres-operator describe postgresclusters.postgres-operator.crunchydata.com hippo
1.
连接到 Postgres 集群
作为创建 Postgres 集群的一部分,Postgres Operator 创建一个 PostgreSQL 用户帐户。此帐户的凭据存储在名为 -pguser- 的 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 数据库的所有信息。
请注意,所有连接都使用 TLS。PGO 为您的 Postgres 集群设置 PKI。您也可以选择自带 PKI / certificate authority;这将在文档后面介绍。
 
复制
psql $(kubectl -n postgres-operator get secrets hippo-pguser-hippo -o go-template='{{.data.uri | base64decode}}')
1.
使用端口转发连接
 
在新终端中,创建一个端口转发:
 
复制
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 数据库。

(编辑:核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读