How can I configure HAProxy to work with server sent events?
Asked Answered
H

1

10

I'm trying to add an endpoint to an existing application that sends Server Sent Events. There often may be no event for ~5 minutes. I'm hoping to configure that endpoint to not cut off my server even when the response has not been completed in ~1min, but all other endpoints to timeout if the server fails to respond.

Is there an easy way to support server sent events in HAProxy?

Haroldson answered 29/1, 2014 at 0:34 Comment(0)
M
12

Here is my suggestion for HAProxy and SSE: you have plenty of custom timeout options in HAProxy, and there is 2 interesting options for you.

The timeout tunnel specifies timeout for tunnel connection - used for Websockets, SSE or CONNECT. Bypass both server and client timeout.

The timeout client handles the situation where a client looses their connection (network loss, disappear before the ACK of ending session, etc...)

In your haproxy.cfg, this is what you should do, first in your defaults section :

# Set the max time to wait for a connection attempt to a server to succeed
timeout connect 30s
# Set the max allowed time to wait for a complete HTTP request
timeout client  50s
# Set the maximum inactivity time on the server side
timeout server  50s

Nothing special until there.

Now, still in the defaults section :

# handle the situation where a client suddenly disappears from the net
timeout client-fin 30s

Next, jump to your backend definition and add this:

timeout tunnel 10h

I suggest a high value, 10 hours seems ok.

You should also avoid using the default http-keep-alive option, SSE does not use it. Instead, use http-server-close.

Malcommalcontent answered 27/8, 2015 at 15:40 Comment(2)
Tunnel timeout may apply to web sockets, I'm less sure it does apply to SSE... The good practice is probably to send keep-alive events from the server every minute or so, and to have timeout server twice this delay.Zworykin
I installed SSE server (NodeJS) and configured it to work with HAProxy. All works good except one thing: when connection is closed on client (EventSource::close()), packet with data about closing the connection isn't going through HAProxy to SSE server (request.on('close', () => { ... }). Any ideas, why? Tried different combination of http-server-close, option httpclose, option http-keep-alive and timeouts, haproxy v2.5, 2.7. Closing connection is sent to SSE server, if use directly (without haproxy).Trifurcate

© 2022 - 2024 — McMap. All rights reserved.