Bug 333736 (ibdata1)

Summary: Akonadi server doesn't start (internal Mysql backend)
Product: [Frameworks and Libraries] Akonadi Reporter: Hatl <hatl>
Component: serverAssignee: kdepim bugs <kdepim-bugs>
Status: RESOLVED FIXED    
Severity: normal CC: dvratil
Priority: NOR    
Version: 1.12.1   
Target Milestone: ---   
Platform: Ubuntu   
OS: Linux   
Latest Commit: Version Fixed In:
Sentry Crash Report:
Attachments: mysqld.conf
akonadiserverrc

Description Hatl 2014-04-22 18:56:01 UTC
I upgraded KDE to 4.13. (while upgrading Ubuntu from 13.10 to 14.04)
Now, Akonadi doesn't start.
Several concurrent Mysql deamons are being started:

gerhard   3629  1.0  0.3 450520 29424 ?        Sl   20:53   0:00 /usr/sbin/mysqld --defaults-file=/home/gerhard/.local/share/akonadi/mysql.conf --datadir=/home/gerhard/.local/share/akonadi/db_data/ --socket=/tmp/akonadi-gerhard.AYV9yA/mysql.socket
gerhard   3658  0.0  0.2 281932 19008 ?        Sl   20:53   0:00 /usr/sbin/mysqld --defaults-file=/home/gerhard/.local/share/akonadi/mysql.conf --datadir=/home/gerhard/.local/share/akonadi/db_data/ --socket=/tmp/akonadi-gerhard.AYV9yA/mysql.socket
gerhard   3676  0.0  0.2 281932 19008 ?        Sl   20:53   0:00 /usr/sbin/mysqld --defaults-file=/home/gerhard/.local/share/akonadi/mysql.conf --datadir=/home/gerhard/.local/share/akonadi/db_data/ --socket=/tmp/akonadi-gerhard.AYV9yA/mysql.socket
gerhard   3694  0.0  0.2 281932 19008 ?        Sl   20:53   0:00 /usr/sbin/mysqld --defaults-file=/home/gerhard/.local/share/akonadi/mysql.conf --datadir=/home/gerhard/.local/share/akonadi/db_data/ --socket=/tmp/akonadi-gerhard.AYV9yA/mysql.socket


Here's the test report:
Akonadi Server Self-Test Report
===============================

Test 1:  SUCCESS
--------

Database driver found.
Details: The QtSQL driver 'QMYSQL' is required by your current Akonadi server configuration and was found on your system.

File content of '/home/gerhard/.config/akonadi/akonadiserverrc':
[QMYSQL]
StartServer=true
ServerPath=/usr/sbin/mysqld
Name=akonadi
Host=localhost
User=
Password=
Options="UNIX_SOCKET=/tmp/akonadi-gerhard.AYV9yA/mysql.socket"

[QPSQL]
Name=akonadi
Host=
User=
Password=
Port=5432

[%General]
Driver=QMYSQL

[Debug]
Tracer=null


Test 2:  SUCCESS
--------

Akonadi is not running as root
Details: Akonadi is not running as a root/administrator user, which is the recommended setup for a secure system.

Test 3:  SUCCESS
--------

MySQL server found.
Details: You have currently configured Akonadi to use the MySQL server '/usr/sbin/mysqld'.
Make sure you have the MySQL server installed, set the correct path and ensure you have the necessary read and execution rights on the server executable. The server executable is typically called 'mysqld'; its location varies depending on the distribution.

Test 4:  SUCCESS
--------

MySQL server is executable.
Details: MySQL server found: 140422 20:50:08 [Warning] Using unique option prefix key_buffer instead of key_buffer_size is deprecated and will be removed in a future release. Please use the full name instead.
/usr/sbin/mysqld  Ver 5.5.35-1ubuntu1 for debian-linux-gnu on x86_64 ((Ubuntu))


Test 5:  ERROR
--------

