当前位置:首页 > 科技  > 知识百科

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

来源: 责编: 时间:2023-08-07 16:29:56 138观看
导读 前提条件请确保您的主机上安装了以下实用程序:kubectlgit安装第 1 步:下载示例首先,转到 GitHub 并 fork Postgres Operator 示例存储库:https://github.com/CrunchyData/postg

 Auv28资讯网——每日最新资讯28at.com

前提条件Auv28资讯网——每日最新资讯28at.com

请确保您的主机上安装了以下实用程序:Auv28资讯网——每日最新资讯28at.com

kubectlgit安装第 1 步:下载示例Auv28资讯网——每日最新资讯28at.com

首先,转到 GitHub 并 fork Postgres Operator 示例存储库:Auv28资讯网——每日最新资讯28at.com

https://github.com/CrunchyData/postgres-operator-examples/forkAuv28资讯网——每日最新资讯28at.com

一旦你分叉了这个 repo,你可以使用类似下面的命令将它下载到你的工作环境中:Auv28资讯网——每日最新资讯28at.com

YOUR_GITHUB_UN=""Auv28资讯网——每日最新资讯28at.com
git clone --depth 1 "git@github.com:${YOUR_GITHUB_UN}/postgres-operator-examples.git"Auv28资讯网——每日最新资讯28at.com
cd postgres-operator-examplesAuv28资讯网——每日最新资讯28at.com

第 2 步:安装 PGO,即 Postgres OperatorAuv28资讯网——每日最新资讯28at.com

您可以使用以下命令安装 PGO,即来自 Crunchy Data 的 Postgres Operator:Auv28资讯网——每日最新资讯28at.com

kubectl apply -k kustomize/installAuv28资讯网——每日最新资讯28at.com

这将创建一个名为 postgres-operator 的命名空间,并创建部署 PGO 所需的所有对象。Auv28资讯网——每日最新资讯28at.com

要检查安装状态,可以运行以下命令:Auv28资讯网——每日最新资讯28at.com

kubectl -n postgres-operator get pods Auv28资讯网——每日最新资讯28at.com
--selector=postgres-operator.crunchydata.com/control-plane=postgres-operator Auv28资讯网——每日最新资讯28at.com
--field-selector=status.phase=RunningAuv28资讯网——每日最新资讯28at.com

如果 PGO Pod 运行良好,您应该会看到类似于以下内容的输出:Auv28资讯网——每日最新资讯28at.com

NAME READY STATUS RESTARTS AGEAuv28资讯网——每日最新资讯28at.com
postgres-operator-9dd545d64-t4h8d 1/1 Running 0 3s创建 Postgres 集群Auv28资讯网——每日最新资讯28at.com

让我们创建一个简单的 Postgres 集群。您可以通过执行以下命令来执行此操作:Auv28资讯网——每日最新资讯28at.com

kubectl apply -k kustomize/postgresAuv28资讯网——每日最新资讯28at.com

注意:Auv28资讯网——每日最新资讯28at.com

注意,你的集群已经有一个默认的 Storage ClassAuv28资讯网——每日最新资讯28at.com

这将在 postgres-operator 命名空间中创建一个名为 hippo 的 Postgres 集群。您可以使用以下命令跟踪集群的进度:Auv28资讯网——每日最新资讯28at.com

kubectl -n postgres-operator describe postgresclusters.postgres-operator.crunchydata.com hippo连接到 Postgres 集群Auv28资讯网——每日最新资讯28at.com

作为创建 Postgres 集群的一部分,Postgres Operator 创建一个 PostgreSQL 用户帐户。此帐户的凭据存储在名为 -pguser- 的 Secret 中。Auv28资讯网——每日最新资讯28at.com

此 Secret 中的属性提供了让您登录 PostgreSQL 集群的信息。这些包括:Auv28资讯网——每日最新资讯28at.com

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

如果您使用 PgBouncer 连接池部署 Postgres 集群,则用户 Secret 中会填充其他值,包括:Auv28资讯网——每日最新资讯28at.com

