code review:访问日志、错误日志的清理 Job 实现

This commit is contained in:
YunaiV 2023-10-02 00:06:28 +08:00
parent d4417d2474
commit f8b4a08fae
14 changed files with 23 additions and 1 deletions

View File

@ -30,6 +30,7 @@ public class YudaoQuartzAutoConfiguration {
return new SchedulerManager(scheduler.get()); return new SchedulerManager(scheduler.get());
} }
// TODO @j-sentinel这个 job先拿到 infra biz 里面实现哈
@Bean @Bean
public JobLogJobHandler jobLogJobHandler(LogJobProperties logJobProperties){ public JobLogJobHandler jobLogJobHandler(LogJobProperties logJobProperties){
return new JobLogJobHandler(logJobProperties); return new JobLogJobHandler(logJobProperties);

View File

@ -7,7 +7,9 @@ import lombok.extern.slf4j.Slf4j;
import javax.annotation.Resource; import javax.annotation.Resource;
// TODO @j-sentinel名字和项目里其它保持统一可以叫 JobLogCleanJob不用带 handler
/** /**
* // TODO @j-sentinel要写下类注释噢就是这个类要干啥然后下面两个应该是 @author @since
* @Author: j-sentinel * @Author: j-sentinel
* @Date: 2023/9/30 20:40 * @Date: 2023/9/30 20:40
*/ */

View File

@ -3,6 +3,7 @@ package cn.iocoder.yudao.framework.quartz.core.job;
import lombok.Data; import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.boot.context.properties.ConfigurationProperties;
// TODO @j-sentinel这个配置类先暂时不做每个 Job 里面定一个静态类其实不是所有的变量都需要配置化因为它本身基本也不会改动
/** /**
* @Author: j-sentinel * @Author: j-sentinel
* @Date: 2023/9/30 16:17 * @Date: 2023/9/30 16:17

View File

@ -62,11 +62,11 @@
</dependency> </dependency>
<!-- Job 定时任务相关 --> <!-- Job 定时任务相关 -->
<!-- TODO @j-sentinel去掉这个依赖哈 -->
<dependency> <dependency>
<groupId>cn.iocoder.boot</groupId> <groupId>cn.iocoder.boot</groupId>
<artifactId>yudao-spring-boot-starter-job</artifactId> <artifactId>yudao-spring-boot-starter-job</artifactId>
</dependency> </dependency>
</dependencies> </dependencies>
</project> </project>

View File

@ -8,6 +8,7 @@ import lombok.extern.slf4j.Slf4j;
import javax.annotation.Resource; import javax.annotation.Resource;
// TODO @j-sentinel JobLogJobHandler
/** /**
* @Author: j-sentinel * @Author: j-sentinel
* @Date: 2023/9/30 16:13 * @Date: 2023/9/30 16:13

View File

@ -8,6 +8,7 @@ import lombok.extern.slf4j.Slf4j;
import javax.annotation.Resource; import javax.annotation.Resource;
// TODO @j-sentinel JobLogJobHandler
/** /**
* @Author: j-sentinel * @Author: j-sentinel
* @Date: 2023/9/30 16:13 * @Date: 2023/9/30 16:13

View File

@ -18,10 +18,12 @@ public interface ApiAccessLogApi {
*/ */
void createApiAccessLog(@Valid ApiAccessLogCreateReqDTO createDTO); void createApiAccessLog(@Valid ApiAccessLogCreateReqDTO createDTO);
// TODO @j-sentinel这个我们先提供接口在 API而是 infra 模块自己清理先哈
/** /**
* 清理 @param accessLogJobDay 天的访问日志 * 清理 @param accessLogJobDay 天的访问日志
* *
* @param accessLogJobDay 超过多少天就进行清理 * @param accessLogJobDay 超过多少天就进行清理
*/ */
void jobCleanAccessLog(Integer accessLogJobDay); void jobCleanAccessLog(Integer accessLogJobDay);
} }

View File

@ -18,10 +18,12 @@ public interface ApiErrorLogApi {
*/ */
void createApiErrorLog(@Valid ApiErrorLogCreateReqDTO createDTO); void createApiErrorLog(@Valid ApiErrorLogCreateReqDTO createDTO);
// TODO @j-sentinel这个我们先提供接口在 API而是 infra 模块自己清理先哈
/** /**
* 清理 @param errorLogJobDay 天的访问日志 * 清理 @param errorLogJobDay 天的访问日志
* *
* @param errorLogJobDay 超过多少天就进行清理 * @param errorLogJobDay 超过多少天就进行清理
*/ */
void jobCleanErrorLog(Integer errorLogJobDay); void jobCleanErrorLog(Integer errorLogJobDay);
} }

View File

@ -41,7 +41,12 @@ public interface JobLogMapper extends BaseMapperX<JobLogDO> {
); );
} }
// TODO @j-sentinel一般来说我们 mapper 只提供 crud 的操作所以这个方法的命名建议是 deleteByCreateTimeLt
// 然后参数是 (crateTime, count) service 传入
// 这里为什么有 lt 这个其实是延续 spring data method 描述的命名习惯lt 表示小于
// 另外timingJobCleanLog 的具体 sql 这么写性能是比较差的可以直接 delete * from job_log where create_time < xxx order by id limit 100;
Integer timingJobCleanLog(@Param("jobCleanRetainDay") Integer jobCleanRetainDay); Integer timingJobCleanLog(@Param("jobCleanRetainDay") Integer jobCleanRetainDay);
// TODO @j-serntineloptimize table infra_job_log 就可以啦
void optimizeTable(); void optimizeTable();
} }

View File

@ -45,6 +45,7 @@ public interface ApiAccessLogMapper extends BaseMapperX<ApiAccessLogDO> {
); );
} }
// TODO @j-sentinel JobLogMapper 的一些优化点
Integer jobCleanAccessLog(@Param("accessLogJobDay") Integer accessLogJobDay); Integer jobCleanAccessLog(@Param("accessLogJobDay") Integer accessLogJobDay);
void optimizeTable(); void optimizeTable();

View File

@ -43,6 +43,7 @@ public interface ApiErrorLogMapper extends BaseMapperX<ApiErrorLogDO> {
); );
} }
// TODO @j-sentinel JobLogMapper 的一些优化点
Integer jobCleanErrorLog(@Param("errorLogJobDay") Integer errorLogJobDay); Integer jobCleanErrorLog(@Param("errorLogJobDay") Integer errorLogJobDay);
void optimizeTable(); void optimizeTable();

View File

@ -52,10 +52,13 @@ public class JobLogServiceImpl implements JobLogService {
} }
} }
// TODO @j-sentinel这个 job也可以忽略租户哈可以直接使用 @TenantIgnore 注解
@Override @Override
public Integer timingJobCleanLog(Integer jobCleanRetainDay) { public Integer timingJobCleanLog(Integer jobCleanRetainDay) {
Integer result = null; Integer result = null;
int count = 0; int count = 0;
// TODO @j-sentinel一般我们在写逻辑时尽量避免用 while true 这种死循环而是 for (int i = 0; i < Short.MAX) 类似这种避免里面真的发生一些意外的情况无限执行
// 然后 for 里面可以有个 if count < 100 未到达删除的预期条数说明已经到底可以 break
while (result == null || DELETE_LIMIT.equals(result)){ while (result == null || DELETE_LIMIT.equals(result)){
result = jobLogMapper.timingJobCleanLog(jobCleanRetainDay); result = jobLogMapper.timingJobCleanLog(jobCleanRetainDay);
count += result; count += result;

View File

@ -47,6 +47,7 @@ public class ApiAccessLogServiceImpl implements ApiAccessLogService {
} }
@Override @Override
// TODO j-sentinel类似 JobLogServiceImpl 的建议
public void jobCleanAccessLog(Integer accessLogJobDay) { public void jobCleanAccessLog(Integer accessLogJobDay) {
TenantUtils.executeIgnore(() -> { TenantUtils.executeIgnore(() -> {
Integer result = null; Integer result = null;

View File

@ -68,6 +68,7 @@ public class ApiErrorLogServiceImpl implements ApiErrorLogService {
} }
@Override @Override
// TODO j-sentinel类似 JobLogServiceImpl 的建议
public void jobCleanErrorLog(Integer errorLogJobDay) { public void jobCleanErrorLog(Integer errorLogJobDay) {
TenantUtils.executeIgnore(() -> { TenantUtils.executeIgnore(() -> {
Integer result = null; Integer result = null;