20260529,日常开发-数据库主从问题

问题背景

一大早,收到一堆报警,赶紧来看。

问题解决

问题出在这里:

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);
}

问题总结

哈哈,完美解决。有时候,就是需要较真的劲儿。才能找到根源,才能成长。

相关推荐
JacksonMx1 小时前
@Transactional 最佳实践
java·spring boot·spring·性能优化
Sincerelyplz2 小时前
【AI会议纪要实践】mapReduce、RAG 与结构化输出
java·后端·agent
过期动态2 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展
zhangjw342 小时前
第15篇:Java多线程零基础入门,进程线程、线程创建方式、线程生命周期、线程安全彻底吃透
java·开发语言·面试
蝈理塘(/_\)大怨种2 小时前
类和对象 (上)
java·开发语言
我材不敲代码3 小时前
Python 函数核心:位置参数与关键字参数详解
java·前端·python
qq_333120974 小时前
C++高并发内存池的整体设计和实现思路_C 语言
java·c语言·c++
mh_f4 小时前
33.批量通过GET链接下载图片到指定文件夹下
java
金銀銅鐵4 小时前
[Java] 如何理解 class 文件中方法的 access flags?
java·后端