MySQL server log contains errors.
Details: The MySQL server error log file &apos;<a href='/home/gerhard/.local/share/akonadi/db_data/mysql.err'>/home/gerhard/.local/share/akonadi/db_data/mysql.err</a>&apos; contains errors.

File content of '/home/gerhard/.local/share/akonadi/db_data/mysql.err':
140422 20:46:49 [Note] Plugin 'FEDERATED' is disabled.
140422 20:46:49 InnoDB: The InnoDB memory heap is disabled
140422 20:46:49 InnoDB: Mutexes and rw_locks use GCC atomic builtins
140422 20:46:49 InnoDB: Compressed tables use zlib 1.2.8
140422 20:46:49 InnoDB: Using Linux native AIO
140422 20:46:49 InnoDB: Initializing buffer pool, size = 80.0M
140422 20:46:49 InnoDB: Completed initialization of buffer pool
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
140422 20:46:49  InnoDB: Retrying to lock the first data file
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
InnoDB: Unable to lock ./ibdata1, error: 11
InnoDB: Check that you do not already have another mysqld process
InnoDB: using the same InnoDB data or log files.
140422 20:47:22 InnoDB: highest supported file format is Barracuda.
140422 20:47:22  InnoDB: Waiting for the background threads to start
140422 20:47:23 InnoDB: 5.5.35 started; log sequence number 2291518
140422 20:47:23 [Note] /usr/sbin/mysqld: Normal shutdown

140422 20:47:23 [Warning] Can't open and lock time zone table: Table 'mysql.time_zone_leap_second' doesn't exist trying to live without them
140422 20:47:23 [ERROR] Can't open and lock privilege tables: Table 'mysql.servers' doesn't exist
140422 20:47:23 [ERROR] Native table 'performance_schema'.'events_waits_current' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'events_waits_history' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'events_waits_history_long' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'setup_consumers' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'setup_instruments' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'setup_timers' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'performance_timers' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'threads' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'events_waits_summary_by_thread_by_event_name' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'events_waits_summary_by_instance' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'events_waits_summary_global_by_event_name' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'file_summary_by_event_name' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'file_summary_by_instance' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'mutex_instances' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'rwlock_instances' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'cond_instances' has the wrong structure
140422 20:47:23 [ERROR] Native table 'performance_schema'.'file_instances' has the wrong structure
140422 20:47:23 [Note] /usr/sbin/mysqld: ready for connections.
Version: '5.5.35-1ubuntu1'  socket: '/tmp/akonadi-gerhard.AYV9yA/mysql.socket'  port: 0  (Ubuntu)
140422 20:47:23  InnoDB: Starting shutdown...
140422 20:47:24  InnoDB: Shutdown completed; log sequence number 2291518
140422 20:47:24 [Note] /usr/sbin/mysqld: Shutdown complete



Test 6:  SUCCESS
--------

MySQL server default configuration found.
Details: The default configuration for the MySQL server was found and is readable at <a href='/etc/akonadi/mysql-global.conf'>/etc/akonadi/mysql-global.conf</a>.

File content of '/etc/akonadi/mysql-global.conf':
#
# Global Akonadi MySQL server settings,
# These settings can be adjusted using $HOME/.config/akonadi/mysql-local.conf
#
# Based on advice by Kris Köhntopp <kris@mysql.com>
#
[mysqld]

# strict query parsing/interpretation
# TODO: make Akonadi work with those settings enabled
# sql_mode=strict_trans_tables,strict_all_tables,strict_error_for_division_by_zero,no_auto_create_user,no_auto_value_on_zero,no_engine_substitution,no_zero_date,no_zero_in_date,only_full_group_by,pipes_as_concat
# sql_mode=strict_trans_tables

# DEBUGGING:
# log all queries, useful for debugging but generates an enormous amount of data
# log=mysql.full
# log queries slower than n seconds, log file name relative to datadir (for debugging only)
# log_slow_queries=mysql.slow
# long_query_time=1
# log queries not using indices, debug only, disable for production use
# log_queries_not_using_indexes=1
#
# mesure database size and adjust innodb_buffer_pool_size
# SELECT sum(data_length) as bla, sum(index_length) as blub FROM information_schema.tables WHERE table_schema not in ("mysql", "information_schema");

# NOTES:
# Keep Innob_log_waits and keep Innodb_buffer_pool_wait_free small (see show global status like "inno%", show global variables)

#expire_logs_days=3

#sync_bin_log=0

# Use UTF-8 encoding for tables
character_set_server=utf8
collation_server=utf8_general_ci

# use InnoDB for transactions and better crash recovery
default_storage_engine=innodb

# memory pool InnoDB uses to store data dictionary information and other internal data structures (default:1M)
# Deprecated in MySQL >= 5.6.3
innodb_additional_mem_pool_size=1M

# memory buffer InnoDB uses to cache data and indexes of its tables (default:128M)
# Larger values means less I/O
innodb_buffer_pool_size=80M

# Create a .ibd file for each table (default:0)
innodb_file_per_table=1

# Write out the log buffer to the log file at each commit (default:1)
innodb_flush_log_at_trx_commit=2

# Buffer size used to write to the log files on disk (default:1M for builtin, 8M for plugin)
# larger values means less I/O
innodb_log_buffer_size=1M

# Size of each log file in a log group (default:5M) larger means less I/O but more time for recovery.
innodb_log_file_size=64M

# # error log file name, relative to datadir (default:hostname.err)
log_error=mysql.err

# print warnings and connection errors (default:1)
log_warnings=2

# Convert table named to lowercase
lower_case_table_names=1

# Maximum size of one packet or any generated/intermediate string. (default:1M)
max_allowed_packet=32M

# Maximum simultaneous connections allowed (default:100)
max_connections=256

# The two options below make no sense with prepared statements and/or transactions
# (make sense when having the same query multiple times)

# Memory allocated for caching query results (default:0 (disabled))
query_cache_size=0

# Do not cache results (default:1)
query_cache_type=0

# Do not use the privileges mechanisms
skip_grant_tables

# Do not listen for TCP/IP connections at all
skip_networking

# The number of open tables for all threads. (default:64)
table_open_cache=200

# How many threads the server should cache for reuse (default:0)
thread_cache_size=3

# wait 365d before dropping the DB connection (default:8h)
wait_timeout=31536000

# We use InnoDB, so don't let MyISAM eat up memory
key_buffer_size=16K

[client]
default-character-set=utf8


Test 7:  SKIP
--------

MySQL server custom configuration not available.
Details: The custom configuration for the MySQL server was not found but is optional.

Test 8:  SUCCESS
--------

MySQL server configuration is usable.
Details: The MySQL server configuration was found at <a href='/home/gerhard/.local/share/akonadi/mysql.conf'>/home/gerhard/.local/share/akonadi/mysql.conf</a> and is readable.

File content of '/home/gerhard/.local/share/akonadi/mysql.conf':
#
# Global Akonadi MySQL server settings,
# These settings can be adjusted using $HOME/.config/akonadi/mysql-local.conf
#
# Based on advice by Kris Köhntopp <kris@mysql.com>
#
[mysqld]

# strict query parsing/interpretation
# TODO: make Akonadi work with those settings enabled
# sql_mode=strict_trans_tables,strict_all_tables,strict_error_for_division_by_zero,no_auto_create_user,no_auto_value_on_zero,no_engine_substitution,no_zero_date,no_zero_in_date,only_full_group_by,pipes_as_concat
# sql_mode=strict_trans_tables

# DEBUGGING:
# log all queries, useful for debugging but generates an enormous amount of data
# log=mysql.full
# log queries slower than n seconds, log file name relative to datadir (for debugging only)
# log_slow_queries=mysql.slow
# long_query_time=1
# log queries not using indices, debug only, disable for production use
# log_queries_not_using_indexes=1
#
# mesure database size and adjust innodb_buffer_pool_size
# SELECT sum(data_length) as bla, sum(index_length) as blub FROM information_schema.tables WHERE table_schema not in ("mysql", "information_schema");

# NOTES:
# Keep Innob_log_waits and keep Innodb_buffer_pool_wait_free small (see show global status like "inno%", show global variables)

#expire_logs_days=3

#sync_bin_log=0

# Use UTF-8 encoding for tables
character_set_server=utf8
collation_server=utf8_general_ci

# use InnoDB for transactions and better crash recovery
default_storage_engine=innodb

# memory pool InnoDB uses to store data dictionary information and other internal data structures (default:1M)
# Deprecated in MySQL >= 5.6.3
innodb_additional_mem_pool_size=1M

# memory buffer InnoDB uses to cache data and indexes of its tables (default:128M)
# Larger values means less I/O
innodb_buffer_pool_size=80M

# Create a .ibd file for each table (default:0)
innodb_file_per_table=1

# Write out the log buffer to the log file at each commit (default:1)
innodb_flush_log_at_trx_commit=2

# Buffer size used to write to the log files on disk (default:1M for builtin, 8M for plugin)
# larger values means less I/O
innodb_log_buffer_size=1M

# Size of each log file in a log group (default:5M) larger means less I/O but more time for recovery.
innodb_log_file_size=64M

# # error log file name, relative to datadir (default:hostname.err)
log_error=mysql.err

# print warnings and connection errors (default:1)
log_warnings=2

# Convert table named to lowercase
lower_case_table_names=1

# Maximum size of one packet or any generated/intermediate string. (default:1M)
max_allowed_packet=32M

# Maximum simultaneous connections allowed (default:100)
max_connections=256

# The two options below make no sense with prepared statements and/or transactions
# (make sense when having the same query multiple times)

# Memory allocated for caching query results (default:0 (disabled))
query_cache_size=0

# Do not cache results (default:1)
query_cache_type=0

# Do not use the privileges mechanisms
skip_grant_tables

# Do not listen for TCP/IP connections at all
skip_networking

# The number of open tables for all threads. (default:64)
table_open_cache=200

# How many threads the server should cache for reuse (default:0)
thread_cache_size=3

# wait 365d before dropping the DB connection (default:8h)
wait_timeout=31536000

# We use InnoDB, so don't let MyISAM eat up memory
key_buffer_size=16K

[client]
default-character-set=utf8


Test 9:  SUCCESS
--------

akonadictl found and usable
Details: The program '/usr/bin/akonadictl' to control the Akonadi server was found and could be executed successfully.
Result:
Akonadi 1.12.1


Test 10:  ERROR
--------

Akonadi control process not registered at D-Bus.
Details: The Akonadi control process is not registered at D-Bus which typically means it was not started or encountered a fatal error during startup.

Test 11:  ERROR
--------

Akonadi server process not registered at D-Bus.
Details: The Akonadi server process is not registered at D-Bus which typically means it was not started or encountered a fatal error during startup.

Test 12:  SKIP
--------

Protocol version check not possible.
Details: Without a connection to the server it is not possible to check if the protocol version meets the requirements.

Test 13:  ERROR
--------

No resource agents found.
Details: No resource agents have been found, Akonadi is not usable without at least one. This usually means that no resource agents are installed or that there is a setup problem. The following paths have been searched: '/usr/share/akonadi/agents'. The XDG_DATA_DIRS environment variable is set to '/usr/share:/usr/share/kde-plasma:/usr/local/share/:/usr/share/'; make sure this includes all paths where Akonadi agents are installed.

Directory listing of '/usr/share/akonadi/agents':
akonadibalooindexingagent.desktop
akonadinepomukfeederagent.desktop
akonotesresource.desktop
archivemailagent.desktop
birthdaysresource.desktop
contactsresource.desktop
davgroupwareresource.desktop
facebookresource.desktop
folderarchiveagent.desktop
gcalresource.desktop
googlecalendarresource.desktop
googlecontactsresource.desktop
googledataresource.desktop
icaldirresource.desktop
icalresource.desktop
imapresource.desktop
invitationsagent.desktop
kabcresource.desktop
kalarmdirresource.desktop
kalarmresource.desktop
kcalresource.desktop
kdeaccountsresource.desktop
kolabproxyresource.desktop
localbookmarksresource.desktop
maildirresource.desktop
maildispatcheragent.desktop
mailfilteragent.desktop
mboxresource.desktop
migrationagent.desktop
mixedmaildirresource.desktop
mtdummyresource.desktop
newmailnotifieragent.desktop
nntpresource.desktop
notesagent.desktop
notesresource.desktop
openxchangeresource.desktop
pop3resource.desktop
sendlateragent.desktop
vcarddirresource.desktop
vcardresource.desktop

Environment variable XDG_DATA_DIRS is set to '/usr/share:/usr/share/kde-plasma:/usr/local/share/:/usr/share/'

Test 14:  ERROR
--------

Current Akonadi server error log found.
Details: The Akonadi server reported errors during its current startup. The log can be found in <a href='/home/gerhard/.local/share/akonadi/akonadiserver.error'>/home/gerhard/.local/share/akonadi/akonadiserver.error</a>.

File content of '/home/gerhard/.local/share/akonadi/akonadiserver.error':
"
Sql error: Can't create table 'akonadi.tagremoteidresourcerelationtable' (errno: 150) QMYSQL: Unable to execute query
Query: CREATE TABLE TagRemoteIdResourceRelationTable (tagId BIGINT NOT NULL, resourceId BIGINT NOT NULL, remoteId VARBINARY(255) NOT NULL, FOREIGN KEY (tagId) REFERENCES TagTable(id) ON UPDATE CASCADE ON DELETE CASCADE, FOREIGN KEY (resourceId) REFERENCES ResourceTable(id) ON UPDATE CASCADE ON DELETE CASCADE)  COLLATE=utf8_general_ci DEFAULT CHARSET=utf8" 
Unable to initialize database. 
"[
0: akonadiserver() [0x419cb7]
1: akonadiserver() [0x419f12]
2: /lib/x86_64-linux-gnu/libc.so.6(+0x36ff0) [0x7f90e020bff0]
3: /lib/x86_64-linux-gnu/libc.so.6(gsignal+0x39) [0x7f90e020bf79]
4: /lib/x86_64-linux-gnu/libc.so.6(abort+0x148) [0x7f90e020f388]
5: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_Z17qt_message_output9QtMsgTypePKc+0x102) [0x7f90e1cf3c92]
6: akonadiserver() [0x41bdbd]
7: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN9QIODevice5writeEPKcx+0xb0) [0x7f90e1d8e470]
8: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(+0x11ab3d) [0x7f90e1d9db3d]
9: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN11QTextStreamD1Ev+0x31) [0x7f90e1da6721]
10: akonadiserver() [0x41f72b]
11: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN7QObject5eventEP6QEvent+0x24e) [0x7f90e1e18c1e]
12: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN16QCoreApplication14notifyInternalEP7QObjectP6QEvent+0x6d) [0x7f90e1e004dd]
13: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN23QCoreApplicationPrivate16sendPostedEventsEP7QObjectiP11QThreadData+0x1ed) [0x7f90e1e03b3d]
14: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(+0x1aaf83) [0x7f90e1e2df83]
15: /lib/x86_64-linux-gnu/libglib-2.0.so.0(g_main_context_dispatch+0x254) [0x7f90df8dae04]
16: /lib/x86_64-linux-gnu/libglib-2.0.so.0(+0x49048) [0x7f90df8db048]
17: /lib/x86_64-linux-gnu/libglib-2.0.so.0(g_main_context_iteration+0x2c) [0x7f90df8db0ec]
18: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN20QEventDispatcherGlib13processEventsE6QFlagsIN10QEventLoop17ProcessEventsFlagEE+0x71) [0x7f90e1e2d7a1]
19: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN10QEventLoop13processEventsE6QFlagsINS_17ProcessEventsFlagEE+0x2f) [0x7f90e1dff0af]
20: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN10QEventLoop4execE6QFlagsINS_17ProcessEventsFlagEE+0x175) [0x7f90e1dff3a5]
21: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN16QCoreApplication4execEv+0x89) [0x7f90e1e04b79]
22: akonadiserver() [0x4142e7]
23: /lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf5) [0x7f90e01f6ec5]
24: akonadiserver() [0x414c48]
]
" 


Test 15:  ERROR
--------

Previous Akonadi server error log found.
Details: The Akonadi server reported errors during its previous startup. The log can be found in <a href='/home/gerhard/.local/share/akonadi/akonadiserver.error.old'>/home/gerhard/.local/share/akonadi/akonadiserver.error.old</a>.

File content of '/home/gerhard/.local/share/akonadi/akonadiserver.error.old':
"
Sql error: Can't create table 'akonadi.tagremoteidresourcerelationtable' (errno: 150) QMYSQL: Unable to execute query
Query: CREATE TABLE TagRemoteIdResourceRelationTable (tagId BIGINT NOT NULL, resourceId BIGINT NOT NULL, remoteId VARBINARY(255) NOT NULL, FOREIGN KEY (tagId) REFERENCES TagTable(id) ON UPDATE CASCADE ON DELETE CASCADE, FOREIGN KEY (resourceId) REFERENCES ResourceTable(id) ON UPDATE CASCADE ON DELETE CASCADE)  COLLATE=utf8_general_ci DEFAULT CHARSET=utf8" 
Unable to initialize database. 
"[
0: akonadiserver() [0x419cb7]
1: akonadiserver() [0x419f12]
2: /lib/x86_64-linux-gnu/libc.so.6(+0x36ff0) [0x7f202b598ff0]
3: /lib/x86_64-linux-gnu/libc.so.6(gsignal+0x39) [0x7f202b598f79]
4: /lib/x86_64-linux-gnu/libc.so.6(abort+0x148) [0x7f202b59c388]
5: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_Z17qt_message_output9QtMsgTypePKc+0x102) [0x7f202d080c92]
6: akonadiserver() [0x41bdbd]
7: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN9QIODevice5writeEPKcx+0xb0) [0x7f202d11b470]
8: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(+0x11ab3d) [0x7f202d12ab3d]
9: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN11QTextStreamD1Ev+0x31) [0x7f202d133721]
10: akonadiserver() [0x41f72b]
11: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN7QObject5eventEP6QEvent+0x24e) [0x7f202d1a5c1e]
12: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN16QCoreApplication14notifyInternalEP7QObjectP6QEvent+0x6d) [0x7f202d18d4dd]
13: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN23QCoreApplicationPrivate16sendPostedEventsEP7QObjectiP11QThreadData+0x1ed) [0x7f202d190b3d]
14: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(+0x1aaf83) [0x7f202d1baf83]
15: /lib/x86_64-linux-gnu/libglib-2.0.so.0(g_main_context_dispatch+0x254) [0x7f202ac67e04]
16: /lib/x86_64-linux-gnu/libglib-2.0.so.0(+0x49048) [0x7f202ac68048]
17: /lib/x86_64-linux-gnu/libglib-2.0.so.0(g_main_context_iteration+0x2c) [0x7f202ac680ec]
18: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN20QEventDispatcherGlib13processEventsE6QFlagsIN10QEventLoop17ProcessEventsFlagEE+0x71) [0x7f202d1ba7a1]
19: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN10QEventLoop13processEventsE6QFlagsINS_17ProcessEventsFlagEE+0x2f) [0x7f202d18c0af]
20: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN10QEventLoop4execE6QFlagsINS_17ProcessEventsFlagEE+0x175) [0x7f202d18c3a5]
21: /usr/lib/x86_64-linux-gnu/libQtCore.so.4(_ZN16QCoreApplication4execEv+0x89) [0x7f202d191b79]
22: akonadiserver() [0x4142e7]
23: /lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf5) [0x7f202b583ec5]
24: akonadiserver() [0x414c48]
]
" 


Test 16:  SUCCESS
--------

No current Akonadi control error log found.
Details: The Akonadi control process did not report any errors during its current startup.

Test 17:  SUCCESS
--------

No previous Akonadi control error log found.
Details: The Akonadi control process did not report any errors during its previous startup.

Reproducible: Always

Steps to Reproduce:
1. Tried to start Akonadi server
Comment 1 Hatl 2014-04-22 18:56:51 UTC
Created attachment 86216 [details]
mysqld.conf
Comment 2 Hatl 2014-04-22 18:58:18 UTC
Created attachment 86217 [details]
akonadiserverrc
Comment 3 Hatl 2014-04-22 19:00:15 UTC
I already tried killing all mysqld processes and restarting akonadi.
Also tried to remove the mysqld.conf.
Comment 4 Daniel Vrátil 2014-04-23 07:03:52 UTC
Looks like a MySQL issue. Please check that you haven't run out of disk space, make sure that file ~/.local/share/akonadi/db_data/ibdata1 (and all other files in that directory) are owned by your user and group and have at least -rw-rw--- rights and that the directory itself is writeable.

Finally, try the following:
cp ~/.local/share/akonadi/db_data/ibdata1{,.backup}
mv ~/.local/share/akonadi/db_data/ibdata1{,.mv}
cp -a ~/.local/share/akonadi/db_data/ibdata1{.mv,}

(Found on the internet, reported by users to solve the "can't get ibdata1 lock" problem.
Comment 5 Hatl 2014-04-23 16:16:05 UTC
Thanks for your reply!

There is plenty of disk space left (13GB)
The file premissions are: -rw-rw---

The mv/cp didn't help.

I also ruled out AppArmor:
3 processes are in complain mode.
   /usr/sbin/mysqld (1596)
   /usr/sbin/mysqld (5612)
   /usr/sbin/mysqld (5638)
Comment 6 Hatl 2014-04-23 16:25:51 UTC
Ubuntu just got an update from mysql 5.5.35 to 5.5.37.
Didn't change anything.
Comment 8 Hatl 2014-04-24 17:53:03 UTC
Sql error: Can't create table 'akonadi.tagremoteidresourcerelationtable' (errno: 150) QMYSQL: Unable to execute query
Query: CREATE TABLE TagRemoteIdResourceRelationTable (tagId BIGINT NOT NULL, resourceId BIGINT NOT NULL, remoteId VARBINARY(255) NOT NULL, FOREIGN KEY (tagId) REFERENCES TagTable(id) ON UPDATE CASCADE ON DELETE CASCADE, FOREIGN KEY (resourceId) REFERENCES ResourceTable(id) ON UPDATE CASCADE ON DELETE CASCADE)  COLLATE=utf8_general_ci DEFAULT CHARSET=utf8"

The query works when I remove
FOREIGN KEY (resourceId) REFERENCES ResourceTable(id) ON UPDATE CASCADE ON DELETE CASCADE

ResourceTable exists (show create table ResourceTable;)

CREATE TABLE `resourcetable` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `name` varbinary(255) DEFAULT NULL,
  `isVirtual` tinyint(1) DEFAULT '0',
  PRIMARY KEY (`id`),
  UNIQUE KEY `name` (`name`),
  UNIQUE KEY `name_2` (`name`),
  UNIQUE KEY `name_3` (`name`)
) ENGINE=MyISAM AUTO_INCREMENT=50 DEFAULT CHARSET=utf8

myisamchk can't find any errors.
Comment 9 Daniel Vrátil 2014-04-25 09:44:38 UTC
Hmm, there's the problem. You are running on MyISAM, which is not a supported configuration (I'm not sure if it was in the past, but I doubt it). I'm not sure how that could happened. Anyway, Akonadi requires InnoDB, because it depends on FOREIGN KEYS to function properly.

I recommend converting all tables to InnoDB manually, then restarting Akonadi. It should automatically create all missing indexes and foreign keys.
Comment 10 Hatl 2014-04-25 17:16:46 UTC
Thank you very much! That worked!
I'm using akonadi since the very beginning.
Maybe the default was changed at some point...