Bug 335209

Summary: sqlite backend not selected automatically
Product: [Frameworks and Libraries] Akonadi Reporter: Ralf Jung <post>
Component: serverAssignee: kdepim bugs <kdepim-bugs>
Status: RESOLVED NOT A BUG    
Severity: normal CC: dvratil
Priority: NOR    
Version: 1.12.1   
Target Milestone: ---   
Platform: unspecified   
OS: Linux   
Latest Commit: Version Fixed In:
Sentry Crash Report:

Description Ralf Jung 2014-05-22 17:42:25 UTC
I decided to use the sqlite backend instead of the mysql backend to save system resources and startup time - I am not going to put much data into Akonadi anyway, so I don't want a full-blown mysql to run all the time.

Reproducible: Always

Steps to Reproduce:
1. Make sure sqlite is the only available backend
2. Make sure no akonadi process is running
3. delete ~/.config/akonadi and ~/.local/share/akonadi
4. Start akonadi
Actual Results:  
 It tries to start the mysql backend, which fails (as expected).
"akonadictl start" prints this error over and over (and a backtrace):

Found mysql_install_db:  "" 
Found mysqlcheck:  "/usr/bin/mysqlcheck" 
Did not find MySQL server default configuration (mysql-global.conf)

Expected Results:  
It should select the right backend (sqlite) automatically if it's the only installed backend.

After manually setting "Driver=QSQLITE3" in ~/.config/akonadi/akonadiserverrc, things work as expected.

I am running Debian testing amd64.
Comment 1 Daniel Vrátil 2014-05-28 09:17:44 UTC
When there's no configuration, Akonadi falls back to a default backend. The default backend can be defined during compilation, but when none is defined, it will choose MySQL. Most distributions don't change this (I only know about Fedora shipping Akonadi compiled with SQLite as default backend), so most users get MySQL automagically when they start Akonadi for the first time.

Falling back to another database backend is not a desired behavior. In case existing MySQL database fails to start for some reason and Akonadi would just fallback to SQLite and create a new SQLite database, which would just mess up KMail and other apps.


You can manually configure the backend in Akonadi Server Configuration KCM (kcmshell4 akonadi) and start Akonadi from there. You should not need to modify the config files by hand.
Comment 2 Ralf Jung 2014-05-28 17:40:05 UTC
(In reply to comment #1)
> You can manually configure the backend in Akonadi Server Configuration KCM
> (kcmshell4 akonadi) and start Akonadi from there. You should not need to
> modify the config files by hand.

That's good to know, thanks.