herokuelixirphoenix-frameworkphoenix-channels

Heroku H15 errors with Elixir/Phoenix Channels


Once I started using Channels with Phoenix, I started getting a lot of these errors on Heroku:

heroku[router]: at=error code=H15 desc="Idle connection" method=GET
path="/socket/websocket?guardian_token=eyJhbGciOiJIUz[...]&vsn=1.0.0" host=[...]
dyno=web.1 connect=0ms service=87803ms status=503 bytes=

A reliable way to reproduce this is on a laptop:

  1. Open a Phoenix page that connects to WebSockets
  2. Close the lid of your laptop
  3. Wait a minute or so (WiFi to disconnect/OS goes to sleep)
  4. The H15 error will occur.

I've set a 45s timeout on my UserChannel already; I'm running Elixir 1.4.2, Phoenix 1.2.1 and my phoenix.js was just upgraded to the one used in Phoenix 1.3.0-rc0 (link to rev)

I can see the error logged on the front-end, but after that it reconnects happily to the backend:

2017-03-04 23:28:55.351 receive: ok user:2 phx_reply (3)
2017-03-04 23:29:24.269 channel: error user:2
2017-03-04 23:29:28.713 push: user:2 phx_join (4)
2017-03-04 23:29:28.745 receive: ok user:2 phx_reply (4)

Any help or ideas how to solve this is much appreciated.

Edit: I'm familiar with Heroku's H15 error code definition so I'm looking for a fix or a workaround for getting rid of the errors (other than migrating away from Heroku, of course).


Solution

  • Phoenix docs recommend setting the timeout for the websocket transport to < 55 seconds:

    defmodule HelloWeb.UserSocket do
      use Phoenix.Socket
    
      ...
    
      ## Transports
      transport :websocket, Phoenix.Transports.WebSocket,
        timeout: 45_000
        ...
    end
    

    Their explanation is:

    This ensures that any idle connections are closed by Phoenix before they reach Heroku’s 55-second timeout window.