【问题标题】:MySQL error InnoDB: WarningMySQL错误InnoDB:警告
【发布时间】:2017-11-17 09:41:52
【问题描述】:

为什么会出现这个错误?

2017-06-15 05:54:42 1848 InnoDB: Warning: Using innodb_additional_mem_pool_size is DEPRECATED. This option may be removed in future releases, together with the option innodb_use_sys_malloc and with the InnoDB's internal memory allocator.
2017-06-15  5:54:42 6216 [Note] InnoDB: innodb_empty_free_list_algorithm has been changed to legacy because of small buffer pool size. In order to use backoff, increase buffer pool at least up to 20MB.

2017-06-15  5:54:42 6216 [Note] InnoDB: Using mutexes to ref count buffer pool pages
2017-06-15  5:54:42 6216 [Note] InnoDB: The InnoDB memory heap is disabled
2017-06-15  5:54:42 6216 [Note] InnoDB: Mutexes and rw_locks use Windows interlocked functions
2017-06-15  5:54:42 6216 [Note] InnoDB: _mm_lfence() and _mm_sfence() are used for memory barrier
2017-06-15  5:54:42 6216 [Note] InnoDB: Compressed tables use zlib 1.2.3
2017-06-15  5:54:42 6216 [Note] InnoDB: Using generic crc32 instructions
2017-06-15  5:54:42 6216 [Note] InnoDB: Initializing buffer pool, size = 16.0M
2017-06-15  5:54:42 6216 [Note] InnoDB: Completed initialization of buffer pool
2017-06-15  5:54:42 6216 [Note] InnoDB: Restoring page 0 of tablespace 0
2017-06-15  5:54:42 6216 [Warning] InnoDB: Doublewrite does not have page_no=0 of space: 0
2017-06-15  5:54:42 6216 [ERROR] InnoDB: space header page consists of zero bytes in data file C:\xampp\mysql\data\ibdata1
2017-06-15  5:54:42 6216 [ERROR] InnoDB: Could not open or create the system tablespace. If you tried to add new data files to the system tablespace, and it failed here, you should now edit innodb_data_file_path in my.cnf back to what it was, and remove the new ibdata files InnoDB created in this failed attempt. InnoDB only wrote those files full of zeros, but did not yet use them in any way. But be careful: do not remove old data files which contain your precious data!
2017-06-15  5:54:42 6216 [ERROR] Plugin 'InnoDB' init function returned error.
2017-06-15  5:54:42 6216 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
2017-06-15  5:54:42 6216 [Note] Plugin 'FEEDBACK' is disabled.
2017-06-15  5:54:42 6216 [ERROR] Could not open mysql.plugin table. Some plugins may be not loaded
2017-06-15  5:54:42 6216 [ERROR] Unknown/unsupported storage engine: InnoDB
2017-06-15  5:54:42 6216 [ERROR] Aborting

【问题讨论】:

  • 在这种情况开始发生之前,您是否更改了此服务器上的任何内容?您是否遇到过任何问题,例如强制关机或任何形式的崩溃?

标签: php mysql phpmyadmin xampp


【解决方案1】:

从 mySql 切换到 MariaDB 后,我遇到了类似的问题,并且您的输出中列出的一些错误是相同的。我希望我的解决方案也与您相关(因为您没有提供太多关于该问题的背景信息)。

我的问题是我没有使用以下命令初始化数据库用户:

$ mysql_install_db --user=mysql --basedir=/usr --datadir=/var/lib/mysql

运行后,我解决了错误

[ERROR] Could not open mysql.plugin table. Some plugins may be not loaded

当我再次启动数据库时,它工作得很好。

【讨论】:

    【解决方案2】:

    我不太确定我是否遇到了与您完全相同的问题(我的日志中有一些不同的内容)。但是 MySQL(在我的情况下实际上是 MariaDB)无法启动,使用相同的[ERROR] Unknown/unsupported storage engine: InnoDB。我通过将此行添加到配置中来解决它(在现有 [mysqld] 部分的末尾,或添加带有该标题的新部分):

    default_tmp_storage_engine = InnoDB
    

    这似乎为我解决了问题。 MySQL 现在可以正常启动了...

    【讨论】:

      【解决方案3】:

      在我的例子中,问题是 MySQL 服务器被配置了太大的缓冲池大小(在内存太少的虚拟机上运行 - 只有 2GB RAM)

      2018-11-13 17:06:19 7882 [Note] Plugin 'FEDERATED' is disabled.
      2018-11-13 17:06:19 7882 [Note] InnoDB: Using atomics to ref count buffer pool pages
      2018-11-13 17:06:19 7882 [Note] InnoDB: The InnoDB memory heap is disabled
      2018-11-13 17:06:19 7882 [Note] InnoDB: Mutexes and rw_locks use GCC atomic builtins
      2018-11-13 17:06:19 7882 [Note] InnoDB: Memory barrier is not used
      2018-11-13 17:06:19 7882 [Note] InnoDB: Compressed tables use zlib 1.2.8
      2018-11-13 17:06:19 7882 [Note] InnoDB: Using Linux native AIO
      2018-11-13 17:06:19 7882 [Note] InnoDB: Not using CPU crc32 instructions
      2018-11-13 17:06:19 7882 [Note] InnoDB: Initializing buffer pool, size = 2.0G
      InnoDB: mmap(1117782016 bytes) failed; errno 12
      2018-11-13 17:06:19 7882 [ERROR] InnoDB: Cannot allocate memory for the buffer pool
      2018-11-13 17:06:19 7882 [ERROR] Plugin 'InnoDB' init function returned error.
      2018-11-13 17:06:19 7882 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
      2018-11-13 17:06:19 7882 [ERROR] Unknown/unsupported storage engine: InnoDB
      2018-11-13 17:06:19 7882 [ERROR] Aborting
      

      【讨论】:

        猜你喜欢
        • 2017-11-27
        • 1970-01-01
        • 2020-10-08
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2016-05-19
        • 2010-09-21
        相关资源
        最近更新 更多