Error number: MY-010658; Symbol: ER_NDB_BINLOG_WRITING_TO_NDB_BINLOG_INDEX; SQLSTATE: HY000
Message: NDB Binlog: Writing row (%s) to ndb_binlog_index – %s
。
错误说明:
MY-010658(ER_NDB_BINLOG_WRITING_TO_NDB_BINLOG_INDEX)是MySQL的一个发展错误,该错误表示MySQL实例当前正在尝试将写入binlog信息索引到“ndb_binlog_index”表。该错误出现在MySQL8.0版本中,它可能是由MySQL操作ndb_binlog_index表时数据库线程出错造成的,并且会导致当前客户无法正常访问。
该错误一般发生在当MySQL尝试在ndb_binlog_index表中写入一些binlog复制历史记录时,尤其是当准备拆分时发生冲突时。该冲突很可能是由于正在使用的ndb_binlog_index表没有正确的可用空间而造成的当场表占用或外部干扰导致的。
解决方法:
如果您发现您的MySQL实例报出MY-010661(ER_NDB_BINLOG_WRITING_TO_NDB_BINLOG_INDEX)错误,则需要执行以下操作来解决该问题:
1. 确保表空间足够大,这样就可以避免实际表占用导致冲突发生。
2. 将ndb_binlog_index清空,以便它可以提供足够的空间来保存新的binlog复制历史记录。
3. 使用sysbench工具来检查是否存在外部干扰,如果存在外部干扰,则需要确认这是否会影响ndb_binlog_index表中的数据。
4. 如果没有外部干扰,则可以修改MySQL配置文件,以便对ndb_binlog_index表执行更新操作。
5. 检查是否存在表不一致,如果存在,可以使用CHECK TABLE和REPAIR TABLE命令来修复表。
6. 最后,可以尝试重新启动MySQL服务器,看是否能解决该问题。