Description
Describe the problem
I run a self hosted netbird setup. On one of the peers, I run a traefik instance with a few webservices. After updating this peer's netbird client from 0.29.4
to 0.30.0
, I'm unable to connect to its port 80
and 443
from other peers.
Everything else, including ping
and ssh
to it works. Port 80
and 443
also start accepting connections immediately if I downgrade the netbird client back to 0.29.4
– and stops working immediately if I update to 0.30.0
.
To Reproduce
- Run
sudo apt-get install netbird=0.30.0
to update the netbird client. - Verify the ports are being listened on the defective netbird peer
user@defective-peer:~$ ss -tuln | grep -E '(:80|:443)'
tcp LISTEN 0 4096 0.0.0.0:80 0.0.0.0:*
tcp LISTEN 0 4096 0.0.0.0:443 0.0.0.0:*
tcp LISTEN 0 4096 100.64.58.207:44338 0.0.0.0:*
tcp LISTEN 0 4096 [::]:80 [::]:*
tcp LISTEN 0 4096 [::]:443 [::]:*
user@defective-peer:~$ nmap -p- 0.0.0.0
Starting Nmap 7.93 ( https://nmap.org ) at 2024-10-06 20:05 IST
Nmap scan report for 0.0.0.0
Host is up (0.000059s latency).
Not shown: 65529 closed tcp ports (conn-refused)
PORT STATE SERVICE
22/tcp open ssh
80/tcp open http
443/tcp open https
631/tcp open ipp
41981/tcp open unknown
52874/tcp open unknown
Nmap done: 1 IP address (1 host up) scanned in 0.85 seconds
- Try to reach the defective peer from a different peer. Ports
80
and443
seem to be filtered. There are no firewalls on the defective peer or anywhere on the network which could be blocking these other than netbird itself.
user@different-peer:~$ nmap -Pn -p- --reason defective-peer.netbird.selfhosted
Starting Nmap 7.95 ( https://nmap.org ) at 2024-10-06 20:17 IST
Nmap scan report for defective-peer.netbird.selfhosted (100.64.58.207)
Host is up, received user-set (0.0035s latency).
Not shown: 65531 closed tcp ports (conn-refused)
PORT STATE SERVICE REASON
22/tcp open ssh syn-ack
80/tcp filtered http no-response
443/tcp filtered https no-response
44338/tcp open unknown syn-ack
Nmap done: 1 IP address (1 host up) scanned in 49.06 seconds
- Downgrade netbird client on the defective peer with
sudo apt-get install netbird=0.29.0
and verify outputs from step 2 haven't changed. - Try to
nmap
the defective peer from a different peer again. It starts responding to ports 80 and 443.
user@different-peer:~$ nmap -Pn -p- --reason defective-peer.netbird.selfhosted
Starting Nmap 7.95 ( https://nmap.org ) at 2024-10-06 20:34 IST
Nmap scan report for yukino-100.netbird.selfhosted (100.64.58.207)
Host is up, received user-set (0.29s latency).
Not shown: 65531 closed tcp ports (conn-refused)
PORT STATE SERVICE REASON
22/tcp open ssh syn-ack
80/tcp open http syn-ack
443/tcp open https syn-ack
44338/tcp open unknown syn-ack
Nmap done: 1 IP address (1 host up) scanned in 4096.96 seconds
Expected behavior
There shouldn't be any difference in reaching port 80 and 443, after updating to 0.30.0.
Are you using NetBird Cloud?
No. I'm self-hosting the Netbird control plane on a Hetzner VPS.
NetBird version
0.30.0
NetBird status -dA output:
user@defective-peer:~$ netbird status -dA
different-peer.netbird.selfhosted:
NetBird IP: 100.64.196.33
Public key: QRedactedBOw6/xKAuuht55kDxmK56LFXYSldKqb1CI=
Status: Connected
-- detail --
Connection type: P2P
ICE candidate (Local/Remote): srflx/host
ICE candidate endpoints (Local/Remote): 198.51.100.0:40320/192.168.0.183:51820
Relay server address: rels://netbird.anon-ERw0W.domain:443/relay
Last connection update: 34 minutes, 33 seconds ago
Last WireGuard handshake: 27 seconds ago
Transfer status (received/sent) 19.8 MiB/16.4 MiB
Quantum resistance: false
Routes: -
Latency: 3.032567ms
OS: linux/amd64
Daemon version: 0.30.0
CLI version: 0.30.0
Management: Connected to https://netbird.anon-ERw0W.domain:443
Signal: Connected to https://netbird.anon-ERw0W.domain:443
Relays:
[stun:netbird.anon-ERw0W.domain:3478] is Unavailable, reason: stun request: context deadline exceeded
[turn:netbird.anon-ERw0W.domain:3478?transport=udp] is Available
[rels://netbird.anon-ERw0W.domain:443/relay] is Available
Nameservers:
FQDN: defective-peer.netbird.selfhosted
NetBird IP: 100.64.58.207/16
Interface type: Kernel
Quantum resistance: false
Routes: -
Peers count: 4/4 Connected // Removed all but the peer I am trying to connect from
Additional context
I've tried running this with the control plane and the other non-defective peer running at both 0.29.4
and 0.30.0
. It doesn't seem to make a difference.
Activity