博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
分布式系统中的定时任务全解(四)--补充
阅读量:6146 次
发布时间:2019-06-21

本文共 1007 字,大约阅读时间需要 3 分钟。

  hot3.png

概述

这个系列计划里面是只有3篇,但是在后续使用的过程中发现了新的问题,以及发现了一个很重要但是没有写上的部分。

遇到的问题是在服务器上运行时,有可能是服务器的CPU和内存资源比个人笔记本上的资源要强大,导致在服务器上采用第三篇 中说到的“如果我需要在job中重新设定下次触发的时间怎么办”中给出的方式,在日志中看到在reschedule的时候,同时出发最多接近10次。

第三篇没有写上的内容是,如何看zookeeper上的节点信息。

接下来一起看一下以上两个点。

使用elastic-job在job内部调用reschedule遇到的问题

在job内部调用reschedule时由于第三篇中说到的下次触发时间计算的问题,导致在reschedule的时刻任务被同时触发了多次,尤其是当服务器空闲资源比较多,或者服务器资源比较强大的时候,触发的次数会更多。

对于这个问题,我们期初使用的是Thread.sleep(1)的方式规避,最好的情况下定时任务1分钟能够执行60,000次。如果用于处理订单的话,这个处理能力对于小型系统来说相当好了,足够用了。

但是,同时触发的现象确实感觉十分不舒服,并且会导致很多无效日志的输出,造成日志体积增大。

由于当前我们的系统规模较小,订单量也小,使用了Thread.sleep(500)的激进方案,这样算下来1分钟内最多最好也就能够处理120次,虽然这个数字很小,但是对我们当前情况来说足够用。

对于这个问题,如果仍然基于elastic-job框架最扩展的话,我们想可以这样处理:借助elastic-job的分片机制,在把待处理订单号插入队列中时添加不同的序列标记,可以和分片数相同。那么总体处理能力就会和服务器的数量成正比:120xN次(N是服务器数量)。这就达到了处理能力的水平扩展。

我如何知道自己任务的执行情况和任务节点的状态信息

这一点有两种方法,一个就是部署一个elastic-job的console服务,通过网页端查看任务的执行情况和任务节点的状态信息。

如果觉得不熟一套console服务必要性不大,也可以自己到zookeeper上查看各个节点的状态。zookeeper有一个eclispe的插件,可以直接在eclipse里面看到zk的节点数据。

安装插件可以参考这篇文章:

转载于:https://my.oschina.net/dabird/blog/830148

你可能感兴趣的文章
检查磁盘利用率并且定期发送告警邮件
查看>>
MWeb 1.4 新功能介绍二:静态博客功能增强
查看>>
摄像机与绕任意轴旋转
查看>>
rsync 服务器配置过程
查看>>
预处理、const与sizeof相关面试题
查看>>
爬虫豆瓣top250项目-开发文档
查看>>
Elasticsearch增删改查
查看>>
oracle归档日志增长过快处理方法
查看>>
有趣的数学书籍
查看>>
teamviewer 卸载干净
查看>>
多线程设计模式
查看>>
解读自定义UICollectionViewLayout--感动了我自己
查看>>
SqlServer作业指定目标服务器
查看>>
UnrealEngine4.5 BluePrint初始化中遇到编译警告的解决办法
查看>>
User implements HttpSessionBindingListener
查看>>
抽象工厂方法
查看>>
焊盘 往同一个方向增加 固定的长度方法 总结
查看>>
eclipse的maven、Scala环境搭建
查看>>
架构师之路(一)- 什么是软件架构
查看>>
jquery的冒泡和默认行为
查看>>