云原生 PostgreSQL 集群 – PGO:五分钟快速上手

云原生 PostgreSQL 集群 – PGO:五分钟快速上手

作者:为少 2022-02-23 20:38:32

云计算

云原生 本篇带给大家五分钟快速安装并创建PostgreSQL 集群的相关内容,希望能够帮助到你!

前提条件

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

  • kubectl
  • git

安装

第 1 步:下载示例

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

https://github.com/CrunchyData/postgres-operator-examples/fork

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

YOUR_GITHUB_UN="<your GitHub username>"
gitclone--depth1"[email protected]:${YOUR_GITHUB_UN}/postgres-operator-examples.git"
cdpostgres-operator-examples

第 2 步:安装 PGO,即 Postgres Operator

您可以使用以下命令安装 PGO,即来自 Crunchy Data 的 Postgres Operator:

kubectlapply-kkustomize/install

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

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

kubectl-npostgres-operatorgetpods\
--selector=postgres-operator.crunchydata.com/control-plane=postgres-operator\
--field-selector=status.phase=Running

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

NAMEREADYSTATUSRESTARTSAGE
postgres-operator-9dd545d64-t4h8d1/1Running03s

创建 Postgres 集群

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

kubectlapply-kkustomize/postgres

注意:

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

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

kubectl-npostgres-operatordescribepostgresclusters.postgres-operator.crunchydata.comhippo

连接到 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;这将在文档后面介绍。

PgBouncer

  • https://www.pgbouncer.org/

通过终端中的 psql 连接

直接连接

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

psql$(kubectl-npostgres-operatorgetsecretshippo-pguser-hippo-ogo-template='{{.data.uri | base64decode}}')

使用端口转发连接

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

PG_CLUSTER_PRIMARY_POD=$(kubectlgetpod-npostgres-operator-oname\
-lpostgres-operator.crunchydata.com/cluster=hippo,postgres-operator.crunchydata.com/role=master)
kubectl-npostgres-operatorport-forward"${PG_CLUSTER_PRIMARY_POD}"5432:5432

建立与 PostgreSQL 集群的连接。

PG_CLUSTER_USER_SECRET_NAME=hippo-pguser-hippo

PGPASSWORD=$(kubectlgetsecrets-npostgres-operator"${PG_CLUSTER_USER_SECRET_NAME}"-ogo-template='{{.data.password | base64decode}}') \
PGUSER=$(kubectlgetsecrets-npostgres-operator"${PG_CLUSTER_USER_SECRET_NAME}"-ogo-template='{{.data.user | base64decode}}') \
PGDATABASE=$(kubectlgetsecrets-npostgres-operator"${PG_CLUSTER_USER_SECRET_NAME}"-ogo-template='{{.data.dbname | base64decode}}') \
psql-hlocalhost

实战 Keycloak 连接 PostgreSQL 集群

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

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

Keycloak

  • https://www.keycloak.org/
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
kubectlapply-fkeycloak.yaml
kubectl-npostgres-operatorport-forward${KEYCLOAK_POD} 8086:8080--address='0.0.0.0'
#Forwardingfrom0.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 自定义资源定义的更多信息,即:

kubectlexplainpostgresclusters

postgresclusters 自定义资源定义

  • https://access.crunchydata.com/documentation/postgres-operator/5.0.4/references/crd/

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/272228.html<

(0)
运维的头像运维
上一篇2025-05-08 15:46
下一篇 2025-05-08 15:47

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注