<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Networking on johanneskueber.com</title><link>https://johanneskueber.com/tags/networking/</link><description>Recent content in Networking on johanneskueber.com</description><generator>Hugo</generator><language>en_US</language><lastBuildDate>Mon, 01 Jun 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://johanneskueber.com/tags/networking/index.xml" rel="self" type="application/rss+xml"/><item><title>Bare-Metal LoadBalancer Services on Talos with Cilium L2 Announcements</title><link>https://johanneskueber.com/posts/2026-06-01-cilium-l2-announcements/</link><pubDate>Mon, 01 Jun 2026 00:00:00 +0000</pubDate><guid>https://johanneskueber.com/posts/2026-06-01-cilium-l2-announcements/</guid><description>&lt;p&gt;This article documents how to replace MetalLB with Cilium&amp;rsquo;s built-in L2 announcement feature, including the IPAM pool, the announcement policy, the supporting Cilium values, and what to verify on the wire.&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="1-metallbs-role"&gt;1. MetalLB&amp;rsquo;s role&lt;/h2&gt;
&lt;p&gt;On a bare-metal cluster, a &lt;code&gt;Service&lt;/code&gt; of &lt;code&gt;type: LoadBalancer&lt;/code&gt; is meaningless until something assigns it an external IP and answers ARP for that IP on the local segment. The classic answer is MetalLB in L2 mode: a controller allocates an IP from a pool; a speaker DaemonSet replies to ARP requests, advertising via gratuitous ARP after leader election.&lt;/p&gt;</description></item><item><title>Running a rootless NetBird Routing Peer Inside Kubernetes</title><link>https://johanneskueber.com/posts/2026-05-25-netbird-routing-peer/</link><pubDate>Mon, 25 May 2026 00:00:00 +0000</pubDate><guid>https://johanneskueber.com/posts/2026-05-25-netbird-routing-peer/</guid><description>&lt;p&gt;This article documents how to run a NetBird client &lt;em&gt;inside&lt;/em&gt; a Kubernetes cluster as a &lt;strong&gt;routing peer&lt;/strong&gt; — rootless, with an in-memory state volume, a shell-based readiness probe, and dropped capabilities — so that remote mesh members can reach cluster-internal services over the encrypted overlay, without exposing kernel WireGuard and without making the cluster a peer of every workload.&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="1-why-a-netbird-peer-in-the-cluster"&gt;1. Why a NetBird peer in the cluster&lt;/h2&gt;
&lt;p&gt;NetBird is a WireGuard-based identity mesh. Each peer holds keys, exchanges them via the management plane, and routes encrypted traffic to other peers. The default deployment runs the client on a host (Linux VM, MacBook, etc.) and uses the host&amp;rsquo;s kernel WireGuard.&lt;/p&gt;</description></item></channel></rss>