Swiftorial Logo
Home
Swift Lessons
Matchups
CodeSnaps
Tutorials
Career
Resources

Deploying MongoDB on Kubernetes

Introduction

Kubernetes is a powerful container orchestration platform that allows you to deploy, manage, and scale containerized applications. Deploying MongoDB on Kubernetes provides a scalable and resilient database solution. This tutorial will guide you through the steps to deploy MongoDB on a Kubernetes cluster.

Setting Up

Before you begin, ensure that you have a Kubernetes cluster set up and kubectl installed. You can use a managed Kubernetes service or set up a local cluster using Minikube.

Creating MongoDB Deployment

Create a Kubernetes deployment for MongoDB using the following YAML file:

mongodb-deployment.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: mongodb
spec:
  replicas: 1
  selector:
    matchLabels:
      app: mongodb
  template:
    metadata:
      labels:
        app: mongodb
    spec:
      containers:
      - name: mongodb
        image: mongo:latest
        ports:
        - containerPort: 27017
        volumeMounts:
        - name: mongodb-data
          mountPath: /data/db
      volumes:
      - name: mongodb-data
        persistentVolumeClaim:
          claimName: mongodb-pvc
            

Creating Persistent Volume

Create a Persistent Volume Claim (PVC) to store MongoDB data:

mongodb-pvc.yaml

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

Deploying MongoDB

Apply the YAML files to deploy MongoDB on your Kubernetes cluster:

Applying YAML Files

kubectl apply -f mongodb-pvc.yaml
kubectl apply -f mongodb-deployment.yaml
            

Accessing MongoDB

Create a Kubernetes Service to expose MongoDB:

mongodb-service.yaml

apiVersion: v1
kind: Service
metadata:
  name: mongodb-service
spec:
  selector:
    app: mongodb
  ports:
    - protocol: TCP
      port: 27017
      targetPort: 27017
            

Apply the Service YAML file:

Applying Service YAML

kubectl apply -f mongodb-service.yaml
            

Conclusion

In this tutorial, you have learned how to deploy MongoDB on a Kubernetes cluster. Kubernetes provides a robust platform for managing and scaling MongoDB deployments, ensuring high availability and performance.