问题背景
一大早,收到一堆报警,赶紧来看。
问题解决
问题出在这里:
java
TSaasTrainerCustomerInfoEntity profileEntity = saasTrainerCustomerV2Dao.selectCustomerProfile(params.getUserId());
if (Objects.isNull(profileEntity)) {
profileEntity = new TSaasTrainerCustomerInfoEntity();
profileEntity.setAddUserId(currentUser.getId());
}
TSaasTrainerCustomerInfoEntity oldEntity = JSONObject.parseObject(JSONObject.toJSONString(profileEntity), TSaasTrainerCustomerInfoEntity.class);
profileEntity.setUserId(params.getUserId());
if (Objects.nonNull(profileEntity.getId())) {
trainerCustomerInfoDao.update(profileEntity);
} else {
// 出问题点,一直报错,唯一索引问题。
trainerCustomerInfoDao.insert(profileEntity);
}
代码没问题呀,先查询,如果存在则更新,如果不存在则插入。
一问BDA,是不是有延迟呀。他回答,是的。哦,然后,我以为到此结束。
中午吃饭跟他聊了下,这个问题,为什么延迟这么久。他说也就十几秒钟,当时在执行大表的添加字段。我说,不可能呀,我看了数据的时间。
下午我来进行确认。
我看了下数据记录的添加时间
java
[
{
"id": 6824,
"user_id": 72502,
"cardealer_id": null,
"city_name": "德州市",
"user_address": "春晖路新园采摘园对面1号展厅",
"video_my": 0,
"add_time": "2026-05-28 09:39:13",
"add_user_id": null,
"update_time": "2026-05-28 10:19:26",
"update_user_id": 14753
}
]
2026-05-28 09:39:13,啊,都已经50多了,还在报错,这显然不是说的十几秒。
哪里不对呢,他说线上主从不可能超过10s,但是这显然不对,哦,他说10库有可能。我看下Dao层,嗨,还真是的。
java
@Mapper(DataSource.BI_WWW)
public interface SaasTrainerCustomerV2Dao extends BaseDao<TSaasTrainerCustomerInfoEntity> {
@Select("select * from db_www.t_saas_trainer_customer_info where user_id = #{userId}")
TSaasTrainerCustomerInfoEntity selectCustomerProfile(@Param("userId") Long userId);
}
走的10库,解决办法,切换为正常的主从,别走10库,跑批等,延迟很高。
java
public interface TrainerCustomerInfoDao extends BaseDao<TSaasTrainerCustomerInfoEntity> {
/**
* 迁移到此处,走主库,而不是bi库
* @param userId
* @return
*/
@Select("select * from db_www.t_saas_trainer_customer_info where user_id = #{userId}")
TSaasTrainerCustomerInfoEntity selectCustomerProfile(@Param("userId") Long userId);
}
问题总结
哈哈,完美解决。有时候,就是需要较真的劲儿。才能找到根源,才能成长。