当前位置: 首页 > 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.lryc.cn/news/592033.html

相关文章:

  • Kotlin序列
  • CloudFabric解决方案
  • 【怜渠客】简单实现手机云控Windows电脑锁屏
  • HTTP 性能优化:五条建议
  • 线程安全集合——ConcurrentHashMap
  • 微店平台商品详情接口技术实现指南
  • 前端埋坑之js console.log字符换行后 html没换行问题处理
  • javascript 中数组对象操作方法
  • AE PDW2200电源射频手侧使用安装说明含电路图
  • 自学力扣:最长连续序列
  • CSS样式中的布局、字体、响应式布局
  • AI大模型打造金融智能信审助手04.七大金融监管相关政策
  • 【Oracle】centos7离线静默安装oracle11g(p13390677_112040)
  • 智象科技赋能金融、证券行业 IT 运维
  • PostgreSQL 16 Administration Cookbook 读书笔记:第7章 Database Administration
  • 【git仓库搭建笔记】
  • Oracle 19C 后台主要进程的功能解析
  • CertiK创始人顾荣辉出席上海Conflux大会,聚焦Web3全球化中的安全与合规路径
  • 赛思SLIC芯片、语音芯片原厂 赛思SLIC语音芯片ASX630:国产强“芯”赋能FTTR全光网络​
  • Docker Swarm 集群使用记录
  • 基于LiteNetLib的Server/Client Demo
  • 算法训练营day24 回溯算法③ 93.复原IP地址 、78.子集、 90.子集II
  • 零基础入门:用C++从零实现TCP Socket网络小工具
  • 人脸检测算法——SCRFD
  • Ubuntu系统下快速体验iperf3工具(网络性能测试)
  • 2G和3G网络关闭/退网状态(截止2025年7月)
  • Python技术题1
  • 【RK3576】【Android14】开发环境搭建
  • 基于现代R语言【Tidyverse、Tidymodel】的机器学习方法与案例分析
  • 用 React-Three-Fiber 实现雪花下落与堆积效果:从零开始的 3D 雪景模拟