Files
Pulse/docs/KUBERNETES.md
2025-10-18 11:50:57 +00:00

5.9 KiB
Raw Blame History

Kubernetes Deployment (Helm)

Deploy Pulse to Kubernetes with the bundled Helm chart under deploy/helm/pulse. The chart provisions the Pulse hub (web UI + API) and can optionally run the Docker monitoring agent alongside it. Stable builds are published automatically to the GitHub Container Registry (GHCR) whenever a Pulse release goes out.

Prerequisites

  • Kubernetes 1.24 or newer with access to a default StorageClass
  • Helm 3.9+
  • An ingress controller (only if you plan to expose Pulse through an Ingress)
  • (Optional) A Docker-compatible runtime on the nodes where you expect to run the Docker agent; the agent talks to /var/run/docker.sock
  1. Authenticate against GHCR (one-time step on each machine):

    helm registry login ghcr.io
    
  2. Install the chart published for the latest Pulse release (swap the inline curl command with a pinned version if you need to lock upgrades):

    helm install pulse oci://ghcr.io/rcourtman/pulse-chart \
      --version $(curl -fsSL https://raw.githubusercontent.com/rcourtman/Pulse/main/VERSION) \
      --namespace pulse \
      --create-namespace
    

    The chart version tracks the Pulse release version. Check GitHub Releases or run gh release list --limit 1 to find the newest tag if you prefer to specify it manually.

  3. Port-forward the service to finish the first-time security setup:

    kubectl -n pulse port-forward svc/pulse 7655:7655
    
  4. Browse to http://localhost:7655, complete the security bootstrap (admin user + MFA + TLS preferences), and create an API token under Settings → Security for any automation or agents you plan to run.

The chart mounts a PersistentVolumeClaim at /data so database files, credentials, and configuration survive pod restarts. By default it requests 8GiB with ReadWriteOnce access—adjust via persistence.* in values.yaml.

Working From Source (local packaging)

Need to test local modifications or work offline? Install directly from the checked-out repository:

  1. Clone the repository and switch into it.

    git clone https://github.com/rcourtman/Pulse.git
    cd Pulse
    
  2. Render or install the chart from deploy/helm/pulse:

    helm upgrade --install pulse ./deploy/helm/pulse \
      --namespace pulse \
      --create-namespace
    
  3. Continue with the port-forward and initial setup steps described above.

Common Configuration

Most day-to-day overrides are done in a custom values file:

# file: helm-values.yaml
service:
  type: ClusterIP

ingress:
  enabled: true
  className: nginx
  hosts:
    - host: pulse.example.com
      paths:
        - path: /
          pathType: Prefix
  tls:
    - hosts: [pulse.example.com]
      secretName: pulse-tls

server:
  env:
    - name: TZ
      value: Europe/Berlin
  secretEnv:
    create: true
    data:
      API_TOKENS: docker-agent-token

Install or upgrade with the overrides:

helm upgrade --install pulse ./deploy/helm/pulse \
  --namespace pulse \
  --create-namespace \
  -f helm-values.yaml

The server.secretEnv block above pre-seeds one or more API tokens so the UI is immediately accessible and automation can authenticate. If you prefer to manage credentials separately, set server.secretEnv.name to reference an existing secret instead of letting the chart create one.

Accessing Pulse

  • Port forward: kubectl -n pulse port-forward svc/pulse 7655:7655
  • Ingress: Enable via the snippet above, or supply your own annotations for external DNS, TLS, etc.
  • LoadBalancer: Set service.type: LoadBalancer and, optionally, service.loadBalancerIP.

Persistence Options

  • persistence.enabled: Disable to use an ephemeral emptyDir
  • persistence.existingClaim: Bind to a pre-provisioned PVC
  • persistence.storageClass: Pin to a specific storage class
  • persistence.size: Resize the default PVC request

Enabling the Docker Agent

The optional agent reports Docker host metrics back to the Pulse hub. Enable it once you have a valid API token:

# agent-values.yaml
agent:
  enabled: true
  env:
    - name: PULSE_URL
      value: https://pulse.example.com
  secretEnv:
    create: true
    data:
      PULSE_TOKEN: docker-agent-token
  dockerSocket:
    enabled: true
    path: /var/run/docker.sock
    hostPathType: Socket

Apply with (choose one):

  • Published chart:

    helm upgrade pulse oci://ghcr.io/rcourtman/pulse-chart \
      --install \
      --version <pulse-version> \
      --namespace pulse \
      -f agent-values.yaml
    
  • Local checkout:

    helm upgrade --install pulse ./deploy/helm/pulse \
      --namespace pulse \
      -f agent-values.yaml
    

Notes:

  • The agent expects a Docker-compatible runtime and access to the Docker socket. Set agent.dockerSocket.enabled: false if you run the agent elsewhere or publish the Docker API securely.
  • Use separate API tokens per host; list multiple tokens with ; or , separators in PULSE_TARGETS if needed.
  • Run the agent as a DaemonSet (default) to cover every node, or switch to agent.kind: Deployment for a single pod.

Upgrades and Removal

  • Upgrade (GHCR): helm upgrade pulse oci://ghcr.io/rcourtman/pulse-chart --version <new-version> -n pulse -f <values.yaml>
  • Upgrade (source): Re-run helm upgrade --install pulse ./deploy/helm/pulse -f <values> with updated overrides.
  • Rollback: helm rollback pulse <revision>
  • Uninstall: helm uninstall pulse -n pulse (PVCs remain unless you delete them manually)

Reference

  • Review every available option in deploy/helm/pulse/values.yaml
  • Inspect published charts without installing: helm show values oci://ghcr.io/rcourtman/pulse-chart --version <version>
  • Helm template rendering preview: helm template pulse ./deploy/helm/pulse -f <values>
  • NOTES.txt emitted by Helm summarizes the service endpoint and agent prerequisites after each install or upgrade