pgbouncer-host: PgBouncer 连接池的主机名。这引用了 PgBouncer 连接池的 Service。pgbouncer-port: PgBouncer 连接池正在侦听的端口。pgbouncer-uri: 一个 PostgreSQL 连接 URI,它提供了通过 PgBouncer 连接池登录到 Postgres 数据库的所有信息。pgbouncer-jdbc-uri: 一个 PostgreSQL JDBC 连接 URI,它提供了使用 JDBC driver 通过 PgBouncer 连接池登录到 Postgres 数据库的所有信息。Auv28资讯网——每日最新资讯28at.com

请注意,所有连接都使用 TLS。PGO 为您的 Postgres 集群设置 PKI。您也可以选择自带 PKI / certificate authority;这将在文档后面介绍。Auv28资讯网——每日最新资讯28at.com

PgBouncerAuv28资讯网——每日最新资讯28at.com

https://www.pgbouncer.org/Auv28资讯网——每日最新资讯28at.com

通过终端中的 psql 连接Auv28资讯网——每日最新资讯28at.com

直接连接Auv28资讯网——每日最新资讯28at.com

如果您与 PostgreSQL 集群位于同一网络上,则可以使用以下命令直接连接到它:Auv28资讯网——每日最新资讯28at.com

psql $(kubectl -n postgres-operator get secrets hippo-pguser-hippo -o go-template='{{.data.uri | base64decode}}')Auv28资讯网——每日最新资讯28at.com

使用端口转发连接Auv28资讯网——每日最新资讯28at.com

在新终端中,创建一个端口转发:Auv28资讯网——每日最新资讯28at.com

PG_CLUSTER_PRIMARY_POD=$(kubectl get pod -n postgres-operator -o name Auv28资讯网——每日最新资讯28at.com
-l postgres-operator.crunchydata.com/cluster=hippo,postgres-operator.crunchydata.com/role=master)Auv28资讯网——每日最新资讯28at.com
kubectl -n postgres-operator port-forward "${PG_CLUSTER_PRIMARY_POD}" 5432:5432Auv28资讯网——每日最新资讯28at.com

建立与 PostgreSQL 集群的连接。Auv28资讯网——每日最新资讯28at.com

PG_CLUSTER_USER_SECRET_NAME=hippo-pguser-hippoAuv28资讯网——每日最新资讯28at.com
Auv28资讯网——每日最新资讯28at.com
PGPASSWORD=$(kubectl get secrets -n postgres-operator "${PG_CLUSTER_USER_SECRET_NAME}" -o go-template='{{.data.password | base64decode}}') Auv28资讯网——每日最新资讯28at.com
PGUSER=$(kubectl get secrets -n postgres-operator "${PG_CLUSTER_USER_SECRET_NAME}" -o go-template='{{.data.user | base64decode}}') Auv28资讯网——每日最新资讯28at.com
PGDATABASE=$(kubectl get secrets -n postgres-operator "${PG_CLUSTER_USER_SECRET_NAME}" -o go-template='{{.data.dbname | base64decode}}') Auv28资讯网——每日最新资讯28at.com
psql -h localhost实战 Keycloak 连接 PostgreSQL 集群Auv28资讯网——每日最新资讯28at.com

用户 Secret 中提供的信息将允许您将应用程序直接连接到您的 PostgreSQL 数据库。Auv28资讯网——每日最新资讯28at.com

例如,让我们连接 Keycloak。Keycloak 是一种流行的开源身份管理工具,由 PostgreSQL 数据库支持。使用我们创建的 hippo 集群,我们可以部署以下清单文件:Auv28资讯网——每日最新资讯28at.com

KeycloakAuv28资讯网——每日最新资讯28at.com

