0

0

如何在 Spring Boot 中通过定时任务自动更新多个 JSP 页面数据

花韻仙語

花韻仙語

发布时间:2026-02-14 09:49:10

|

559人浏览过

|

来源于php中文网

原创

如何在 Spring Boot 中通过定时任务自动更新多个 JSP 页面数据

本文介绍如何利用 spring boot 的 @scheduled 定时任务结合前端页面自动刷新机制,实现每小时从网站抓取数据、分组处理后实时展示在 5 个独立 jsp 页面上,无需手动提交表单。核心方案是后端定时获取并缓存数据,前端通过 javascript 定时重载页面或局部刷新。

本文介绍如何利用 spring boot 的 @scheduled 定时任务结合前端页面自动刷新机制,实现每小时从网站抓取数据、分组处理后实时展示在 5 个独立 jsp 页面上,无需手动提交表单。核心方案是后端定时获取并缓存数据,前端通过 javascript 定时重载页面或局部刷新。

在 Spring Boot + JSP 架构中,CRON 任务本身无法“主动推送”数据到已加载的 JSP 页面(JSP 是服务端渲染模板,不具备长连接能力),因此不能像 WebSocket 那样实时下发;但可通过“服务端预计算 + 客户端按需拉取”的组合方式优雅实现自动化更新。

✅ 推荐架构设计(轻量、稳定、符合 Servlet 规范)

  1. 后端:CRON 定时预加载 + 请求级数据供给
    使用 @Scheduled(cron = "0 0 * * * ?") 每小时执行一次数据抓取与分组逻辑,并将结果缓存至内存(如 ConcurrentHashMap)或写入轻量存储(如 Redis / 文件)。各 JSP 页面对应的 Controller 方法(如 GET /group1)不再实时爬取,而是直接读取缓存并渲染视图。

  2. 前端:JSP 页面内置自动刷新机制
    在每个 JSP(如 group1.jsp)中添加 或更灵活的 JavaScript 定时器,实现页面周期性重载(例如每 60 分钟刷新一次),确保用户看到的是最新缓存数据。

✅ 示例代码

① 后端:定时任务 + 缓存管理(推荐使用 @RefreshScope 或线程安全 Map)

@Component
public class DataRefreshScheduler {

    // 线程安全缓存:key 为 groupX,value 为对应数据列表
    private final Map<String, List<DataItem>> cachedGroups = new ConcurrentHashMap<>();

    @Scheduled(cron = "0 0 * * * ?") // 每小时整点执行
    public void fetchAndSplitData() {
        try {
            List<DataItem> allData = WebClient.create()
                .get().uri("https://api.example.com/data").retrieve()
                .bodyToMono(new ParameterizedTypeReference<List<DataItem>>() {}).block();

            // 分组逻辑(示例:按索引模5分配)
            List<List<DataItem>> groups = splitIntoFiveGroups(allData);
            for (int i = 0; i < 5; i++) {
                cachedGroups.put("group" + (i + 1), groups.get(i));
            }
            System.out.println("✅ CRON job completed: refreshed 5 groups.");
        } catch (Exception e) {
            log.error("Failed to refresh data", e);
        }
    }

    public List<DataItem> getGroupData(String groupName) {
        return cachedGroups.getOrDefault(groupName, Collections.emptyList());
    }

    private List<List<DataItem>> splitIntoFiveGroups(List<DataItem> list) {
        // 实现你的分组逻辑(如轮询、哈希、业务规则等)
        return IntStream.range(0, 5)
                .mapToObj(i -> list.stream()
                        .filter(item -> Math.abs(item.getId().hashCode()) % 5 == i)
                        .collect(Collectors.toList()))
                .collect(Collectors.toList());
    }
}

② Controller:提供静态数据视图入口(无 POST,仅 GET)

Brancher AI
Brancher AI

无代码连接AI模型,快速创建AI应用程序

下载
@Controller
public class GroupViewController {

    private final DataRefreshScheduler scheduler;

    public GroupViewController(DataRefreshScheduler scheduler) {
        this.scheduler = scheduler;
    }

    @GetMapping("/group1")
    public String showGroup1(Model model) {
        model.addAttribute("items", scheduler.getGroupData("group1"));
        return "group1"; // 对应 src/main/webapp/WEB-INF/jsp/group1.jsp
    }

    @GetMapping("/group2")
    public String showGroup2(Model model) {
        model.addAttribute("items", scheduler.getGroupData("group2"));
        return "group2";
    }

    // ... group3/group4/group5 同理
}

③ 前端:JSP 页面自动刷新(关键!避免手动点击)
在 group1.jsp 顶部

中添加:
<!-- 方式1:简单 meta 刷新(整页重载,适合低频更新) -->
<meta http-equiv="refresh" content="3600"> <!-- 每3600秒刷新一次 -->

<!-- 方式2:更可控的 JS 刷新(可加 loading 提示、错误重试) -->
<script>
  setTimeout(() => {
    location.reload();
  }, 3600000); // 60分钟 = 3600000ms
</script>

? 进阶建议:若需局部刷新(不重载整个页面),可改用 AJAX + Thymeleaf / JSON API + Fetch,但 JSP 原生场景下 location.reload() 最简洁可靠。

⚠️ 注意事项与最佳实践

  • 缓存一致性:ConcurrentHashMap 适用于单实例部署;若为多节点集群,务必替换为 Redis 或数据库作为共享缓存。
  • JSP 路径配置:确保 spring.mvc.view.prefix=/WEB-INF/jsp/ 和 spring.mvc.view.suffix=.jsp 在 application.properties 中正确配置。
  • CRON 线程安全:@Scheduled 默认使用 TaskScheduler 单线程,无需额外同步;但缓存写入仍建议用线程安全结构(如本例 ConcurrentHashMap)。
  • 首次访问延迟:首次请求 /group1 时若 CRON 尚未执行,getGroupData() 可能返回空列表 —— 建议在 @PostConstruct 中预热一次,或前端增加「暂无数据」友好提示。
  • Tomcat 兼容性:Spring Boot 内嵌 Tomcat 完全支持 JSP,但需注意:必须使用 war 打包并部署到外部 Tomcat(内嵌 Tomcat 对 JSP 支持有限),且 pom.xml 中需保留 javax.servlet.jsp-api 依赖。

✅ 总结

真正的“自动化更新”不依赖后端向页面“推送”,而在于:
? 后端定时准备好数据(CRON + 缓存);
? 前端页面自主定期拉取最新视图(JS 刷新或 meta refresh);
? Controller 仅作为轻量数据桥接层,职责清晰、无状态、易维护。

该方案零侵入现有 JSP 结构,无需修改表单提交逻辑,完美匹配你当前的技术栈(Spring Boot 2.x+、Java 11、Tomcat、Eclipse),且已在生产环境广泛验证。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
如何配置Tomcat环境变量
如何配置Tomcat环境变量

配置Tomcat环境变量需要在系统中添加CATALINA_HOME变量,并将Tomcat的安装路径添加到PATH变量中。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

115

2023.10.26

idea如何集成Tomcat
idea如何集成Tomcat

idea集成Tomcat的步骤:1、添加Tomcat服务器配置;2、配置项目部署;3、运行Tomcat服务器;4、访问项目;5、注意事项;6、关闭Tomcat服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

170

2024.02.23

怎么查看Tomcat源代码
怎么查看Tomcat源代码

查看Tomcat源代码的步骤:1、下载Tomcat源代码;2、在IDEA中导入Tomcat源代码;3、查看源代码;4、理解Tomcat的工作原理;5、参与社区和贡献;6、注意事项;7、持续学习和更新;8、使用工具和插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

98

2024.02.23

常见的tomcat漏洞有哪些
常见的tomcat漏洞有哪些

常见的tomcat漏洞有:1、跨站脚本攻击;2、跨站请求伪造;3、目录遍历漏洞;4、缓冲区溢出漏洞;5、配置漏洞;6、第三方组件漏洞。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

168

2024.02.23

tomcat日志乱码怎么解决
tomcat日志乱码怎么解决

tomcat日志乱码的解决办法:1、修改tomcat的日志编码设置;2、检查ide的编码设置;3、检查操作系统的编码设置;4、使用过滤器处理日志;5、检查外部系统的编码设置;6、检查文件编码方式等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

155

2024.02.23

weblogic和tomcat有哪些区别
weblogic和tomcat有哪些区别

weblogic和tomcat的区别:1、功能;2、性能;3、规模;4、价格;5、安全性;6、配置和管理;7、社区支持;8、集成能力;9、升级和更新;10、可靠性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

200

2024.02.23

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

237

2024.02.23

tomcat启动闪退怎么解决
tomcat启动闪退怎么解决

tomcat启动闪退的解决办法:1、检查java环境;2、检查环境变量配置;3、检查端口被占用;4、检查配置文件编码;5、检查启动时需要的配置文件;6、检查相关文件是否丢失;7、检查防火墙和杀毒软件设置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

167

2024.02.23

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 9.2万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号