Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Using Browser-Sync / Html Config Proxy needs minutes to finish loading #475

Open
stevenengland opened this issue Mar 23, 2024 · 4 comments

Comments

@stevenengland
Copy link
Contributor

Hi folks,

I am using React for the admin part of a adapter. When I launch the dev-server with watch or debug --wait it needs minutes to load. A complete cycle looks like that:

image
image

As one can see the websocket is not able to establish a connection.

A few things I noticed:

Unfortunately I am not skilled in Browser-Sync at all so I don't have a clue what is wrong here.

A complete log until the connection succeeds is attached below.
localhost-1711220680850.log

@stevenengland
Copy link
Contributor Author

stevenengland commented Mar 23, 2024

One thing more that I noticed:
When I manipulate the client side socket.io options.connectTimeout like in the screenshot below (increased it to 10 seconds), the loading happens after a few seconds with success.

image

So: It seems that the React admin portion needs longer to load than the client side socket.io timeout allows.
Q1: Is it feasable, at least as a workaround, to increase the default connection timeout value for the client side socket-io?
Q2: How can the response time of the backend be improved so that the usual 2-3 seconds of timeout are just fine?

@stevenengland
Copy link
Contributor Author

Unfortunately I have to revert my last post. When I persist the connectTimout in the socket.io.js that is delivered by iobroker/admin (https://github.com/ioBroker/ioBroker.admin/blob/27c9de12993611797b0cd099ef42cef4c9952fb4/packages/admin/src/public/lib/js/socket.io.js#L82) then the error stays the same. But what remains is that whenever I activate a breakpoint like in the screenshot above, let the application hit it and then manually resume the process it works. So the pure fact that I am interrupting the flow with the help of a breakpoint is "repairing" the flow.

Further: If I start the dev-server with the --verbose flag (activating silly messages) and also the Browser-Sync with debug level logs (manually edited here

logLevel: 'info',
) I can see a few more messages before the websocket connection attempt is made but nothing more during the connection attempt or when the connection aborts.

I am poking around in the fog...

@stevenengland
Copy link
Contributor Author

More info:

When the HTML/React BrowserSync part starts up, the BrowserSync creation fails after 4 Minutes (each time):
image
Additionaly you can see that it takes a lot of websocket retries for the non admin part -> after the BrowserSync creation fails after 4 minutes the underlying next websocket request succeeds in contrast to all others before, when the creation of the BrowserSync was still in progress...
image

When choosing JSON Config BrowserSync then this BS instance immediately is created and the underlying websocket is connected.

@stevenengland
Copy link
Contributor Author

I further narrowed it down a little bit. It is highly connected to adapter-react-v5 usage.

What do I mean? --> To better analyse it I created a complete new adapter with React enabled with adapter-create. That one uses the older adapter-react. With that one I am able to start the dev-server without any issues.

The complete described behaviour from above occurs as fast as I manually switch to adapter-react-v5 like I did in a PR for adapter-create (ioBroker/create-adapter#1096). There I migrated with the help of the adapter-react-v5 readme and some reference repos. It is functional working. The error only occurs if BrowserSync comes into play. Can someone help me investigate this one a bit more deeply?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant