Skip to content

Unable to reach WSL from Windows with mirrored networking mode #13013

Open
@gaac510

Description

@gaac510

Windows Version

Microsoft Windows [Version 10.0.26100.4202]

WSL Version

2.5.7.0

Are you using WSL 1 or WSL 2?

  • WSL 2
  • WSL 1

Kernel Version

6.6.87.1-1

Distro Version

Ubuntu 24.04

Other Software

No response

Repro Steps

Preparation

  1. Set WSL to use mirrored networking mode, make sure systemd is enabled, and leave everything else default.
  2. Reboot Windows to make sure the settings take effect. (The reboot has been necessary for me, I'm not sure about everyone else's situation.)

Scenario A - Docker 101 served from port 80

In WSL, run docker run --rm -p 80:80 docker/getting-started to start serving Docker 101 tutorial from port 80.

Scenario B - Serve a Next.js dev app from port 3000

  1. In WSL, run npx create-next-app@latest to create a Next.js app.
  2. cd into the project directory, and run npm run dev to start a dev server at port 3000.

Scenario C - Serving various Supabase services with Docker from port 5432*

  1. In WSL, run npx create-next-app@latest to create a Next.js app.
  2. cd into the project directory, and run npm install supabase --save-dev to install Supabase as a project dev dependency.
  3. Run npx supabase init and then npx supabase start to start various containerised services - they should occupy port 54321, 54323 and 54324.

Expected Behavior

These URLs should all be reachable from both within WSL and from host Windows:

Actual Behavior

  • All URLs listed were only reachable from within WSL.
  • Loading any of the URLs in MS Edge running in host Windows resulted in (address differed for each URL):
    Hmmm… can't reach this page
    localhost refused to connect.
    
    Try:
    Search the web for [localhost](https://www.bing.com/search?form=ANLKDR&q=localhost)
    Checking the connection
    [Checking the proxy and the firewall](chrome-error://chromewebdata/#buttons)
    
    ERR_CONNECTION_REFUSED
    
    I also tried requesting using Bruno, and I always got connect ETIMEDOUT 127.0.0.1:3000 (port differed for each URL).

Additional troubleshooting I've done

  • Installed a brand-new Ubuntu 24.04 distro and tested from there - got same issue.
  • Changed to NAT networking mode while leaving everything else unchanged - didn't get the same issue, i.e. can reach WSL from Windows.
  • Tried systemctl disable network-manager.service and systemctl disable NetworkManager.service - neither worked since neither service existed.
  • Realised there's systemd-networkd.service and it was already disabled; in vain hope, tried enabling & starting the service and then stopping & disabling the service - in the end, nothing changed i.e. still got the same issue.
  • Tried both Hyper-V firewall commands noted at https://learn.microsoft.com/en-us/windows/wsl/networking#mirrored-mode-networking - made no difference i.e. still got the same issue.
  • Played with disabling/enabling the "Hyper-V" and/or the "Windows Hypervisor Platform" Windows features - made no difference i.e. still got the same issue.

Diagnostic Logs

WslNetworkingLogs-2025-05-30_21-43-52.zip

Metadata

Metadata

Assignees

No one assigned

    Labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions