Skip to main content

Heimdall

image.png

Resumen

  • Creación del Namespace heimdall

  • Despliegue de Heimdall usando un StatefulSet.

    • Creación de PVC con nfs-client como StorageClass.
  • Exposición del servicio usando NGINX Ingress.

Namespace

apiVersion: v1
kind: Namespace
metadata:
  name: heimdall

StatefulSet

---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: heimdall
  namespace: heimdall
spec:
  serviceName: "heimdall"
  replicas: 1
  selector:
    matchLabels:
      app: heimdall
  template:
    metadata:
      labels:
        app: heimdall
    spec:
      containers:
        - name: heimdall
          image: lscr.io/linuxserver/heimdall:latest
          ports:
            - containerPort: 80
          volumeMounts:
            - name: heimdall-pvc
              mountPath: /config
  volumeClaimTemplates:
    - metadata:
        name: heimdall-pvc
      spec:
        accessModes:
          - ReadWriteMany
        storageClassName: nfs-client
        resources:
          requests:
            storage: 2Gi

Service

---
apiVersion: v1
kind: Service
metadata:
  name: heimdall
  namespace: heimdall
spec:
  ports:
    - port: 80
      targetPort: 80
  clusterIP: None
  selector:
    app: heimdall

Ingress

---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: heimdall-ingress
  namespace: heimdall
  annotations:
    nginx.ingress.kubernetes.io/rewrite-target: /
    nginx.ingress.kubernetes.io/ssl-redirect: "true"
    cert-manager.io/cluster-issuer: "letsencrypt-staging" # Puedes cambiar por "letsencrypt-production" 
spec:
  ingressClassName: nginx
  tls:
    - hosts:
        - heimdall.k8s.ictiberia.com
      secretName: heimdall-tls  # Nombre del secreto con el certificado TLS
  rules:
    - host: heimdall.k8s.ictiberia.com
      http:
        paths:
          - path: /
            pathType: Prefix
            backend:
              service:
                name: heimdall
                port:
                  number: 80

Comandos

# Aplicar
kubectl apply -f heimdall.yaml

# Comprobar
kubectl get all -n heimdall