-
Notifications
You must be signed in to change notification settings - Fork 312
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
Auto-recover connection upon network connectivity issue #506
Comments
What do you mean by that? As soon as you're being disconnected you can try again, no?
Why is it important the error being thrown? Also, why are you using non-existing target ids? |
I can try reconnect, but if the disconnect reason was because the target closed, the reconnect attempts will always fail because there isn't such target-id anymore.
I'm not using non-existing target ids, one of the situation the disconnect callback is being triggered is when the target got closed and when I try reconnect to a target that got closed, I got the error above. |
IMHO after any disconnection (I can only think of Chrome or a tab being closed) the target id is no more valid. You shouldn't rely on that, rather every time rerun the code you're using to find/create the target you're going to interact with. |
The idea was to recover a connection to a specific target-id in case the websocket experienced network issue, is there a way I can query if the target-id still valid? |
You can obtain the list of all the available targets with |
Yes, this is what I've implemented today but it is not optimal, because in my use-case I have a lot of opened targets and on each disconnection I need to iterate on the entire list. |
I'm not sure I 100% understand your issue after all... I'm not fully aware of your setup but let's say that there are two kinds of problems that can happen:
In the former case you can just reconnect and use the same target IDs, in the latter you need to set up everything again, from scratch.
Why not just attempt the connection? See the following (simplified example): const CDP = require('chrome-remote-interface');
(async () => {
try {
const target = 'whatever ID from before';
const client = await CDP({target});
console.log('TODO resume your work here...');
} catch (err) {
console.log('cannot connect to target, starting anew');
try {
const {webSocketDebuggerUrl: browserTarget} = await CDP.Version();
const browserClient = await CDP({
target: browserTarget
});
const {targetId} = await browserClient.Target.createTarget({
url: 'https://example.com'
});
console.log(`TODO do stuff with the new target ${targetId}`);
} catch (err) {
console.log('Chrome is definitely gone');
}
}
})(); |
I'm trying to deal with #1 - the connectivity between the node that run the script and the one that hosts the Chrome instance breaks; When the connection breaks, the 'disconnect' event is being triggered: Now, once the callback is called, I would like to perform auto-reconnect logic (loop until reconnect successfully or timeout). To solve it, I've used CDP.List() and check if the target is still available before attempt to reconnect, but as I've mentioned above it's not optimal. If there was a specific error (like TargetNotFound) was thrown when CDP({target}) invoked, I can use it to break the loop instead of querying all target list. |
Note though, that said loop is performed anyway under the hood by the library when you pass a target id instead of a WebSocket URL: chrome-remote-interface/lib/chrome.js Lines 181 to 183 in cbd690f
This is because obtaining the WebSocket URL from a target id is something not documented AFAIK, and that most importantly, changes across implementations. If you know your implementation (and you do), you can directly attempt a connection to:
|
Hi,
I would like to make my CDP client resilient to network connectivity issues and I'm wondering what's the best way to achieve it.
It seems the disconnect callback is invoked when the target is closed or when the websocket disconnected, however the disconnection reason is not available and there is no way to know when should the auto-recovery need to retry.
Trying to reconnect to non-exists target-id causes the following error:
The text was updated successfully, but these errors were encountered: