-
Notifications
You must be signed in to change notification settings - Fork 43
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
syncing an entity with large # objects causes server error #132
Comments
You are not using websocks, are you? |
No. |
You should! |
And that would alleviate this issue...? |
@Rollaway Yes, the HTTP interface for Simperium will soon be deprecated. We strongly recommend enabling websockets in the latest develop branch: Sorry this wasn't clear. We'll be doing this and updating docs in the coming weeks. Could you please try doing this and confirm it fixes your problem? |
@mikejohnstn I made the change and I no longer get the same POST error. But it still appears to be doing the same thing in that after a certain number of objects are synced, the JSON String saved to NSUserDefaults as changesPending- doesn't get smaller as you would expect as the objects are synced. It does at first then stays the same at around 1200 objects processed. It just keeps spinning through the change processor until memory is exhausted and the app crashes. Let me know if you'd like to see logs or parts of a log (they get large fast!). |
Thanks @Rollaway. With 1200 offline objects, there are going to be performance/memory issues with NSUserDefaults access. @jleandroperez could you add this as a test at some point to see if we can reproduce the crash? We have #124 to move metadata storage to the database. Once that's fixed, I believe this will be fixed as well, but let's leave this open as a reminder. |
Good stuff...thanks @mikejohnstn! |
@Rollaway i'll be working on a unit test this week, perhaps we can reproduce this crash. Just in case, did you get a crashlog generated?. Did you get any low memory warnings? or it was a bad access crash?. Thanks! |
Memory gets exhausted fast indeed. Testing on an iPad mini, with 4000 objects, 2000 in each entity, in no time it hits almost 200MB of live bytes and shortly after this it crashes. |
@Rjonhson Sounds fair enough. I'll be working on this ASAP, perhaps we've got a retain cycle somewhere (the whole project has gone ARC enabled just a couple weeks ago!). Thanks for the feedback! |
@jleandroperez Alright! let me know if you need anything! |
You guys are great! Thanks for getting right on this...and let me know if you need any logs, etc. |
We'll be working on merging the 'Memory Footprint' pull request, in the next couple weeks. @Rollaway please, if you're still experiencing any "413 Request Entity Too Large" erros, just let us know. Thanks! |
When authentication and / or networking is turned off and objects managed by simperium are created, enabling authentication and networking later may generate an error caused by simperium trying to sync that entity in a single POST. If the number of objects is large enough, the POST becomes too large for the server to handle and a "413 Request Entity Too Large" error is returned while simperium continues to try sending.
The text was updated successfully, but these errors were encountered: