我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java处理延时任务的解决方案有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java处理延时任务的解决方案有哪些

本篇内容介绍了“Java处理延时任务的解决方案有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    数据库轮询

    原理

    通过一个线程定时的扫描数据库当天创建的订单,根据订单的创建时间来判断订单是否超时,针对超时订单进行相关的更新操作。
    实现技术
    采用Spring Boot结合quartz来实现,具体的实现可以参考之前的文章。

    优缺点

    优点:

    此方案比较简单,且quartz也支持集群操作。

    缺点:

    • 系统订单数据量比较大,每个几分钟轮询数据库,对服务器和数据库的内存消耗比较大。

    • 存在延迟,即使1分钟扫描一次数据库,也会存在1分钟的延迟。

    Java延迟队列

    原理

    采用JDK自带的DelayQueue来实现,这是一个无界阻塞队列,该队列只有在延迟期满的时候才能从中获取元素,放入DelayQueue中的对象。
    实现技术
    使用JDK的DelayQueue队列进行相关操作即可。

    优缺点

    优点:

    此方案是基于内存操作所以效率高,任务触发时间延迟低.

    缺点:

    • 消息队列的信息都存放在内存中,一旦服务器重启,则数据全部消失

    • 无法进行集群用扩展

    • 由于本机内存有限,一旦订单数据量过大,很容易出现OOM异常。

    Reids监听失效key

    原理

    该方案使用Redis的Keyspace Notifications,利用key失效的提供的回调机制,处理相关的业务实现

    实现技术

    基于reids的方案,实现MessageListener接口。

    实现步骤

    修改Redis配置文件
    打开redis.conf 文件,搜索 “notify-keyspace-events”找到原本的notify-keyspace-events " ",修改为 “notify-keyspace-events Ex”,至此Redis 就支持Key过期事件的监听。

    Java处理延时任务的解决方案有哪些

    创建监听类,实现MessageListener接口

    @Componentpublic class RedisKeyExpirationListener implements MessageListener{    private static final Logger logger = LoggerFactory.getLogger(RedisKeyExpirationListener.class);        public static final String KEY_PREX = "test::order:queue";        @Override    public void onMessage(Message message, byte[] pattern)    {        try        {            String expiredKey = message.toString();            // 通过key来判断            if(!expiredKey.contains(KEY_PREX))            {                return;            }                        //满足条件处理具体的业务逻辑        }        catch (Exception e)        {            logger.error("失效事件失败",e);        }    }}

    优缺点

    优点:

    基于Redis实现简单

    缺点:

    • 客户端断开后重连会导致所有事件丢失。

    • 高并发场景下,存在大量的失效key场景会导出失效时间存在延迟。

    • 此方案针对业务量较少且可靠性要求不高的场景使用。

    RocketMq延迟消息

    实现原理

    基于RocketMQ设置消息的等级,发送延迟消息,RocketMQ延时消息会暂存在名为SCHEDULE_TOPIC_XXXX的Topic中,并根据delayTimeLevel存入特定的queue,queueId = delayTimeLevel – 1,即一个queue只存相同延迟的消息,保证具有相同发送延迟的消息能够顺序消费。broker会调度地消费SCHEDULE_TOPIC_XXXX,将消息写入真实的topic。
    其具体步骤如下:

    • 修改消息Topic名称和队列信息

    • 转发消息到延迟主题SCHEDULE_TOPIC_XXXX的CosumeQueue中

    • 延迟服务消费SCHEDULE_TOPIC_XXXX消息

    • 将信息重新存储到CommitLog中

    • 将消息投递到目标Topic中

    • 消费者消费目标topic中的数据。

       public void sendDelayMessage(String topic,Object msg)   {      Message msgMessage =new Message();      //设置消息等级      msgMessage.setDelayTimeLevel(2);     rocketMQTemplate.convertAndSend(topic, msg);   }

    注意:RocketMQ延时消息的延迟时长不支持随意时长的延迟,是通过特定的延迟等级来指定的。默认支持18个等级的延迟消息,延时等级定义在RocketMQ服务端的MessageStoreConfig类中的如下变量中:

    Java处理延时任务的解决方案有哪些

    例如指定的延时等级为2,则表示延迟时长为5s,即延迟等级是从1开始计数的。

    优缺点

    优点:

    支持高并发场景消息处理.

    缺点:

    • 引入额外的消息队列,增加项目的维护和复杂度。

    • 支持固定时长的消息延迟,针对任意时长的消息延迟需要进行扩展。

    “Java处理延时任务的解决方案有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    Java处理延时任务的解决方案有哪些

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    Java处理延时任务的解决方案有哪些

    本篇内容介绍了“Java处理延时任务的解决方案有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!数据库轮询原理通过一个线程定时的扫描数据库
    2023-06-30

    Java并行执行任务的方案有哪些

    本篇内容介绍了“Java并行执行任务的方案有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!背景最近在排查生产环境问题,发现商品详情接口时
    2023-06-25

    java定时任务实现的方式有哪些

    Java中实现定时任务的方式有以下几种:1. Timer类:Java提供了Timer类,可以用来实现简单的定时任务。Timer类允许我们指定一个时间间隔,然后在指定的时间间隔后执行任务。但是Timer类有一些缺点,比如当执行任务的时间超过了
    2023-08-29

    批处理bat延时执行命令的方法有哪些

    这篇文章主要介绍“批处理bat延时执行命令的方法有哪些”,在日常操作中,相信很多人在批处理bat延时执行命令的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”批处理bat延时执行命令的方法有哪些”的疑
    2023-06-09

    Java中定时任务的实现方式有哪些

    本篇内容主要讲解“Java中定时任务的实现方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中定时任务的实现方式有哪些”吧!1、线程等待实现先从最原始最简单的方式来讲解。可以先创建
    2023-06-25

    云服务器解决延迟的方法有哪些

    云服务器延迟优化减少云服务器延迟至关重要,可提升用户体验和应用程序性能。优化方法包括:优化网络连接(高带宽、优化路径、减少跳数)优化云服务器配置(高性能实例、加速功能、调整设置)优化应用程序代码(高效算法、并行处理、缓存/预取)其他措施(CDN、负载平衡、监控、协作、特定工具)
    云服务器解决延迟的方法有哪些
    2024-04-13

    云服务器解决延迟的方法有哪些

    云服务器解决延迟的方法有以下几种:1. 使用CDN(内容分发网络):通过将内容部署到全球各地的服务器上,使用户可以从离他们地理位置最近的服务器获取内容,从而减少延迟。2. 使用负载均衡:将请求分发到多台服务器上,以减轻单台服务器的压力,提高
    2023-09-09

    使用Java实现定时任务的方法有哪些

    使用Java实现定时任务的方法有哪些?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、 sleep这也是我们最常用的 sleep 休眠大法,不只是当作休眠用,我们还可以利用它很
    2023-06-08

    java超时异常处理的方法有哪些

    Java中超时异常处理的方法有以下几种:使用线程的interrupt()方法:在执行任务的线程中设置一个定时器,当任务执行时间超过预设的时间时,调用线程的interrupt()方法中断任务的执行。任务中需要通过判断线程的中断状态来提前结束任
    2023-10-26

    windows任务管理器打不开解决方法有哪些

    windows任务管理器打不开解决方法有哪些,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。第一个原因:是不是内存吃紧导致,如果电脑都不动或死机了,也是打不开任务管理器的,如
    2023-06-14

    数据库连接超时java处理的方式有哪些

    这篇文章主要讲解了“数据库连接超时java处理的方式有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“数据库连接超时java处理的方式有哪些”吧!数据库连接超时java处理的方式在测试一套
    2023-07-06

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录