How to Run PostgreSQL on my Local Machine.

I am currently making a project helping to memorize english vocabularies. At first success, I set up PostgreSQL by using Deployment, Service, Secret. Then I realized this is not a best practice. Because it was stateless, which means all tables disappear if a pod is killed. So this is suitable for stateless service like a API server. As I will plan to deploy the API service, I will make some notes. Structures: Deployment, Service, Secret This is my setup details. Deployment apiVersion: apps/v1 kind: Deployment metadata: name: postgres-deployment spec: replicas: 1 selector: matchLabels: app: postgres template: metadata: labels: app: postgres spec: containers: - name: postgres image: postgres:13 ports: - containerPort: 5432 envFrom: - secretRef: name: postgres-secret volumeMounts: - name: postgres-storage mountPath: /var/lib/postgresql/data resources: requests: memory: "512Mi" cpu: "500m" limits: memory: "1Gi" cpu: "1" volumes: - name: postgres-storage emptyDir: {} Secret Service apiVersion: v1 kind: Service metadata: name: postgres-service spec: selector: app: postgres ports: - protocol: TCP port: 5432 targetPort: 5432 type: NodePort Run kubectl apply -f postgre-secret.yaml kubectl apply -f postgre-deployment.yaml kubectl apply -f postgre-service.yaml Access kubectl get svc In the result, you will see the external port like down below. In my case, it was 31477. But if you don't specify NodePort in your service yaml, it will randomly set. Thus yours might be different with mine. Then, In your dbms program, you can access to the database. However, after some talks with ChatGPT, I learned it should be a stateful service. So, I will try to change this in a Stateful method. Wow, it was stateless because I didn't set PersistenceVolume. Changing this configuration, it doesn't clear all tables when the pod is killed. Deployment yaml ... spec: template: spec: volumes: - name: postgres-storage persistentVolumeClaim: claimName: postgres-pvc ... PV apiVersion: v1 kind: PersistentVolume metadata: name: postgres-pv spec: capacity: storage: 1Gi accessModes: - ReadWriteOnce hostPath: path: /tmp/postgres-data type: Directory PVC apiVersion: v1 kind: PersistentVolumeClaim metadata: name: postgres-pvc spec: accessModes: - ReadWriteOnce resources: requests: storage: 1Gi kubectl apply -f postgre-pv.yaml kubectl apply -f postgre-pvc.yaml kubectl apply -f postgre-deployment.yml But, this strategy has a disadvantage. I don't know exactly, there might be something related to count of the pod. I think as this deployment runs only one pod, it can be stateful? might be...? Kubenetes kinds usages recommended by ChatGPT Use Case Recommended Resource Stateless apps (e.g., APIs, frontends) Deployment Apps needing shared storage (e.g., logs, caches) Deployment + PVC Databases, Kafka, Redis, Zookeeper StatefulSet + PVC Apps that require stable network identities StatefulSet

Feb 17, 2025 - 21:41
 0
How to Run PostgreSQL on my Local Machine.

I am currently making a project helping to memorize english vocabularies.

At first success, I set up PostgreSQL by using Deployment, Service, Secret. Then I realized this is not a best practice. Because it was stateless, which means all tables disappear if a pod is killed. So this is suitable for stateless service like a API server. As I will plan to deploy the API service, I will make some notes.

Structures: Deployment, Service, Secret

Image description

This is my setup details.

Deployment

apiVersion: apps/v1
kind: Deployment
metadata:
  name: postgres-deployment
spec:
  replicas: 1
  selector:
    matchLabels:
      app: postgres
  template:
    metadata:
      labels:
        app: postgres
    spec:
      containers:
      - name: postgres
        image: postgres:13
        ports:
          - containerPort: 5432
        envFrom:
          - secretRef:
              name: postgres-secret
        volumeMounts:
          - name: postgres-storage
            mountPath: /var/lib/postgresql/data
        resources:
          requests:
            memory: "512Mi"
            cpu: "500m"
          limits:
            memory: "1Gi"
            cpu: "1"
      volumes:
        - name: postgres-storage
          emptyDir: {}

Secret


Service

apiVersion: v1
kind: Service
metadata:
  name: postgres-service
spec:
  selector:
    app: postgres
  ports:
    - protocol: TCP
      port: 5432
      targetPort: 5432
  type: NodePort

Run

kubectl apply -f postgre-secret.yaml
kubectl apply -f postgre-deployment.yaml
kubectl apply -f postgre-service.yaml

Access

kubectl get svc 

In the result, you will see the external port like down below. In my case, it was 31477. But if you don't specify NodePort in your service yaml, it will randomly set. Thus yours might be different with mine.
Image description

Then, In your dbms program, you can access to the database.

However, after some talks with ChatGPT, I learned it should be a stateful service. So, I will try to change this in a Stateful method.

Wow, it was stateless because I didn't set PersistenceVolume. Changing this configuration, it doesn't clear all tables when the pod is killed.

Deployment yaml

...
spec:
  template:
    spec:
      volumes:
        - name: postgres-storage
          persistentVolumeClaim:
            claimName: postgres-pvc
...

PV

apiVersion: v1
kind: PersistentVolume
metadata:
  name: postgres-pv
spec:
  capacity:
    storage: 1Gi
  accessModes:
    - ReadWriteOnce
  hostPath:
    path: /tmp/postgres-data
    type: Directory

PVC

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: postgres-pvc
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 1Gi

kubectl apply -f postgre-pv.yaml
kubectl apply -f postgre-pvc.yaml
kubectl apply -f postgre-deployment.yml 

But, this strategy has a disadvantage. I don't know exactly, there might be something related to count of the pod. I think as this deployment runs only one pod, it can be stateful? might be...?

Kubenetes kinds usages recommended by ChatGPT

Use Case Recommended Resource
Stateless apps (e.g., APIs, frontends) Deployment
Apps needing shared storage (e.g., logs, caches) Deployment + PVC
Databases, Kafka, Redis, Zookeeper StatefulSet + PVC
Apps that require stable network identities StatefulSet