A Kubernetes cluster spread across four countries (Netherlands, Switzerland, Norway, Greece) with my own ASN and BGP anycast routing. The excuse was disaster recovery. The real reason was wanting to understand how the internet works at the routing level.

Overview

AspectDetails
CountriesNetherlands, Switzerland, Norway, Greece
ArchitectureHybrid (on-premises + cloud VPS)
RoutingBGP anycast with personal ASN
IPv6/48 prefix via RIPE LIR
Nodes13 across 2 operational sites (NL, GR)

Key Technical Components

BGP & Networking

  • Personal ASN registration via RIPE LIR with /48 IPv6 prefix
  • eBGP peering with two upstream transit providers for anycast redundancy
  • iBGP mesh over IPsec/WireGuard tunnels using Cilium BGP control plane
  • NAT64 edge translation enabling IPv6 ingress to IPv4 core infrastructure

Site Connectivity

  • Full mesh encrypted tunnels between on-premises (Cisco ASA) and cloud sites (strongSwan)
  • Geo-distributed edge nodes for latency optimization and DDoS resilience
  • IPsec tunnels with automatic failover

Kubernetes Platform

  • Cilium CNI with eBPF dataplane
  • BGP control plane for LoadBalancer services
  • Cross-cluster service mesh via Cilium Cluster Mesh

Architecture

                         ┌─────────────────────────────────┐
                         │     IPv6 Anycast Traffic        │
                         │      (Personal ASN + /48)       │
                         └───────────────┬─────────────────┘
                         ┌───────────────┴───────────────┐
                         │      Transit Providers         │
                         │    (eBGP - Redundant Path)     │
                         └───────────────┬───────────────┘
        ┌────────────────┬───────────────┼───────────────┬────────────────┐
        │                │               │               │                │
        ▼                ▼               │               ▼                ▼
┌───────────────┐ ┌───────────────┐      │      ┌───────────────┐ ┌───────────────┐
│  Switzerland  │ │    Norway     │      │      │  Netherlands  │ │    Greece     │
│  (iFog VPS)   │ │(Gigahost VPS) │      │      │  (On-Prem)    │ │  (On-Prem)    │
│  strongSwan   │ │  strongSwan   │      │      │ Cisco ASA     │ │ Cisco ASA     │
│  NAT64+eBGP   │ │  NAT64+eBGP   │      │      │   5508-X      │ │   5508-X      │
└───────┬───────┘ └───────┬───────┘      │      └───────┬───────┘ └───────┬───────┘
        │                 │              │              │                 │
        │                 │              │              │                 │
        └─────────────────┴──────────────┴──────────────┴─────────────────┘
                    ┌────────────────────┴────────────────────┐
                    │      IPsec Full Mesh (All 4 Sites)      │
                    │  CH ←→ NO ←→ NL ←→ GR ←→ CH ←→ NL...   │
                    └────────────────────┬────────────────────┘
              ┌──────────────────────────┴──────────────────────────┐
              │                                                     │
              ▼                                                     ▼
┌─────────────────────────────────┐         ┌─────────────────────────────────┐
│       Netherlands (NL)          │         │          Greece (GR)            │
│         nllei01k8s              │         │          grskg01k8s             │
│  ┌───────────────────────────┐  │         │  ┌───────────────────────────┐  │
│  │  3x Control Plane (HA)    │  │         │  │  3x Control Plane (HA)    │  │
│  │  4x Worker Nodes          │  │         │  │  4x Worker Nodes          │  │
│  │  Cilium CNI + iBGP        │  │         │  │  Cilium CNI + iBGP        │  │
│  │  Proxmox VE               │  │         │  │  Proxmox VE               │  │
│  └───────────────────────────┘  │         │  └───────────────────────────┘  │
│         PRIMARY SITE            │◄───────►│          DR/HA SITE             │
│       192.168.85.0/24           │ Cluster │        192.168.58.0/24          │
└─────────────────────────────────┘  Mesh   └─────────────────────────────────┘

Technology Stack

Networking

  • BGP: Personal ASN with /48 IPv6 prefix
  • Transit: Dual upstream providers for redundancy
  • Tunneling: IPsec (Cisco ASA) + strongSwan (cloud)
  • Edge: NAT64 for IPv6→IPv4 translation

Kubernetes

  • Version: v1.34.2
  • CNI: Cilium with eBPF dataplane
  • Mesh: Cilium Cluster Mesh for cross-site connectivity
  • Ingress: NGINX with BGP-advertised VIPs

Infrastructure

  • On-premises: Proxmox VE, Cisco ASA 5508-X
  • Cloud: iFog (Switzerland), Gigahost (Norway)
  • Storage: SeaweedFS with cross-site replication

Status

Current: Netherlands and Greece operational (primary + DR) Transit: Switzerland (iFog) and Norway (Gigahost) operational as edge/transit nodes


Read the full build story in the blog post .