Sqlite use in shiny apps deployed on posit connect
We are developing a large multi user application in shiny that uses duckdb and rsqlite databases. We are experiencing some issue that we believe are coming from multiple connections to the RSQLite database coming from the same process.
The issue
The symptoms are the freezing if it is in use, or a white screen on start up. We don't have admin access on posit connect so we can't debug and inspect the logs. Testing suggests that simultaneous writes to the RSQLite database are issue and setting max processes =1 in the application settings resolves this.
Question
Doing some research[1], it appears it is due to multiple connections to the same SQLite database.
It is possible to have multiple connections (max connections >1) to in the posit app?
I use SQLite a lot myself in app development and have used it successfully in hosted apps before, but there are indeed several caveats.
First as you know SQLite / DuckDB are file-based databases and not designed for efficient concurrent writing as there is no sophisticated DB management system monitoring anything (just file locking when writing). The use of the pool package is definitely something I would recommend as this will try and manage multiple connections to the database. Alternatively, databases like SQLite also allow you to increase the busy timeout to wait before erroring out using sqliteSetBusyHandler(). In the end this is still only useful if your app has a limited amount of users who need to write to the database. Otherwise you'll have to implement postgres or another management system.
Also a reminder that it's not trivial to getting data back from your database as a developer once it's on Posit Connect as you cannot easily access the files once they have been deployed.
Finally, are you sure you can't see the logs? Normally they are visible at the top of the screen when accessing an app the way you show in your screenshot.
To my understanding pool will take care of this. It will create a WAL for every transaction that writes to the database (or if you want to run several transactions before committing). During that time indeed other connections can't write to the database, but will after it has completed. So it depends on your code if this could cause delays for the user or not. Reading should not be impeded.
I'm not a real expert on the topic so keep that in mind when following my advice In general I think you can be creative with file-based databases but there is a point where you'll have to switch to a DMS is your app gets many connections or needs advances processing.