无法运行 XAMPP - MySql

问题描述 投票:0回答:9

当我尝试启动 XAMPP - MySql 时,它不起作用。 我已经尝试修复它,但我找不到任何实际的解决方案,我希望你能找到它的问题所在。

有日志:

2019-06-26  9:08:35 0 [Note] InnoDB: Mutexes and rw_locks use Windows interlocked functions
2019-06-26  9:08:35 0 [Note] InnoDB: Uses event mutexes
2019-06-26  9:08:35 0 [Note] InnoDB: Compressed tables use zlib 1.2.11
2019-06-26  9:08:35 0 [Note] InnoDB: Number of pools: 1
2019-06-26  9:08:35 0 [Note] InnoDB: Using SSE2 crc32 instructions
2019-06-26  9:08:35 0 [Note] InnoDB: Initializing buffer pool, total size = 16M, instances = 1, chunk size = 16M
2019-06-26  9:08:35 0 [Note] InnoDB: Completed initialization of buffer pool
2019-06-26  9:08:35 0 [Note] InnoDB: Setting file 'C:\xampp\mysql\data\ibdata1' size to 10 MB. Physically writing the file full; Please wait ...
2019-06-26  9:08:35 0 [Note] InnoDB: File 'C:\xampp\mysql\data\ibdata1' size is now 10 MB.
2019-06-26  9:08:35 0 [Note] InnoDB: Setting log file C:\xampp\mysql\data\ib_logfile101 size to 5242880 bytes
2019-06-26  9:08:35 0 [Note] InnoDB: Setting log file C:\xampp\mysql\data\ib_logfile1 size to 5242880 bytes
2019-06-26  9:08:36 0 [Note] InnoDB: Renaming log file C:\xampp\mysql\data\ib_logfile101 to C:\xampp\mysql\data\ib_logfile0
2019-06-26  9:08:36 0 [Note] InnoDB: New log files created, LSN=45786
2019-06-26  9:08:36 0 [Note] InnoDB: Doublewrite buffer not found: creating new
2019-06-26  9:08:36 0 [Note] InnoDB: Doublewrite buffer created
2019-06-26  9:08:36 0 [Note] InnoDB: 128 out of 128 rollback segments are active.
2019-06-26  9:08:36 0 [Note] InnoDB: Creating foreign key constraint system tables.
2019-06-26  9:08:36 0 [Note] InnoDB: Creating tablespace and datafile system tables.
2019-06-26  9:08:36 0 [Note] InnoDB: Creating sys_virtual system tables.
2019-06-26  9:08:36 0 [Note] InnoDB: Removed temporary tablespace data file: "ibtmp1"
2019-06-26  9:08:36 0 [Note] InnoDB: Creating shared tablespace for temporary tables
2019-06-26  9:08:36 0 [Note] InnoDB: Setting file 'C:\xampp\mysql\data\ibtmp1' size to 12 MB. Physically writing the file full; Please wait ...
2019-06-26  9:08:36 0 [Note] InnoDB: File 'C:\xampp\mysql\data\ibtmp1' size is now 12 MB.
2019-06-26  9:08:36 0 [Note] InnoDB: Waiting for purge to start
2019-06-26  9:08:36 0 [Note] InnoDB: 10.3.16 started; log sequence number 0; transaction id 7
2019-06-26  9:08:36 0 [Note] Plugin 'FEEDBACK' is disabled.
2019-06-26  9:08:36 0 [Note] Server socket created on IP: '::'.
2019-06-26  9:08:36 0 [ERROR] mysqld.exe: Table '.\mysql\user' is marked as crashed and should be repaired
2019-06-26  9:08:36 0 [ERROR] mysqld.exe: Index for table '.\mysql\user' is corrupt; try to repair it
2019-06-26  9:08:36 0 [ERROR] Couldn't repair table: mysql.user
2019-06-26  9:08:36 0 [ERROR] Fatal error: Can't open and lock privilege tables: Index for table 'user' is corrupt; try to repair it
xampp
9个回答
157
投票

这是由于 C:\xampp\mysql\data\mysql 中的某些文件损坏造成的。

解决方案

  1. 备份C:\xampp\mysql\data
  2. 复制所有文件C:\xampp\mysql ackup
  3. 粘贴并替换现有文件:C:\xampp\mysql\data除了 ibdata1 文件。
    留下 ibdata1 将有助于防止表不存在错误。

42
投票

解决方案只是一个

Copy From ...xampp/mysql/backup/... of all files and paste into .../xampp/mysql/data/  -> you will lost your data

Just copy the folder From ...xampp/mysql/backup/ & Paste into .../xampp/mysql/data/  -> this will help to run Mysql & existing database is working

14
投票

我以前也遇到过这种情况,解决方案非常简单。 请仔细阅读所有步骤:

  1. 为此文件夹进行备份C:\xampp\mysql\data(确保备份文件夹的名称不是backup)。
  2. 现在从C:\xampp\mysql ackup复制所有文件/文件夹,除了ibdata1,以避免表不存在的错误。
  3. 将所有复制的文件/文件夹粘贴到C:\xampp\mysql\data

希望您的问题能够得到解决。


12
投票

复制 xampp/mysql/backup/ 中的所有文件和文件夹并将其粘贴到 xampp/mysql/data/ 中。如果要求替换,请单击全部替换


5
投票

@tobiloba 的解决方案是临时的。我有类似的问题。并通过他的解决方案暂时解决。但下次mysql启动时。它失败了。因为我需要保留我的数据并打开 mysql 服务器来运行它。

xampp/mysql/bin/my.conf 打开 my.conf 并找到这两行。

innodb_buffer_pool_size=10M

将其更改为 30M 0r 50MB。和比

 innodb_data_file_path=ibdata1:20M:autoextend

也改变这个

 innodb_data_file_path=ibdata1:60M:autoextend

对我来说,它永久解决了问题,并使我现有的数据保持活力,并且之后工作正常。


2
投票

此解决方案将有助于保护您现有的数据库。

Just copy the folder From ...xampp/mysql/backup/ & Paste into .../xampp/mysql/data/  -> this will help to run Mysql & existing database is working

1
投票

只需从 my.ini 编辑此行即可:

;脚本可能消耗的最大内存量(128MB) ; http://php.net/memory-limit memory_limit=128M -> 选择你想要的大小。


1
投票

对我来说,我备份了data文件夹,然后将/backup/中的文件和文件夹复制到/data/,服务成功启动。除了 ibdata1 之外,我不需要从备份数据中复制任何内容,否则就会抱怨表不存在。


0
投票

删除或移动ib_logfile0和ib_logfile1到备份文件夹..并尝试重新启动Mysql 这将恢复这些文件,并且 mysql 应该运行而不会丢失任何数据。

© www.soinside.com 2019 - 2024. All rights reserved.