主从:Error:The size of BLOB/TEXT data inserted in one transaction is greater than 10% of redo log size

问题描述:mysql主从复制报错:Last_SQL_Error: Error 'The size of BLOB/TEXT data inserted in one transaction is greater than 10% of redo log size. Increase the redo log size using innodb_log_file_size.
意思就是:在一个事务中插入的BLOB/TEXT数据的大小大于重做日志大小的10%。使用innodb_log_file_size增加重做日志大小。
报错如下:
MySQL主从复制报错
解决步骤:
1、查看innodb_log_file_size值的大小

mysql> SHOW VARIABLES LIKE '%innodb_log_file_size%';
+----------------------+---------+
| Variable_name        | Value   |
+----------------------+---------+
| innodb_log_file_size | 5242880 |
+----------------------+---------+

值为:5242880/1024/1024=5M
2、停止主从

mysql> stop slave;
Query OK, 0 rows affected (0.01 sec)

3、修改innodb_log_file_size值的大小

vim my.cnf
#添加参数
innodb_log_file_size=256M
说明:修改完重启从数据库,企图临时修改set innodb_log_file_size = 256 * 1024 * 1024;,会报错:ERROR 1238 (HY000): Variable 'innodb_log_file_size' is a read only variable,只读变量,所有只能修改配置文件重启数据库。

4、重起完数据库,开启主从

SHOW VARIABLES LIKE '%innodb_log_file_size%';
+----------------------+-----------+
| Variable_name        | Value     |
+----------------------+-----------+
| innodb_log_file_size | 268435456 |
+----------------------+-----------+
1 row in set (0.00 sec)
mysql> start slave;
Query OK, 0 rows affected, 1 warning (0.00 sec)

主从状态恢复
完美解决,MySQL主从恢复正常!

在一个事务中插入的blob/text数据的大小超过了10%的限制时,可能会遇到以下问题。 首先,这可能会导致事务的执行时间变长。由于数据量较大,需要更长的时间来将大块数据插入到数据库中。这会增加事务的执行时间,可能导致其他正在等待执行的事务出现延迟。 其次,大容量的blob/text数据插入可能会占用数据库中的存储空间。如果频繁插入大量的blob/text数据,数据库的存储空间可能会迅速耗尽。这可能需要更频繁地进行数据库的备份和清理,以确保数据库的正常运行。 另外,事务过大也可能导致数据库的性能下降。当事务过大时,数据库需要处理更多的数据,并可能需要进行更多的写入操作。这可能会导致数据库负载增加,使得数据库的响应时间变慢。 为了解决这个问题,可以考虑以下几点。首先,可以将大容量的blob/text数据拆分成较小的部分,然后分批插入到数据库中。这样可以减少单次事务的数据量,降低对数据库的负载,提高数据库的性能。 其次,可以考虑优化数据库的存储结构和设置,以提高数据库对大容量数据的处理能力。例如,可以合理设置数据库的缓存大小、调整存储引擎的参数等,以优化数据库的性能和存储空间的利用率。 最后,可以使用其他存储方式来存储大容量的blob/text数据,如分布式文件系统、对象存储等。这些存储方式可以提供更高的存储容量和更好的性能,从而解决大容量数据插入的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值