Spring事务配置隔离级别Isolation.READ_COMMITTED引发的一系列问题


这两天改了下spring事务隔离级别,使用Isolation.READ_COMMITTED,导致了放到生产环境马上出现错误。这是在测试环境没有的,找log发现了:

Caused by: java.sql.SQLException: Cannot execute statement: impossible to write to binary log since BINLOG_FORMAT = STATEMENT and at least one table uses a storage engine limited to row-based logging. InnoDB is limited to row-logging when transaction isolation level is READ COMMITTED or READ UNCOMMITTED.
本着好记性不如烂笔头的想法,记录下解决这个bug中间学习到的新东西吧。
基本原因就是mysql记录数据库操作日志的这种 BINLOG_FORMAT = STATEMENT方式,不支持这种READ COMMITTED or READ UNCOMMITTED事务级别。

解决方案:binlog_format=row,这行添加在my.cnf里面的[mysqld]下面,重启mysql服务就行。如果是主从的话就要两个库都配置这样。这到底是为什么呢,我这种小白也不懂,都是google来的。

由于生产是主从库,不敢随便在生产弄,测试没主从,就配一波mysql主从配置。

很大程度上参考这里:https://blog.csdn.net/xlgen157387/article/details/51331244

先配置下主库:

my.cnf里面[mysqld]下面添加

#master slave
log-bin=mysql-bin	//这个应该是记录操作日志的吧(不是特别理解)
server-id=93		//这个我理解为是整个服务器的id,我直接放服务器最后一个ip段
binlog-ignore-db=information_schema	
binlog-ignore-db=cluster
binlog-ignore-db=mysql
#上面三个是忽略操作
binlog-do-db=capki0714 //这个是你需要操作的数据库
#记录日志格式
binlog_format=row
配置从库:

my.cnf里面[mysqld]下面添加

log-bin=mysql-bin
server-id=131
binlog-ignore-db=information_schema
binlog-ignore-db=cluster
binlog-ignore-db=mysql
replicate-do-db=capki0714
replicate-ignore-db=mysql
log-slave-updates	//此参数网上查是说可以用来记录日志,将从库做主库。(应该是做成多级从库的形式)
slave-skip-errors=all
slave-net-timeout=60
#记录日志格式
binlog_format=row
主从的配置文件都修改完毕了。
再次回到主库运行:
show master status;

将里面显示的数据记录出来

change master to master_host='192.168.162.93',master_user='root',master_password='yourpasswd',master_log_file='mysql-bin.000003', master_log_pos=9326;
	
master_host=主库ip,master_user=主库用户,master_password=用户密码,master_log_file=对应status信息的File, master_log_pos=对应status信息的Position
记录完毕。
回到从库:

执行刚刚那个条记录,

change master to master_host='192.168.162.93',master_user='root',master_password='yourpasswd',master_log_file='mysql-bin.000003', master_log_pos=9326;
start slave;
show slave status \G;

启动从库复制操作。看信息是否正确,然后在主库添加记录看看是否成功了。

你可能感兴趣的:(j2ee)