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

K8S部署postgresql

(作者:陈玓玏)

一、前置条件

  1. 已部署k8s,服务端版本为1.21.14

二、部署postgresql

  1. 拉取镜像,docker pull postgres,不指定版本,自动从docker hub拉取最新版本;
  2. 配置configmap,保存postgresql的用户名、密码等信息,注意密码如果是数字,需要用双引号裹起来;
apiVersion: v1
kind: ConfigMap
metadata:name: pg-configlabels:app: postgres
data:POSTGRES_DB: pgdbPOSTGRES_USER: pgadminPOSTGRES_PASSWORD: "123456"

创建 Postgres ConfigMap 资源,kubectl apply -f postgresql.yaml;
在这里插入图片描述3. 持久卷声明,创建pv和pvc,用于数据的持久化存储:

kind: PersistentVolume
apiVersion: v1
metadata:name: pg-pv-volumelabels:type: localapp: postgres
spec:storageClassName: manualcapacity:storage: 5GiaccessModes:- ReadWriteManyhostPath:path: "/home/postgresql/data"
---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:name: pg-pv-claimlabels:app: postgres
spec:storageClassName: manualaccessModes:- ReadWriteManyresources:requests:storage: 5Gi

保存后通过kubectl apply -f创建pv及pvc。
4. 创建deployment

apiVersion: apps/v1
kind: Deployment
metadata:name: pg-deployment
spec:strategy:type: Recreateselector:matchLabels:app: postgresreplicas: 1template:metadata:labels:app: postgresspec:containers:- name: postgresimage: postgres:11.5imagePullPolicy: "IfNotPresent"ports:- containerPort: 5432envFrom:- configMapRef:name: pg-configvolumeMounts:- mountPath: /var/lib/postgresql/dataname: postgredbvolumes:- name: postgredbpersistentVolumeClaim:claimName: pg-pv-claim

主要是要注意其中selector的app和metadata中的app名称要一致,另外引入的configmap名称要和前面的configmap一致等等。创建好yaml文件后,通过kubectl创建deployment。replica写1就好,数据库的副本数一般1就够了,避免读写冲突。

pg的版本如果不记得,可以通过docker images |grep postgresql查一下。
5. 创建service,对外暴露服务入口

apiVersion: v1
kind: Service
metadata:name: pg-servicelabels:app: postgres
spec:type: NodePortports:- port: 5432targetPort: 5432protocol: TCPselector:app: postgres

注意targetPort要和deployment暴露出来的一致,否则无法转发到deployment创建的pod。同样,写好yaml之后通过kubectl apply -f创建service。

三、验证部署结果

  1. 验证部署是否成功
    在这里插入图片描述
    service可以查询到,再尝试下使用pg,首先下载一个pg的客户端:apt -y install postgresql-client-12,下载完成后,登录pg,通过psql -U pgadmin -h 10.43.25.238 -p 5432 pgdb登录pg,数据库名、用户名、密码、端口、ip在前面都可以找到,能够登录即部署成功。登录成功如下:
    在这里插入图片描述

参考:

  1. https://hanggi.me/post/kubernetes/k8s-postgresql/
  2. https://stackoverflow.com/questions/28290488/get-error-you-must-install-at-least-one-postgresql-client-version-package-whe
  3. https://blog.csdn.net/dujidan/article/details/128862899
http://www.lryc.cn/news/308129.html

相关文章:

  • Go 如何控制并发的goroutine数量?
  • 【黑马程序员】1、TypeScript介绍_黑马程序员前端TypeScript教程,TypeScript零基础入门到实战全套教程
  • JS进阶——深入对象
  • Gitlab部署管理
  • MyBatis 学习(二)之 第一个 MyBatis 案例
  • 30天自制操作系统(第21天)
  • linux系统Jenkins的安装
  • 【GStreamer】basic-tutorial-1:GstBus、GstMessage详解
  • Python中的可变变量与不可变变量
  • OpenGL调用窗口,方向键和鼠标
  • fastAdmin表格列表的功能
  • 用来检查 CUDA、Conda 和 PyTorch 的版本的python文件
  • 基于Redisson,实现分布式锁注解
  • 【机器学习】机器学习是什么?
  • 一文速览深度伪造检测(Detection of Deepfakes):未来技术的守门人
  • C# 中的执行表达式树(Expression Tree)
  • 森林监测VR虚拟情景再现系统更便利
  • 高频面试题整理(一)
  • 2-23 switch、JVM内存模型、垃圾回收机制、this、static、变量的分类
  • 基础!!!吴恩达deeplearning.ai:卷积层
  • SpringBoot案例(黑马学习笔记)
  • 项目流程图
  • 鸿蒙这么大声势,为何迟迟看不见岗位?最新数据来了
  • Qt中关于信号与槽函数的思考
  • 项目技术栈-解决方案-消息队列
  • 【深度优先搜索】【图论】【推荐】332. 重新安排行程
  • DAY9-防病毒AV概述
  • TCP缓存
  • Socket网络编程(一)——网络通信入门基本概念
  • RTCA DO-178C 机载系统和设备认证中的软件注意事项-软件质量保证流程(八)