-
Notifications
You must be signed in to change notification settings - Fork 894
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
RFC: Usage of experimentalForceLongPolling option. #1674
Comments
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
@mikelehen I have not been able to reproduce the issue myself, but generally users on Equinor/Statoil corporate network experience the issue, also some users with adblocker (VPN based i think) have reported this. I never deployed the setting to production because of the performance issues, so I am unable to confirm if it helps or not, but I have some users that can help testing when/if performance is improved. |
I did end up adding an option for the user to enable this manually, and have asked a few users to try it out, and it did indeed help with the issue, and they where able to use the application. So I hope this option is not removed, as it will help even if performance is lower. Not all my users have huge amount of documents. One user had issues on his Mac, same network as his phone (where it works). gist. One user is on a "high security" corporate network, gist. Behaviour without experimentalForceLongPolling, is no data is retrieved or being sent to firestore, but works when enabled. Hope it helps. Maybe it could be possible for firebase-js to detect when this is needed as a fallback? |
This comment has been minimized.
This comment has been minimized.
@tgangso Thanks very much for the data. We'll plan to keep the option around unless the problem stops happening or we devices a better solution (like automatic fallback). |
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
Hi. I cannot connect to firestore without experimentalForceLongPolling.
Thanks. |
Hello, we have a Firestore connection issue with one of our computers at work. The error message says "Firestore (6.3.0): Could not reach Cloud Firestore backend. Backend didn't respond within 10 seconds..." This issue doesn't occur on the other computers within the same network. Enabling ExperimentalForceLongPolling seems to resolve the issue. The problematic one is a Windows PC with "Symantec Endpoint Protection" installed. The others are all Mac computers without antivirus. Here's the gist: https://gist.github.com/dcc82/270cc8eac2f0fe312aa4ac8befad7925 Thanks. |
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
Hi,
With experimentalForceLongPolling set to true, the corporate environment works beautifully with excellent performance and responsiveness. The gist is here: https://gist.github.com/abrice/de6984ffb7361cf4c071d574e49eb552. Note, we only use the web (no mobile). So, the issue then becomes, is 'experimental' going to become 'production'? It seems very risky to proceed with a solution that may or may not be withdrawn at any time. The Firebase Auth/Firestore solution is truely impressive and ForceLongPolling works! Please move it to production status. |
@abrice Thanks for the feedback! The high-level answer is:
For your specific case, can you elaborate on "Bluecoat layers"? I guess Blue Coat Systems was acquired by Symantec and perhaps this is the current version of their proxy software: https://www.symantec.com/products/proxy-sg-and-advanced-secure-gateway ? It looks like it is known to cause problems do to SSL interception / proxying, e.g. with Windows Update and Office 365. So I'm not at all surprised it causes issues for Firestore as well, although interestingly this is the first report I've seen. I don't suppose you or your IT department would be interested in engaging with Symantec on this issue and see if it can be resolved? I'd be happy to participate in the discussion and provide technical details, etc. If you're interested, feel free to reach out / CC me at michael@firebase.com. Thanks! |
Any update on if it is possible to make it fall back automatically to forceLongPolling? I agree there are performance drawbacks, and should not be the default option. I get a few questions every week from users experiencing problems (mostly on corporate networks), and enabling this in the settings of my app always resolve it. |
Hi @mikelehen , The corporate runs O365 and has dealt with the challenges of Windows Updates. The network side is complex as there are a few other parties involved that provision various levels of proxy servers, anti-virus, load balancing, etc as-a-service. There's quite a lot of complex traffic moving about so, unfortunately, I can't help any further on pursuing a more in-depth technical examination. But it's excellent news about your approach to experimentalForceLongPolling. Thank you! |
@tgangso Adding a fallback mechanism is still on our radar but not something we're actively pursuing. Unfortunately it would be pretty complicated to add since it's hard to differentiate this case from being offline or even just on a slow network, so it's not obvious when to employ the fallback, etc. Right now we're still gathering feedback on the scope of the problem. Thanks! |
Hi @mikelehen I have been seeking help from Firebase Support, and after one and a half week we came up with changing the firestore settings to When using any website requesting data from Cloud Firestore, I am unable to use the site. On my own however, I enable the setting simply for me to be able to actually use it. |
@DJ-Shady02 Thank you for the information! Usually this issue only manifests in the face of specific corporate proxy or antivirus software, etc., so the fact that you're seeing it on two different computers and two different networks, even with disabling proxies / firewalls is unusual. I would still guess that there's some common factor that's causing it to happen, but it's hard to know what it might be. If by chance you're able to collect any more information that helps isolate the root cause (by trying from yet more devices including phones or tablets) or more networks (coffee shop, etc.), let us know. Thanks! |
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
@mikelehen Finally, I have an update! I have bought myself a new computer. Used Firestore for a month without issues. I install Bullguard, bam! Same issue as before. Being assured the issue was created by Bullguard, I contacted their support. It appears their "Safe Surfing" (The function name is translated from my native language, so it may vary), is causing the issue. Disabling it will trade a warning notification on sketchy websites with fully functional firestore without using forceLongPolling - worth it! While this is not directly helpful to you on the topic of the experimentalForceLongPolling option, it can help others avoid it. |
@DJ-Shady02 Thanks for the report! We're fairly certain that this problem isn't going away and are working on building logic into the SDK that will be able to automatically fall back on long polling. |
@sparkts-shaun looking through my notes from when this happened with one of my customers behind a Zscalar: From another SaaS vendor:
There may also have been an issue with the Zscaler requiring the Ultimately, the customer had to reach out to Zscalar for support, and I'm not sure I received a full explanation other than they had to update their configuration/rules. |
@bgetsug Thank you for the quick response! The customer is hesitant to implement a bypass rule for as broad a domain as firestore.googleapis.com, which was my initial suggestion to them. You may not be the person to ask, but do you have any concept what degree of performance impact the "experimentalLongPolling" flag introduces / at what scale it is noticeable? We would have to roll this out to all of our customers given our current infrastructure, and I'm hesitant to just flip that on. |
@sparkts-shaun Hi! Yes, it does looks like from your results that both "longpolling" flags would be able to resolve the issue for you :) Also, as per my understanding, Auto-detect long polling is already on by default since SDK 9.22: So far we haven't gotten any feedbacks about it having a negative impact on performance or reliability. So i think it should be rather safe if you're still on an earlier SDK and doesn't have it turned on yet :) (If you're on 9.22 onwards, there might be other issues at hand, like @bgetsug has indicated.) |
@sparkts-shaun, I understand your hesitance. I don't have experience enabling that flag, and I chose to avoid enabling it given it's "experimental," and the same customer did not have connectivity issues using our mobile app (with underlying native SDKs) on their network. In my case, I had to have a couple of conference calls with this particular customer's IT department and encourage them to get help with their Zscalar. I don't think they had to add an exception for the domain entirely, but they did have to "tune" their Zscalar configuration to not "mangle" the packets at hand. You could also foster more understanding about Firestore to help them better assess the perceived risk. I'd argue that while |
Hey! Thanks. Yes, every now and then I get the message in the console telling me the backend wasn't reached in time. However, in the network tab, there are only requests with a 200 status, except for one: 'https://firestore.googleapis.com/google.firestore.v1.Firestore/Listen/channel?VER=8&database=projects%...' (TYPE: terminate). Other than that, I have only successful requests even though the backend wasn't reached... Any thoughts on this? What request would you like to see exactly? Thank you so much for your help! |
Thanks a lot for the additional details! So you're saying that the "backend not reached" error is not consistent on your client, but rather sporadic? If so, it seems to indicates an issue that is NOT related to a buffering proxy, which normally remains a constant issue when there is one. And if so, the flag mentioned in this issue might not be able to help you. In terms of the network tab, i was originally thinking that you'd get a screenshot of all the requests related to the "Listen/channel" path as you've mentioned. That looks kinda like this (although the paths here are different): And in this case since you get a failed request, if you can gather all the HTTP Headers of the failed requests (either via screenshot or github gist), it could help with understanding the issue too.
You're most welcome and hope you have a great day too :) |
@bgetsug @sampajano For posterity, we have enabled the flag and haven't run into negative consequences so far, will update here if something goes awry. |
Hey @sampajano @cherylEnkidu, thanks for your feedback. I'm starting to think there's something wrong with my app instead, because I have 2 apps running on next that use different versions of NextJs. On the first app (that I don't use anymore and can't use for production), I never get the issue, but on the second app, that has a more recent version of Next and firebase, I sometimes get the issue. I'm starting to think it's probably due to the version of firebase I'm using, but I can't go back because the old versions don't work for some reason. There isn't much difference between the 2 apps. Both are aimed at the same backend, I don't know if that might be the problem? Anyway, the problem still persists, and I can't understand why, even more so now that I know it works on the other deprecated app... Any ideas? Finally after getting other occurrences where it didn't work, there's no failed request. Thank you so much again for your support honestly. |
@Great62 Thanks again for the detailed feedback and providing the links to your apps! It's very helpful!
This is very important information.. And rather telling.. Because Although, when i inspected the network traffic (on your App 2), i didn't see Can you try the following things? It would be best if you could try both, but even just doing one of them would provide good evidences:
My guess is, if your problem is indeed related to If neither is making a difference, then it means your issue might be hiding somewhere unrelated.. :) Hope that helps!!
You're very welcome. Hope you have a great day and holidays too! :) (I'll be on vacation for 3 weeks so i won't be replying in this time :)) |
I need to turn on |
@vietstone-ng Hi Thanks for informing us! May i ask what is your Firebase version? From what i understood, Thanks! |
@sampajano Hi, I use Firebase 10.9.0 |
@vietstone-ng Oh Thanks for confirming!! Could you confirm again that turning It would indicate some flag configuration issues if it's not actually on by default.. Thanks a lot! |
@sampajano I'm not sure if I wrote the correct code, because I'm a newbie with JS. # package.json
{
"name": "vite_firestore",
"private": true,
"version": "0.0.0",
"type": "module",
"scripts": {
"dev": "vite",
"build": "vite build",
"lint": "eslint . --ext js,jsx --report-unused-disable-directives --max-warnings 0",
"preview": "vite preview"
},
"dependencies": {
"firebase": "^10.9.0",
"react": "^18.2.0",
"react-dom": "^18.2.0"
},
"devDependencies": {
"@types/react": "^18.2.66",
"@types/react-dom": "^18.2.22",
"@vitejs/plugin-react": "^4.2.1",
"eslint": "^8.57.0",
"eslint-plugin-react": "^7.34.1",
"eslint-plugin-react-hooks": "^4.6.0",
"eslint-plugin-react-refresh": "^0.4.6",
"vite": "^5.2.0"
}
} // firebaseConfig.js
import firebase from 'firebase/compat/app';
import 'firebase/compat/firestore';
const firebaseConfig = {
...
};
firebase.initializeApp(firebaseConfig);
const firestore = firebase.firestore();
firebase.firestore().settings({ experimentalAutoDetectLongPolling: true});
firebase.firestore.setLogLevel('debug');
export default firestore; // FireStoreTest.jsx
import { useEffect } from 'react'
import firestore from './firebaseConfig'
function FireStoreTest() {
useEffect(() => {
const fetchData = async () => {
const collectionRef = firestore.collection('la')
try {
const snapshot = await collectionRef.get()
snapshot.forEach((doc) => {
console.log(doc.id, '=>', doc.data())
})
} catch (err) {
console.log('Error getting documents', err)
}
}
fetchData()
}, [])
return <div>{/* Your component content */}</div>
}
export default FireStoreTest In Below is the error log when I turned it off: [2024-04-10T04:21:49.907Z] @firebase/firestore: Firestore (10.9.0): Could not reach Cloud Firestore backend. Backend didn't respond within 10 seconds.
This typically indicates that your device does not have a healthy Internet connection at the moment. The client will operate in offline mode until it is able to successfully connect to the backend. |
@vietstone-ng Thanks for confirming!! This is slightly concerning to me because @wu-hui @dconeybe Hi Hui and Denver, could you help take a look and see whether the user is configuring his app correctly? Any theory on why Thanks! |
@vietstone-ng I see that your code is using |
@dconeybe Does this mean if you use the compact libraries that you are hard-coded to Firebase JS version 9.0.0 even if you upgrade it in your package.json? |
No. The latest version of the firebase-compat libraries use the latest version of the non-compat libraries under the hood. The compat libraries do, however, add a layer of indirection making debugging more difficult and, also, they are intended for a migration from the old API to the new API rather than something to use out of the gate. Also, I confirmed that using the "compat" libraries should have @vietstone-ng If you'd like us to continue investigation, please log a new issue and we will continue investigation there. What you are reporting is definitely not expected behavior. |
Is the debugging website still working as expected? I get a lot of failed tests.
|
hmm... Let me revisit it and make sure it's up-to-date. |
Thanks for the update @sampajano |
Are you experiencing the error
Could not reach Cloud Firestore backend. Backend didn't respond within 10 seconds
despite your network seeming healthy? Please visit https://debug-my.firebaseapp.com/ and check the results at the end. If the tests "with default options" fail (or are very slow) but the "with forceLongPolling" ones succeed, then this indicates your traffic is likely going through a proxy that is buffering responses in a way that is not compatible with Firestore.As a workaround, you can force long-polling as follows:
Have you enabled
experimentalForceLongPolling
andexperimentalAutoDetectLongPolling
to solve a reproducible connection issue related to a specific environment?We would like to know:
experimentalForceLongPolling
orexperimentalAutoDetectLongPolling
?experimentalAutoDetectLongPolling
completely resolve the issue?experimentalForceLongPolling
completely resolve the issue?If there is an existing comment concerning the environment you are using, feel free to just add a 👍 to it.
The text was updated successfully, but these errors were encountered: