When receiving the error...
"InnoDB: Error: Attempted to open a previously opened tablespace. Previous tablespace"
when running a systemctl status mariadb.service it can often indicate a failed tablespace file.
This can happen if the MySQL server was shut down unexpectedly or if there is a problem with the file system.
Check the permissions on the tablespace file. Make sure that the user running MySQL has read and write permissions on the file.
Try restarting MySQL with the innodb_force_recovery parameter set to 1. This will force MySQL to ignore any errors and continue running.
If the error persists, you may need to restore your database from a backup.
Performing the following may also rectify the issue:
- Open my.cnf
- Look for [mysqld]
- Just below [mysqld] insert innodb_force_recovery = 1
- Start MySQL Service
- Stop MySQL Service
- Remove the line from my.cnf (or my.ini for Windows) (innodb_force_recovery = 1)
- Start MySQL Service
- Run a "tail -f /var/log/mysql/`servername`.log" and watch for further errors. If the tablespace issue reoccurs backup the database, remove the database, remove the files associated it @ /var/log/mysql/username_database* and reimporting it will often correct the .id file(s)
The Previous tablespace part of the message tells you the name of the tablespace that MySQL is trying to open.
The innodb_force_recovery parameter is a setting in the MySQL configuration file that allows you to force MySQL to ignore errors and continue running.