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

问题总结

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

相关推荐
唐青枫20 小时前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
云技纵横20 小时前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二20 小时前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
一个做软件开发的牛马21 小时前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户37215742613521 小时前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户37215742613521 小时前
Java 打印 Word 文档:从基础打印到高级设置
java
小猿姐1 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
用户3521802454752 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程
东坡白菜2 天前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈
唐青枫2 天前
Java Tomcat 实战指南:从 Servlet 容器到 Spring Boot 部署
java