当前位置: 首页 > news >正文

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客户端连接 

http://www.dtcms.com/a/285307.html

相关文章:

  • Java面向对象核心揭秘:从构造到多态的实战指南
  • Java List 集合详解:从基础到实战,掌握 Java 列表操作全貌
  • 代码随想录算法训练营65期第22天
  • 五分钟学会大数定律【笔记】
  • day055-Dockerfile与常用指令
  • 上网行为管理之内容审计实验
  • 数据结构-2(链表)
  • 基于强化学习的人机协同教学角色分配优化与课堂参与度建模研究
  • C++拷贝构造
  • 鸿蒙UI自动化测试框架Hypium的使用指南
  • Netty入门学习
  • java-字符串和集合
  • (自用)补充说明2
  • 《python语言程序设计》2018版第8章8题编写函数实现二进制转十进制(字符串变整数)!!整数没法进行下标
  • 基于MATLAB的极限学习机ELM的数据回归预测方法应用
  • 用python可视化分析二次元经济的爆发
  • python网络爬虫(第一步:网络爬虫库、robots.txt规则(防止犯法)、查看获取网页源代码)
  • 2025年6月GESP(C++一级):假期阅读
  • Baumer工业相机堡盟工业相机如何通过YoloV8模型实现人物识别(C#)
  • 2025年6月GESP(C++一级):值日
  • VOTE:基于轨迹集成投票的视觉-语言-动作模型优化
  • 掌握工程化固件烧录,开启你的技术进阶之路-STM32系列
  • C#将类属性保存到Ini文件方法(利用拓展方法,反射方式获取到分组名和属性名称属性值)
  • vue-cli 模式下安装 uni-ui
  • 2-Vue3应用介绍
  • STM32f103ZET6之ESP8266模块
  • AlpineLinux的内核优化
  • AI搜索+GEO时代的营销策略更迭学习笔记
  • 计算机的网络体系及协议模型介绍
  • 【Java】文件编辑器