I am trying to save a blob > 1GB via relstorage in a sqlite backend. The following minimum working example
Minimum Working Example:
import os
import shutil
from ZODB import blob, config
connectionString = """
%import relstorage
<zodb main>
<relstorage>
blob-dir blob
keep-history false
cache-local-mb 0
<sqlite3>
data-dir .
</sqlite3>
</relstorage>
</zodb>
"""
# cleaning up
for x in os.listdir():
if "sqlite" in x:
os.remove(x)
shutil.rmtree("blob", True)
# creating database
db = config.databaseFromString(connectionString)
with db.transaction() as conn:
conn.root.blob = blob.Blob()
with conn.root.blob.open("w") as f:
f.write(b"\0" * 1024 ** 3)
During the commit (at the __exit__
method of the db.transaction with-block) of the newly created object an error occurs with the following final exception:
sqlite3.InterfaceError: Error binding parameter 2 - probably unsupported type.
Saving a blob with size 1024 ** 2
does not raise the exception.
How is it possible to save a blob in a sqlite backend using relstorage without the usage of a shared blob directory?
According to my research, you can't store arbitrary sized blobs in this setup. You are hitting the sqlite blob size limit (https://www.sqlite.org/limits.html).
Your only options at this stage appear to be:
Personally, I would be inclined to use the shared blob directory if I was using sqlite, but you have discounted that option, so I think your choices are limited.