持久层的数据库锁控制

网站最近并发访问量增多,log常一旦抛出以下异常:

Caused by: java.sql.BatchUpdateException: Lock wait timeout exceeded; try restarting transaction

 

org.springframework.dao.CannotAcquireLockException: Hibernate flushing: Could not execute JDBC batch update; SQL [update fb_session_keys set hh_session_key=?, last_update=?, live_forever=?, session_key=?, uid=? where id=?]; Lock wait timeout exceeded; try restarting transaction; nested exception is java.sql.BatchUpdateException: Lock wait timeout exceeded; try restarting transaction

 

fb_session_keys這個表在高并發時被鎖住了,見鬼!

 

查entity時發現沒有設定數據庫鎖,orm使用的是jpa annotation

 

得使用樂觀鎖來搞定:

 

        private Integer version=Integer.valueOf(0); //乐观锁版本控制
	
	@Version
	public Integer getVersion() {
		return version;
	}
	public void setVersion(Integer version) {
		this.version = version;
	}

 收工!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值