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

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.xdnf.cn/news/15661.html

相关文章:

  • 【机器学习深度学习】什么是 GGUF?
  • 游戏盾在非游戏行业的应用:跨界守护网络安全的新利器
  • 计算机“十万个为什么”之跨域
  • [QOI] qoi_desc | qoi_encode | qoi_decode
  • WEB安全架构
  • 【Python】LEGB作用域 + re模块 + 正则表达式
  • 【PTA数据结构 | C语言版】左堆的合并操作
  • 加速度计和气压计、激光互补滤波融合算法
  • IDEA插件离线安装
  • 反序列化漏洞3-反序列化漏洞讲解演示
  • 5W8-3D牢游戏超级大集合[2012年6月] 地址 + 解压密码
  • 智慧后厨检测算法构建智能厨房防护网
  • 瀚高数据库开启Oracle兼容模块
  • 私有服务器AI智能体搭建配置选择记录
  • 如何更改 SQLserver 数据库存储的位置 想从C盘换到D盘
  • ​​Docker 速通教程
  • 机器人行业10年巨变从协作机器人到具身智能的萌芽、突破和成长——从 Automatic慕尼黑10 年看协作机器人到具身智能的发展
  • 加了pm2
  • (数据结构)线性表(上):SeqList 顺序表
  • vue自定义指令bug
  • Skia 的核心类---深入画布SkCanvas
  • Jfinal+SQLite处理 sqlite数据库执行FIND_IN_SET报错
  • Spring AI:程序调用 AI 大模型
  • Python编程进阶知识之第二课学习网络爬虫(selenium)
  • Java HashMap key为Integer时,遍历是有序还是无序?
  • 信息学奥赛一本通 1575:【例 1】二叉苹果树 | 洛谷 P2015 二叉苹果树
  • 基于LiteNetLib的Server/Client Demo
  • 深入理解 Redis 集群化看门狗机制:原理、实践与风险
  • 当OT遇见IT:Apache IoTDB如何用“时序空间一体化“技术破解工业物联网数据孤岛困局?
  • iOS 文件深度调试实战 查看用户文件 App 沙盒 系统文件与日志全指南