异步将用户信息存入 Redis 缓存

主要是为了解决Redis的缓存问题,异步将用户信息存入Redis缓存

首先我们需要引入一部线性池

核心概念

  1. 异步执行

    • 异步执行是指任务提交后不会立即等待其完成,而是立即返回并继续执行其他任务。任务将在后台执行,执行结果可以通过回调、Future、Promise 等机制获取。
    • 异步执行通常意味着任务不会阻塞当前线程,也就是当前线程可以继续做其他事情。
  2. 线程池

    • 线程池是一个维护一组线程的集合,任务提交给线程池后,线程池会从线程池中取出一个空闲线程来执行任务,而不是每次都新建一个线程。线程池能够有效地管理线程的生命周期,避免线程创建和销毁的开销。
  3. 任务提交与执行

    • 异步线程池中的任务是被异步地执行的。任务可以通过提交接口(例如 submit()execute())被提交到线程池中,线程池的线程会异步执行这些任务。提交的任务一般是 CallableRunnable 类型。
  4. 异步结果

    • 异步任务执行完毕后,通常会返回一个结果。Java 中可以通过 Future 对象获取结果或状态。通过 Future.get() 方法可以获取任务执行的结果(注意 get() 是阻塞方法),如果你只关心任务是否完成,可以使用 isDone() 方法。
java 复制代码
@Configuration
public class ThreadPoolConfig {

    @Bean(name = "taskExecutor")
    public Executor taskExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(10);
        executor.setMaxPoolSize(50);
        executor.setQueueCapacity(200);
        executor.setKeepAliveSeconds(30);
        executor.setThreadNamePrefix("UserExecutor-");

        // 拒绝策略:由调用线程处理(一般为主线程)
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());

        // 等待所有任务结束后再关闭线程池
        executor.setWaitForTasksToCompleteOnShutdown(true);
        // 设置等待时间
        executor.setAwaitTerminationSeconds(60);

        executor.initialize();
        return executor;
    }
}

下面展示用户信息存入 Redis 缓存的部分代码

java 复制代码
        // 根据用户 ID 查询用户信息
        UserDO userDO = userDOMapper.selectById(userId);

        // 判空
        if (Objects.isNull(userDO)) {
            threadPoolTaskExecutor.execute(() -> {
                // 防止缓存穿透,将空数据存入 Redis 缓存 (过期时间不宜设置过长)
                long expirationTime = 60 + RandomUtil.randomInt(60);
                redisTemplate.opsForValue().set("这里自己定义key值", "null", expirationTime, TimeUnit.SECONDS);
            });
            throw new (根据自己设置的异常);
        }
相关推荐
Wang15306 小时前
jdk内存配置优化
java·计算机网络
点云SLAM6 小时前
BOOS库中Graph模块boost::edge_reverse_t和boost::vertex_color_t解读
数据库·edge·图论·bfs·dfs/拓扑排序·boost库、
尽兴-6 小时前
《深入剖析:全面理解 MySQL 的架构设计》
数据库·mysql·数据库架构设计·理解mysql架构
0和1的舞者6 小时前
Spring AOP详解(一)
java·开发语言·前端·spring·aop·面向切面
Wang15306 小时前
Java多线程死锁排查
java·计算机网络
在风中的意志6 小时前
[数据库SQL] [leetcode] 2388. 将表中的空值更改为前一个值
数据库·sql·leetcode
梦幻通灵7 小时前
Mysql字段判空实用技巧
android·数据库·mysql
小小星球之旅7 小时前
CompletableFuture学习
java·开发语言·学习
jiayong237 小时前
知识库概念与核心价值01
java·人工智能·spring·知识库
皮皮林5517 小时前
告别 OOM:EasyExcel 百万数据导出最佳实践(附开箱即用增强工具类)
java