|
|
|
|
|
by chii
1403 days ago
|
|
but now transactional guarantees only extend to the id stored in the DB, and not on the external storage. Therefore, it's possible that the id is invalid (for the external storage) when referenced in the future. I think doing so only adds complexity as system grows. It would be better to chunk your blob data to fit the DB, imho. It beats introducing external blob storage in the long run. |
|
Depends! If the ID is a cryptographic hash, then as long as the blob is uploaded first, then the DB can't be inconsistent with the blob[1].
A Merkle Tree also allows "updates" by chunking the data into some convenient size, say 64 MB, and then building a new tree for each update and sticking that into the database.
[1] With the usual caveats that nobody is manually mucking about with the blob store, that it hasn't "lost" any blobs due to corruption, etc, etc...