您的位置:IT爆料网 > 互联网

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

发布时间:2022-12-04 10:35:55  来源:互联网     背景:

 

前提条件

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

kubectlgit安装第 1 步:下载示例

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

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

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

YOUR_GITHUB_UN=""
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

注意:

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

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

kubectl -n postgres-operator describe postgresclusters.postgres-operator.crunchydata.com hippo连接到 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 -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 数据库。

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

Keycloak

https://www.keycloak.org/cat <> 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 集群已启动并运行,还连接了一个应用程序!


本文标题:云原生 PostgreSQL 集群 - PGO:五分钟快速上手 - 互联网
本文地址:www.itbaoliao.com/hlw/9472.html

返回网站首页

本文评论
坐标上海!国内首个5G通话接通
据国内媒体报道,全球首个行政区域5G网络在今天在上海建成并开始试用。今天上午,“全球双千兆第一区”开通仪式在上海市虹口区举行。上海市副市长吴清拨通了首个5G手机通话,标志着上海成为全国首个中国移动5G试用城市。...
日期:11-11
天语回应A930手机抽查结果不合格问题
【TechWeb消息】近日,上海市质量技术监督局4月28日公布了上海市手机产品质量监督抽查结果,在抽查21批次不合格手机中,包括“天语”等在内的手机厂商质量问题突出,具体为天语的一批2008年4月份生产、批号为354411012...
日期:11-21
侧滑全键盘智能机 诺基亚C6行货仅1999
文/白色鱼 【湖北行情】诺基亚C6是诺基亚旗下的S60 V5触控智能机型,该机是定位在中端的多功能智能手机,配备的QWERTY全键盘侧滑机身让该机吸引了不少的眼球,另外,该...
日期:11-20
31省份昨日新增本土“1947+2384” 本土确诊1947例 无症状2384例
3月21日讯,据国家卫健委,3月20日0—24时,31个省(自治区、直辖市)和新疆生产建设兵团报告新增确诊病例2027例,其中境外输入病例80例,本土病例1947例;无新增死亡病例,新增疑似病例6例;新增无症状感染者2492例,...
日期:10-09
恒大足球上市 “亚洲足球第一股”横空出世
随着恒大分拆上市首单的尘埃落定,“亚洲足球第一股”横空出世。7月2日,恒大地产(HK.3333)发布公告,其控股的广州恒大淘宝足球俱乐部股份有限公司已向全国中小企业股份转让系统(简称“新三板”...
日期:11-14
比特币再次涨破58000美元
比特币涨破58000美元/枚,为2月22日以来首次。...
日期:11-14
OPPO Find X今日10点开售:曲面全景屏 售价4999元
6月底,OPPO正式发布了Find X未来旗舰手机,OPPO Find X采用了双轨潜望结构、全隐藏的3D摄像头,另外就是屏占比达到93.8%的曲面全景屏。7月13日上午10点,OPPO Find X标准版将正式开卖,售价4999元。...
日期:11-26
乐酷天上线推拼音域名lekutian.com
新浪科技讯 10月19日上午消息,由百度和日本乐天合资成立的大型网上购物商城乐酷天今日正式上线。该网站同时推出其拼音域名lekutian.com,目前商城内的产品涵盖服装、饰品、家居、家电、数...
日期:11-06
中秋祝福免费送 KC网络电话双重“给利”
中秋祝福免费送 KC网络电话双重“给利”对于许多年轻人而言,在中秋节热闹、团圆和喜庆的背后,花钱过猛和透支消费也是我们不得不面对的一种无奈,中秋节除了需要给父母和长辈买些月饼、鲜花、 礼品外,光是自己已经列出的需要给亲友打电话祝福中秋的...
日期:11-18
网友爆料P2P平台美冠信投致投资人信:你们的钱收不回来
【TechWeb报道】2月26日消息,今日晚间@财联社App曝出一张P2P平台美冠信投致投资人信的截图,据截图显示,美冠信投创始人周琦向投资人表示创业失败,投资人的钱肯定拿不回来了,自己会去一个大家都找不到的地方休息,周琦还向投资人提供了泰...
日期:09-30
《魔兽》电影全球总票房3.77亿美元 9成票房来自海外市场
【TechWeb报道】6月22日消息,《魔兽》电影在国内经过两周时间的上映,全球票房取得了3.77亿美元的票房收入,这也让经典游戏IP再次体现了本应有的价值。而《魔兽》这部影片更成为了目前电影史上票房最高的游戏改编电影。...
日期:10-30
ios5开放下载 苹果ios5升级详细教程
自动升级与手动升级在做好万全的准备工作之后,就可以开始进行固件升级了。具体的升级方法分为自动升级和手动升级两种,下面就让小编为大家分别介绍一下两种不同升级方法的具体操作步骤。一、自动升级自动升级的操作步骤非常简单,用户只需要将设备与电...
日期:11-11
我的世界1.8.1懒人包下载 基础整合包下载
我的世界1.8.1懒人包下载带给玩家,希望小编的攻略对玩家们有帮助,看看我的世界1.8.1懒人包下载。...
日期:11-10
数据分析速成班?包就业?扒一扒数分培训行业黑幕!
写这篇文章的原因是,最近突然很多粉丝来找我和小橘子问高价培训班的事情,还有粉丝列出好几个培训班的条件,让我们帮忙给选择建议(这种建议我们确实给不了)。我寻思短时间怎么突然这么多人问同类问题,翻了翻手机才发现培训班的广告越来越猖獗了。在看了...
日期:11-23
进可攻退可守 ABAB塔防小游戏Top 5盘点
进可攻退可守,没有点策略还真赢不了,这便是塔防游戏的魅力所在。塔防游戏即指一类通过在地图上建造炮塔或类似建筑物,以阻止游戏中敌人进攻的策略型游戏。深受大家喜爱的《植物大战僵尸》、《保卫萝卜》就是这种类型。这种游戏多见于flash游戏,而手游...
日期:11-14
摩托DROID Bionic/HTC Vigor即将发布
文/马千里上周,国外媒体称摩托罗拉CEO Sanjay Jha博士表示摩托罗拉DROID Bionic会在9月份发布上市,昨日,在泄露的一张来自Verizon的新品清单中,我们看到了Bionic的名字,令...
日期:11-23
我乐网CEO :周娟访谈 互联网巾帼不让须眉
我乐网(www.56.com)CEO周娟  简单?不简单。  周娟说,她的经历很简单:  老家在江西临川,王安石的故乡,不过自小理科很棒;  高中时代开始上寄宿的高中,长年在外,个性比较独立;  后来考上了中国科技大学,学计算机...
日期:11-29
为爱点赞 百度公益一小时援助先心病患儿
在中国,每8分钟,就有一名先天性心脏病(简称“先心病”)儿童诞生。在每年新增约13.4万的先心病患儿中,不少孤贫患儿因贫困无法及时得到救治而夭折。今年,已经进入第三个年头的互联网公益行动——百...
日期:10-31
朱广权段子版春节祝福:朗朗上口,寓意很好,立意新颖,很高级
【TechWeb】2月12日消息,大年初一,央视节目主持人朱广权在节目中为观众送上牛年第一条春节祝福 :新的一年,三餐四季、温柔有趣、牛年日日奔红火,天天大吉大利!天是2021初一,段子手朱广权又来啦。今年他说了一段段子版的拜年文案。文案朗...
日期:12-02
朱广权段子版春节祝福:朗朗上口,寓意很好,立意新颖,很高级
【TechWeb】2月12日消息,大年初一,央视节目主持人朱广权在节目中为观众送上牛年第一条春节祝福 :新的一年,三餐四季、温柔有趣、牛年日日奔红火,天天大吉大利!天是2021初一,段子手朱广权又来啦。今年他说了一段段子版的拜年文案。文案朗...
日期:12-01