webpack/webpack-dev-server

Connection to localhost does not work on Mac due to IPv6

Timmmm opened this issue · 6 comments

  • Operating System: macOS 10.14.4

  • Node Version: 10.16.0

  • NPM Version: 6.9.0

  • webpack Version: 4.41.0

  • webpack-dev-server Version: 3.8.1

  • Browser: Electron 6

  • This is a bug

  • This is a modification request

Code

Create a default project like this:

npm install -g @vue/cli
vue create foo # Add Typescript, but it probably doesn't make a difference.
cd foo
vue add electron-builder

Run the electron app:

npm run electron:serve

Or run the web server:

npm run serve

Expected Behavior

  • Electron page loads correctly.
  • The "local" URL that the web server prints (App running at: - Local: http://localhost:8080/) should work.

Actual Behavior

You get a blank electron app, and http://localhost:8080/ does not load. The problem is that webpack-dev-server actually listens on 127.0.0.1 (or maybe 0.0.0.0), but somewhere in its code it says "Oh ... 127.0.0.1? Silly users won't understand that! I'll replace it with localhost which is much more friendly."

A gallant aim perhaps, but not a robust one. On Mac localhost resolves to ::1, not 127.0.0.1. Since Electron and the web browser have been told to connect to localhost (::1) but the server is actually listening on 127.0.0.1, they do not work.

A workaround is to put this in your vue.config.js file:

module.exports = {
  devServer: {
    host: '127.0.0.1'
  }
}

I also reported this bug to vue-cli but I'm pretty sure the problem is actually in webpack-dev-server.

I think you have broken hosts file (or maybe something other works not as expected), because localhost should be always resolve as
The name localhost normally resolves to the IPv4 loopback address 127.0.0.1, and to the IPv6 loopback address ::1.[1] (https://en.wikipedia.org/wiki/Localhost)

0.0.0.0 !== 127.0.0.1

This happened to me after upgrading to Catalina. The fix above worked for me.

@ErikMikkelson hm, maybe regression in new Catalina. it’s also rather strange that we didn’t receive issue from other developers, i will look on this in near future.

What webpack-dev-server output to you? Maybe vue-cli uses 0.0.0.0, not 127.0.0.1?

Ugh, finally found an answer via this other person. Bloody antivirus!

They basically intercept every connection to localhost:8080. Specifically that host/port combo: localhost:8081 and 127.0.0.1:8080 both work fine. It was nothing to do with IPv6. Check out this madness (with no server running):

$ telnet localhost 8081
Trying ::1...
telnet: connect to address ::1: Connection refused
Trying 127.0.0.1...
telnet: connect to address 127.0.0.1: Connection refused
telnet: Unable to connect to remote host

$ telnet 127.0.0.1 8080
Trying 127.0.0.1...
telnet: connect to address 127.0.0.1: Connection refused
telnet: Unable to connect to remote host

$ telnet localhost 8080
Trying ::1...
Connected to localhost.
Escape character is '^]'.
Connection closed by foreign host.

Sorry for blaming you guys!

I'd suggest using a different default port, but frankly this is ESET's fault & fuck those guys.

@Timmmm thanks for feedback and investigation, good job!

I am here with the same issue but for local domains.

Previously any local domain host entry like 127.0.0.1 mysite.local and it worked fine, but it used to be very slow to resolve. So I switched to IP6 ::1 mysite.local and being lazy had a few times with both.

I dug up an old site and it would not resolve, I can't even ping it. But as soon as I add 127.0.0.1 it works again 🤷‍♂️.