https://www.keycloak.org/cat <> keycloak.yamlAuv28资讯网——每日最新资讯28at.com
apiVersion: apps/v1Auv28资讯网——每日最新资讯28at.com
kind: DeploymentAuv28资讯网——每日最新资讯28at.com
metadata:Auv28资讯网——每日最新资讯28at.com
name: keycloakAuv28资讯网——每日最新资讯28at.com
namespace: postgres-operatorAuv28资讯网——每日最新资讯28at.com
labels:Auv28资讯网——每日最新资讯28at.com
app.kubernetes.io/name: keycloakAuv28资讯网——每日最新资讯28at.com
spec:Auv28资讯网——每日最新资讯28at.com
selector:Auv28资讯网——每日最新资讯28at.com
matchLabels:Auv28资讯网——每日最新资讯28at.com
app.kubernetes.io/name: keycloakAuv28资讯网——每日最新资讯28at.com
template:Auv28资讯网——每日最新资讯28at.com
metadata:Auv28资讯网——每日最新资讯28at.com
labels:Auv28资讯网——每日最新资讯28at.com
app.kubernetes.io/name: keycloakAuv28资讯网——每日最新资讯28at.com
spec:Auv28资讯网——每日最新资讯28at.com
containers:Auv28资讯网——每日最新资讯28at.com
- image: quay.io/keycloak/keycloak:latestAuv28资讯网——每日最新资讯28at.com
name: keycloakAuv28资讯网——每日最新资讯28at.com
args: ["start-dev"]Auv28资讯网——每日最新资讯28at.com
env:Auv28资讯网——每日最新资讯28at.com
- name: DB_VENDORAuv28资讯网——每日最新资讯28at.com
value: "postgres"Auv28资讯网——每日最新资讯28at.com
- name: DB_ADDRAuv28资讯网——每日最新资讯28at.com
valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: host } }Auv28资讯网——每日最新资讯28at.com
- name: DB_PORTAuv28资讯网——每日最新资讯28at.com
valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: port } }Auv28资讯网——每日最新资讯28at.com
- name: DB_DATABASEAuv28资讯网——每日最新资讯28at.com
valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: dbname } }Auv28资讯网——每日最新资讯28at.com
- name: DB_USERAuv28资讯网——每日最新资讯28at.com
valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: user } }Auv28资讯网——每日最新资讯28at.com
- name: DB_PASSWORDAuv28资讯网——每日最新资讯28at.com
valueFrom: { secretKeyRef: { name: hippo-pguser-hippo, key: password } }Auv28资讯网——每日最新资讯28at.com
- name: KEYCLOAK_ADMINAuv28资讯网——每日最新资讯28at.com
value: "admin"Auv28资讯网——每日最新资讯28at.com
- name: KEYCLOAK_ADMIN_PASSWORDAuv28资讯网——每日最新资讯28at.com
value: "admin"Auv28资讯网——每日最新资讯28at.com
- name: PROXY_ADDRESS_FORWARDINGAuv28资讯网——每日最新资讯28at.com
value: "true"Auv28资讯网——每日最新资讯28at.com
ports:Auv28资讯网——每日最新资讯28at.com
- name: httpAuv28资讯网——每日最新资讯28at.com
containerPort: 8080Auv28资讯网——每日最新资讯28at.com
- name: httpsAuv28资讯网——每日最新资讯28at.com
containerPort: 8443Auv28资讯网——每日最新资讯28at.com
restartPolicy: AlwaysAuv28资讯网——每日最新资讯28at.com
EOFAuv28资讯网——每日最新资讯28at.com
kubectl apply -f keycloak.yamlAuv28资讯网——每日最新资讯28at.com
kubectl -n postgres-operator port-forward ${KEYCLOAK_POD} 8086:8080 --address='0.0.0.0'Auv28资讯网——每日最新资讯28at.com
# Forwarding from 0.0.0.0:8086 -> 8080Auv28资讯网——每日最新资讯28at.com

转到 http://127.0.0.1:8086Auv28资讯网——每日最新资讯28at.com

Auv28资讯网——每日最新资讯28at.com

在 kustomize/keycloak 文件夹中有一个关于如何使用 Postgres Operator 部署 Keycloak 的完整示例。Auv28资讯网——每日最新资讯28at.com

注意:Auv28资讯网——每日最新资讯28at.com

quay.io/keycloak/keycloak:latest,科学拉取镜像对 keycloak.yaml 进行了上述修改Auv28资讯网——每日最新资讯28at.com

恭喜,您的 Postgres 集群已启动并运行,还连接了一个应用程序!Auv28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-119-2177-0.html云原生 PostgreSQL 集群 - PGO:五分钟快速上手

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 混合云:如何让「混乱」回归秩序 译文

下一篇: 容器云架构 | 了解 Kubernetes 网络模型

标签:
  • 热门焦点
Top
Baidu
map