k8s:利用kubectl部署postgis:17-3.5

1.离线环境

CPU:Hygon C86 7285 32-core Processor

操作系统:麒麟操作系统

containerd:1.7.27

Kubernetes:1.26.12

KubeSphere:4.1.2

kubekey:3.1.10

Harbor:2.13.1

Postgis:17-3.5

2.创建并执行postgresql-headless.yaml

2.1创建

apiVersion: v1

kind: Service

metadata:

name: postgresql-headless

labels:

app: postgresql

spec:

ports:

  • name: client

port: 5432

targetPort: 5432

clusterIP: None

selector:

app: postgresql

2.1执行

kubectl apply -f postgresql-headless.yaml

3创建数据库登录用户及密码的Secret

3.1创建

apiVersion: v1

kind: Secret

metadata:

name: postgresql-secret

type: Opaque

data:

使用 base64 编码的用户名和密码

POSTGRES_USER: c2lub3Bz

POSTGRES_PASSWORD: U2lub3BzMTIzNA==

3.2执行

kubectl apply -f postgresql-secret.yaml

4创建postgresql-sts.yaml

4.1创建

apiVersion: apps/v1

kind: StatefulSet

metadata:

name: postgresql

spec:

serviceName: postgresql-headless

replicas: 1

selector:

matchLabels:

app: postgresql

template:

metadata:

labels:

app: postgresql

spec:

containers:

  • name: postgresql

image: 172.23.123.117:8443/library/postgis/postgis:17-3.5

ports:

  • containerPort: 5432

env:

  • name: POSTGRES_DB

value: "CZ_DB"

  • name: POSTGRES_USER

valueFrom:

secretKeyRef:

name: postgresql-secret

key: POSTGRES_USER

  • name: POSTGRES_PASSWORD

valueFrom:

secretKeyRef:

name: postgresql-secret

key: POSTGRES_PASSWORD

  • name: TZ

value: "Asia/Shanghai"

volumeMounts:

  • name: postgresql-data

mountPath: /var/lib/postgresql/data

volumeClaimTemplates:

  • metadata:

name: postgresql-data

spec:

accessModes: [ "ReadWriteOnce" ]

storageClassName: local-postgresql

resources:

requests:

storage: 10Gi

4.2执行

kubectl apply -f postgresql-sts.yaml

5创建postgresql-service.yaml

5.1创建

apiVersion: v1

kind: Service

metadata:

name: postgresql-service

spec:

type: NodePort

ports:

  • port: 5432

targetPort: 5432

nodePort: 30084

selector:

app: postgresql

5.2执行

kubectl apply -f postgresql-service.yaml

6客户端连接

相关推荐
小成202303202651 小时前
Linux高级02
linux·开发语言
mounter6251 小时前
【硬核前沿】CXL 深度解析:重塑数据中心架构的“高速公路”,Linux 内核如何应对挑战?-- CXL 协议详解与 LSF/MM 最新动态
linux·服务器·网络·架构·kernel
++==1 小时前
Linux 进程间通信与线程同步技术详解:IPC 机制、线程 API、同步工具与经典同步问题
linux
架构师老Y1 小时前
008、容器化部署:Docker与Python应用打包
python·容器·架构
特长腿特长1 小时前
centos、ubantu系列机的用户和用户组的结构是什么?具体怎么配置?用户组权限怎么使用?这篇文章持续更新,帮助你复习linux的基础知识
linux·运维·centos
zzzyyy5381 小时前
Linux环境变量
linux·运维·服务器
pluvium272 小时前
记对 xonsh shell 的使用, 脚本编写, 迁移及调优
linux·python·shell·xonsh
无级程序员2 小时前
centos7 安装 llvm-toolset-7-clang出错的问题解决
linux·centos
CHHC18803 小时前
NetCore树莓派桌面应用程序
linux·运维·服务器
云栖梦泽4 小时前
Linux内核与驱动:9.Linux 驱动 API 封装
linux·c++