How to solve Chrome's 6 connection limit when using xhr polling
Asked Answered
B

1

23

I recently found out that Chrome seems to have a connection limit of 6 ( Chrome hangs after certain amount of data transfered - waiting for available socket ) unfortunately I found this out the hard way by getting a "waiting for available sockets" message after loading up too many tabs (7).

I know it is Chrome since another Chrome user (a.k.a another browser session) loads the web page perfectly fine on the same computer at the same time (I have multiple Chrome users open on my computer). So it is not the server in any way.

I believe this is because, in socket.io (which I am using for notifications), I am xhr-polling which is causing Chrome to have to wait until it can grab a socket from one of those connections before it can process the page.

What is the solution to this?

I have thought of a couple of solutions:

  • make the xhr-polling window smaller, this increases connections in the browser and node.js but will mean the page won't stall.
  • Use websockets. I am unsure if websockets are immune to this problem either.
  • Make connections inactive on tabs not focused. Though it seems other sites don't have to do that...
  • Use some kind of connection sharing. Considering that Chrome isolates websockets and xhr requests to the tab I do find it difficult to understand how that works.

As an added point: the reason I have not gone with websockets from the start is because I use cloudflare. But if this is the way to solve it then: so be it.

Badr answered 21/9, 2015 at 14:33 Comment(6)
Use a real webSocket, rather than XHR Polling. webSocket connections do not count toward the http connection limit to the same origin.Cornelia
@Cornelia aha, thanks!Badr
A couple reference articles: Max parallel http connections in a browser? and Maximum concurrent connections to the same domain for browsers and HTTP simultaneous connections per host limit… are per tab, browser instance or global?.Cornelia
@Cornelia if you put that as an answer with some explanation I'll definitely upvote it. I think I am gonna have to use a workaround with cloudflare, my idea of hoping to get around it with xhr is falling apart tbhBadr
from our testing, websocket is also subjected to the same limit.Czech
@PhuahYeeKeat you can have frames on a websocket which means you can send many types of data down the same websocket and the node.js app can just route the requestBadr
C
21

Use a real webSocket, rather than XHR Polling. webSocket connections do not count toward the http connection limit to the same origin.

There is a separate global limit to how many webSocket connections can be created, but it is a high number (200 in Firefox - not sure what it is exactly in Chrome).

Here are some references on this topic:

Cornelia answered 21/9, 2015 at 20:41 Comment(4)
Decided to do this in the end, just made a SSL'd domain outside of cloudflare and decide to say hell to it. I lose some of cloudflares protection but meh this domain serves a single thingBadr
Cloudflare has websockets now. did you every try to switch to it?Kinnikinnick
@Kinnikinnick sorry, only just noticed your comment. I think WS is for their enterprise plan so I have not yetBadr
It’s for all plans but at different levels of service. I’m on the $20 plan and it works fineKinnikinnick

© 2022 - 2024 — McMap. All rights reserved.