Bug 396559 - "digikam.dbengine: Database is locked." when scanning for new items.
Summary: "digikam.dbengine: Database is locked." when scanning for new items.
Status: RESOLVED FIXED
Alias: None
Product: digikam
Classification: Applications
Component: Database-Scan (show other bugs)
Version: 6.0.0
Platform: Microsoft Windows Microsoft Windows
: NOR normal
Target Milestone: ---
Assignee: Digikam Developers
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2018-07-16 08:53 UTC by MarcP
Modified: 2019-09-15 09:12 UTC (History)
3 users (show)

See Also:
Latest Commit:
Version Fixed In: 6.4.0
Sentry Crash Report:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description MarcP 2018-07-16 08:53:17 UTC
Every time digikam has to scan for new items (new pictures that have been copied to its watched folders), it takes a while to scan them. In debug view, I continuously see these messages for each new picture:

[18700] digikam.dimg: "Z:/Fotos/2018-07 My Holidays/IMG_6950.JPG"  : JPEG file identified
[18700] digikam.dbengine: Database is locked. Waited 7000
[18700] digikam.dbengine: Database is locked. Waited 6000
[18700] digikam.dbengine: Database is locked. Waited 7250
[18700] digikam.dbengine: Database is locked. Waited 6250
[18700] digikam.dbengine: Database is locked. Waited 7500
[18700] digikam.dbengine: Database is locked. Waited 6500
[18700] digikam.dbengine: Database is locked. Waited 7750
[18700] digikam.dbengine: Database is locked. Waited 6750
[18700] digikam.dbengine: Database is locked. Waited 8000
[18700] digikam.dbengine: Database is locked. Waited 7000
[18700] digikam.dbengine: Database is locked. Waited 8250
[18700] digikam.dbengine: Database is locked. Waited 7250
[18700] digikam.dbengine: Database is locked. Waited 8500
[18700] digikam.dbengine: Database is locked. Waited 7500
[18700] digikam.dbengine: Database is locked. Waited 8750
[18700] digikam.dbengine: Database is locked. Waited 7750
[18700] digikam.dbengine: Database is locked. Waited 9000
[18700] digikam.dbengine: Database is locked. Waited 8000
[18700] digikam.dbengine: Database is locked. Waited 9250
[18700] digikam.dbengine: Database is locked. Waited 8250
[18700] digikam.dbengine: Database is locked. Waited 9500
[18700] digikam.dbengine: Database is locked. Waited 8500
[18700] digikam.dbengine: Database is locked. Waited 9750
[18700] digikam.database: Adding new item "Z:/Fotos/2018-07 My Holidays/IMG_6950.JPG"

For what I see, it takes around 10 seconds to scan each new picture. Moreover, digikam's interface does not respond during that process, so for 400 new pictures, I estimate that it will take around an hour for digikam to become responsive before I can use it.

The database (SQLite) is currently stored in a network share, which could certainly affect the performance, but I remember this being an issue even when the pictures and the database were stored locally.

I am using the last digikam 6.0 snapshot for windows 10 64 bit.
Comment 1 Maik Qualmann 2018-07-18 12:52:28 UTC
I tried to simulate the problem with an SQlite database on a very slow USB stick. Yes, the scan of new images takes an extremely long time, over 10 seconds per image, but I can not reproduce a locked database. Can you describe how you added the images, via Windows Explorer or via digiKam? However, the problem will not be solved for us. SQlite needs this locked process and if another thread is still not finished after 10 seconds, digiKam can not change this. Combining all SQlite actions in an intermediate layer would not solve the problem either, since digiKam still stands still because it has to wait. SQlite does not belong on a remote drive, only locally, preferably on an SSD. Even on a local HDD, a locked database of 1-2 second can occur, with digiKam actions that require a lot of access.

Maik
Comment 2 MarcP 2018-07-18 12:56:41 UTC
The files (a whole folder of 400 pictures) was copied using windows explorer to its destination.

Is this a problem that only affects SQLite? Would changing to MySQL or another database avoid these waiting times?

Tell me if you want me to run some more tests. I could try scanning from a local folder, and also using a locally stored database.
Comment 3 Maik Qualmann 2019-04-04 18:05:19 UTC
*** Bug 406228 has been marked as a duplicate of this bug. ***
Comment 4 Ben 2019-04-09 18:51:56 UTC
In our case the database file is local. the lock error happens nevertheless.
Comment 5 Maik Qualmann 2019-04-09 19:01:38 UTC
A locked database is completely normal with SQLite. It is not possible to read and write from a SQLite database at the same time, an active write action must first be completed.

Maik
Comment 6 MarcP 2019-04-09 19:09:26 UTC
But isn´t there a way not to freeze the whole interface while scanning for new items? Bug #389652 is basically a consequence of this.

Ideally, you should be able to use Digikam even if it´s scanning for new items. Just like you can browse albums just fine while it´s writing metadata changes to files.

I don´t know exactly how it´s been implemented, but maybe giving a higher priority to user actions rather than the background new file scan, so when in conflict, the user has priority? Like pausing for a moment the scan of a file/folder and do what the user has requested in the interface, and then resume the scanning.

Or, as a last resort, tell the user that the interface won't be available during the scan. Otherwise, at least in Ubuntu, it constantly throws "Force close" messages to the user, which is not elegant.
Comment 7 Maik Qualmann 2019-04-10 19:55:10 UTC
The scanning process is a separate task that does not block the GUI. In this case it would help because of the locked database, with the digiKam database to switch to a local MySQL server.

Maik
Comment 8 Maik Qualmann 2019-09-15 09:12:25 UTC
Git commit e6e76cf0cf8b34f028511958070f98f457eef81a by Maik Qualmann.
Committed on 15/09/2019 at 06:47.
Pushed by mqualmann into branch 'master'.

less locked database during the initial scan
Related: bug 389949, bug 411927
FIXED-IN: 6.4.0

M  +3    -1    NEWS
M  +8    -4    core/libs/database/collection/collectionscanner_scan.cpp

https://invent.kde.org/kde/digikam/commit/e6e76cf0cf8b34f028511958070f98f457eef81a