踩坑日记啦啦啦啦

文章讲述了在SpringBoot项目中使用自定义的@Transactional注解引发的问题,当业务方法包含发送Kafka消息时,由于事务未提交,导致消费者获取到的数据不是最新。解决方案是将数据修改部分与MQ发送分开处理,确保事务提交后再写入MQ。另外,文章还提到了在Clickhouse中执行SQL插入时,若字段为null会导致写入失败,因此需确保所有字段都不为null,对可能为空的字段做处理。
摘要由CSDN通过智能技术生成

1、SpringBoot的项目中使用@DalTransactional注解

现象:在业务代码方法前加了该注解,希望修改是事务的。当中有一个发送kafka消息的调用。
当消费者消费到消息时,从mysql查询,此时事务还未提交,导致不能处理到最新的结果数据。从而产生kafka数据丢失的幻觉。

解决:除了发送到mq的代码,其他修改业务数据的代码封装起来,以事务进行。提交完了,在外层进行mq写入。

2、Clickhouse sql写入,sql当中指定的input不能为null,否则会写入失败

现象:flink消费ubt数据时,根据日志层层打点,发现没有问题,最终定位到写入sql中有字段为null,导致在DBEaver中一直查询不到

解决:

input后的字段都不能为null,可能为null的字段要处理空字符串''

String sql = "insert into ab_app_division_log 
        select division_id, division_type, platform_code, exp_code, 
         ab_version, layer, domain, mod, version, effective_time, currentTime,d 
        from input('division_id String, division_type String, platform_code String,
         exp_code String, ab_version String, layer String, domain String, mod String,
         version String, effective_time String, currentTime DateTime, d Date')";
PreparedStatement preparedStatement = sql;
try {
  if (preparedStatement != null) {
    int count = 0;
    for (ABModel abModel : elements) {
      preparedStatement.setString(1, abModel.getDivisionId());
      preparedStatement.setString(2, abModel.getDivisionType());
      preparedStatement.setString(3, abModel.getPlatformCode());
      preparedStatement.setString(4, abModel.getExpCode());
      preparedStatement.setString(5, abModel.getAbVersion());
      preparedStatement.setString(6, abModel.getLayer());
      preparedStatement.setString(7, abModel.getDomain());
      preparedStatement.setString(8, abModel.getMod());
      preparedStatement.setString(9, abModel.getSendFrom());
      preparedStatement.setString(10, abModel.getStartTime());
      preparedStatement.setObject(11, abModel.getTs());
      preparedStatement.setObject(12, new java.sql.Date(abModel.getTs().getTime()));
      preparedStatement.addBatch();
      count++;
    }
    preparedStatement.executeBatch();
  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值