-
Notifications
You must be signed in to change notification settings - Fork 243
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
Support memory open mode (was: More DB open methods possible?) #256
Comments
You can update the database on disk without synchronizing the rest of the system. The file just needs to be replaced atomically. This is what |
I suppose, but then you have to make sure all of your automated tooling will actually do this correctly. Where as if the C version supported the same MEMORY mode that the java version of the library does then it could all be avoided by letting the program using the library handle the file/memory management Just seems like it would open up the library to more flexible implementations |
Thanks. I'll leave this issue open as a feature request. There was some work on a shared memory mode 8+ years ago in the https://github.com/maxmind/libmaxminddb/tree/dave/shared-memory branch. There didn't seem to be that much interest in it at the time though, and so work was abandoned. Note that even if the reader is loading the database into memory, it is strongly recommended that the file be replaced atomically unless you know that there is no chance that the database could be reopened by the application while it is being updated. |
Is there more to it than skipping the mmap and setting the pointers in the MMDB_s structure? |
I haven't examined the code, but assuming we are just being passed in a buffer and size, I don't suspect that many changes would be necessary. |
Hi @oschwald - I was trying to achieve this behavior but it seems the |
If you are updating the file atomically, the reader would continue to have the old file MMAP'd. You would need to reopen the database to get the new file. If you have follow-up questions, it might be best to create a new issue. This is pretty far removed from a memory-open mode. |
It would be good if there were other methods available to open besides mmap'ing a file. We have integrated this into apache trafficserver (and I know other projects use it) but since the only way to load a db file is via mmap then that means you cant have any other automated tooling update databases on disk without synchronizing the rest of the system (and forcing downtime of applications dependent on mmdb since they must be stopped and forced to close db's before touching the file) to that, otherwise you may cause a crash due to the mmap'd file.
If there was a way to load via a buffer+size, or just any other sort of method that isnt directly referencing the on-disk file in the library, that could help alleviate this.
The text was updated successfully, but these errors were encountered: