应用办公生活信息教育商业
投稿投诉
商业财经
汽车智能
教育国际
房产环球
信息数码
热点科技
生活手机
晨报新闻
办公软件
科学动态
应用生物
体育时事

面试官问,怎么实现一个定时任务调度器?如果是分布式下的呢?

  首先要思考一下通用的定时器大概包含哪些要素?首先,应该听过Quartz,SpringSchedule等框架;往分布式研究,又有SchedulerX,ElasticJob等分布式任务调度。那么往底层实现看,又有多种定时器实现方案的原理、工作效率、数据结构等等可以进行思考。
  那么抽象来说,定时器大概包含如下属性,判断一个任务是否到期,基本会采用轮询的方式,每隔一个时间片去检查最近的任务是否到期,并且,在NewTask和Cancel的行为发生之后,任务调度策略也会出现调整。存储一系列的任务集合,并且Deadline越接近的任务,拥有越高的执行优先级NewTask:将新任务加入任务集合Cancel:取消某个任务Run:执行一个到期的定时任务
  框架列举【单机】ScheduledExecutorService:相对延迟或者周期作为定时任务调度,缺点没有绝对的日期或者时间【单机】spring定时框架:配置简单功能较多,如果系统使用单机的话可以优先考虑spring定时器【分布式】Quartz:Java事实上的定时任务标准。但是Quartz可以基于数据库实现作业的高可用,有侵入性,而且缺少分布式并行调度的功能【分布式】Springbatch:轻量级的,完全面向Spring的批处理框架,可以应用于企业级大量的数据处理系统。SpringBatch可以提供大量的,可重复的数据处理功能,包括日志记录跟踪,事务管理,作业处理统计工作重新启动、跳过,和资源管理等重要功能。【分布式】elasticjob:当当开发的弹性分布式任务调度系统,功能丰富强大,采用zookeeper实现分布式协调,实现任务高可用以及分片【分布式】xxljob:是大众点评员工徐雪里于2015年发布的分布式任务调度平台,是一个轻量级分布式任务调度框架,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。支持集群部署xjob:保证每个集群节点配置(db和登陆账号等)保持一致。调度中心通过db配置区分不同集群。执行器支持集群部署,提升调度系统可用性,同时提升任务处理能力。集群部署唯一要求为:保证集群中每个执行器的配置项xxl。job。admin。addresses调度中心地址保持一致,执行器根据该配置进行执行器自动注册等操作。ejob:重写Quartz基于数据库的分布式功能,用Zookeeper实现注册中心。作业注册中心:基于Zookeeper和其客户端Curator实现的全局作业注册控制中心。用于注册,控制和协调分布式作业执行。多节点部署时任务不能重复执行xjob:使用Quartz基于数据库的分布式功能ejob:将任务拆分为n个任务项后,各个服务器分别执行各自分配到的任务项。一旦有新的服务器加入集群,或现有服务器下线,elasticjob将在保留本次任务执行不变的情况下,下次任务开始前触发任务重分片。日志xjob:支持日志可追溯,有日志查询界面ejob:可通过事件订阅的方式处理调度过程的重要事件,用于查询、统计和监控。ElasticJob目前提供了基于关系型数据库两种事件订阅方式记录事件监控报警xjob:调度失败时,将会触发失败报警,如发送报警邮件。任务调度失败时邮件通知的邮箱地址,支持配置多邮箱地址,配置多个邮箱地址时用逗号分隔ejob:通过事件订阅方式可自行实现弹性扩容缩容xjob:使用Quartz基于数据库的分布式功能,服务器超出一定数量会给数据库造成一定的压力ejob:通过zk实现各服务的注册、控制及协调支持并行调度xjob:调度系统多线程(默认10个线程)触发调度运行,确保调度精确执行,不被堵塞ejob:采用任务分片方式实现。将一个任务拆分为n个独立的任务项,由分布式的服务器并行执行各自分配到的分片项高可用策略xjob:调度中心通过DB锁保证集群分布式调度的一致性,一次任务调度只会触发一次执行ejob:调度器的高可用是通过运行几个指向同一个ZooKeeper集群的ElasticJobCloudScheduler实例来实现的。ZooKeeper用于在当前主ElasticJobCloudScheduler实例失败的情况下执行领导者选举。通过至少两个调度器实例来构成集群,集群中只有一个调度器实例提供服务,其他实例处于待命状态。当该实例失败时,集群会选举剩余实例中的一个来继续提供服务失败处理策略xjob:调度失败时的处理策略,策略包括:失败告警(默认)、失败重试ejob:弹性扩容缩容在下次作业运行前重分片,但本次作业执行的过程中,下线的服务器所分配的作业将不会重新被分配。失效转移功能可以在本次作业运行中用空闲服务器抓取孤儿作业分片执行。同样失效转移功能也会牺牲部分性能对比总结xJob侧重的业务实现的简单和管理的方便,学习成本简单,失败策略和路由策略丰富。推荐使用在用户基数相对少,服务器数量在一定范围内的情景下使用eJob关注的是数据,增加了弹性扩容和数据分片的思路,以便于更大限度的利用分布式服务器的资源。但是学习成本相对高些,推荐在数据量庞大,且部署服务器数量较多时使用
  数据结构
  我们主要衡量NewTask(新增任务),Cancel(取消任务),Run(执行到期的定时任务)这三个指标,分析时间复杂度和空间复杂度。双向有序链表(LinkedList)
  NewTask:O(N)
  Cancel:O(1)
  Run:O(1)
  N:任务数堆(PriorityQueue)
  在Java中,PriorityQueue是一个天然的堆,可以利用传入的Comparator来决定其中元素的优先级。
  NewTask:O(logN)
  Cancel:O(logN)
  Run:O(1)
  N:任务数
  expireTime是Comparator的对比参数。NewTaskO(logN)和CancelO(logN)分别对应堆插入和删除元素的时间复杂度;RunO(1),由expireTime形成的小根堆,我们总能在堆顶找到最快的即将过期的任务。时间轮
  Netty针对IO超时调度的场景进行了优化,实现了HashedWheelTimer时间轮算法。
  HashedWheelTimer是一个环形结构,可以用时钟来类比,钟面上有很多bucket,每一个bucket上可以存放多个任务,使用一个List保存该时刻到期的所有任务,同时一个指针随着时间流逝一格一格转动,并执行对应bucket上所有到期的任务。任务通过取模决定应该放入哪个bucket。和HashMap的原理类似,newTask对应put,使用List来解决Hash冲突。
  NewTask:O(1)
  Cancel:O(1)
  Run:O(M)
  Tick:O(1)
  M:bucket,MNC,其中C为单轮bucket数,Netty中默认为512
  构造Netty的HashedWheelTimer时有两个重要的参数:tickDuration和ticksPerWheel。tickDuration:即一个bucket代表的时间,默认为100ms,Netty认为大多数场景下不需要修改这个参数;ticksPerWheel:一轮含有多少个bucket,默认为512个,如果任务较多可以增大这个参数,降低任务分配到同一个bucket的概率。层级时间轮
  Kafka针对时间轮算法进行了优化,实现了层级时间轮TimingWheel
  调度和任务分开执行
  把调度和任务执行,隔离成两个部分:调度中心和执行器。调度中心模块只需要负责任务调度属性,触发调度命令。执行器接收调度命令,去执行具体的业务逻辑,而且两者都可以进行分布式扩容。
  MQ模式
  调度中心依赖Quartz集群模式,当任务调度时候,发送消息到RabbitMQ。业务应用收到任务消息后,消费任务信息。
  这种模型充分利用了MQ解耦的特性,调度中心发送任务,应用方作为执行器的角色,接收任务并执行。
  但这种设计强依赖消息队列,可扩展性和功能,系统负载都和消息队列有极大的关联。这种架构设计需要架构师对消息队列非常熟悉。
  XXLJOB
  XXLJOB是一个分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用。

今明两年不买房,5年后房子随便买还是买不起?答案来了1998年,我国进行了商品房制度改革,终结了传统的福利分房制度,转而实行商品房制度。此后二十多年时间,房地产市场迎来了蓬勃发展的时期。新建商品房成交量逐渐上升,随之而来的,房价……30分钟续航感受航拍快乐DJIMiniSE值得入手吗?外出踏青用无人机俯拍城市美景也是不错的选择,提到无人机大家首先会想到大疆,这家客户遍布全球100多个国家的公司可是获得过不小的成就,就在2015年2月,美国著名商业杂志《快公司……一加新品OnePlusNordN300搭载联发科处理器,将于OnePlus透露了即将推出的NordN300的一些细节。首先,该机具有入门级机型中很少见到的33W快速有线充电。该公司发言人斯宾塞布兰克(SpenserBlank)表示,该设……二十大新闻中心组织中外记者沿北京中轴线参访活动中国日报北京10月13日电(记者邹红)2022年10月12日下午,中国共产党第二十次全国代表大会新闻中心组织近80名中外媒体记者沿北京中轴线开展揽胜中轴气象,品韵古都风华参观采……史可携老公走红毯,穿修身缎面裙小肚子鼓鼓,富豪老公硬汉风十足头条创作挑战赛好身材要么天生,要么依靠后天的自律,但是很遗憾出于多种原因,很多人二者都不具备。再加上年岁渐长,新陈代谢逐渐变得缓慢,想要维持好身材实属不易,对于明星来说也……西山区2022年灵活就业人员基本养老保险费申报核定告知书来啦按照云南省人力资源和社会保障厅云南省财政厅《关于2022年度全省职工基本养老保险和工伤保险相关参数的通知》(云人社发202244号)和《关于印发云南省阶段性缓缴社会保险政策扩围……极致的站立技术!盘点综合格斗中最伟大的10名中量级选手中量级在综合格斗中属于很好看的一个级别,这个量级的大部分选手既有一击致命的力量和爆发力,又不至于因过高或过重而丧失掉技术和灵活性。回顾综合格斗的发展过程,几乎就是摔跤手和……iQOONeo7定档10月20日天玑9000旗舰配置中端价视频加载中。。。iQOONEO7话题热度是直线上升,可见性价比是真的深入人心。从最近爆料的信息来看iQOONeo7将有多处提升续航从现款4700毫安提升……戚薇真会玩,衣服不好好穿就算了,裤子还非得反着穿,意外洋气戚薇每一次的裤装选择和搭配都值得借鉴,她在选择裤装的时候,可以巧妙地利用吸睛点呈现时髦感,整体的牛仔元素看上去帅气有型,短款印花牛仔外套,瞬间提高身材比例,戚薇真会玩,衣服不好……人老都从哪里老?请君听俺老了歌人老了,人老了,人老先从哪里老?人老先从头上老。白头发多,黑头发少,就这就是人老了。人老是从哪里老?人老是从记性老。忘记的多,记住的少,就这就是人老了。人老先从哪里……甘蔗红糖鄂东乡村的甜蜜产业好甜啊,有小时候的味道。游客在花涧谷品尝了用古法制作的红糖水后发出一声赞叹。花涧谷坐落于湖北省黄冈市浠水县翟铺村,是集甘蔗种植、古法红糖制作、田园餐饮等产业为一体的田园综……解读戴森球,敲开宇宙高级文明大门的金钥匙太阳,就是人类的全部,更是太阳系的全部。太阳质量占据了整个太阳系质量的99。86,如果没有了太阳,太阳系也就不存在了。地球上我们能见到的所有能量几乎都是太阳能。太阳每秒钟……
马云隐居海外,刘强东定居国外,互联网大佬接连隐退,是怎么了?头条创作挑战赛马云于1993年,创建了阿里巴巴,这些年,他改变了我们的生活方式,带我们进入无现金时代,贡献不言而喻!2019年,55岁的马云,卸任阿里巴巴董事长,套现上千……应用场景加速落地新技术催生新业态5G无人驾驶摆渡车在景区行驶自如,机器人在田间地头实时监测、帮忙采收,矿工坐在操作间里远程挖矿当前,5G、人工智能、物联网等新技术加快融入千行百业,新应用新业态不断涌现,……欧冠冠军悲喜夜!皇马3战3胜,8。6亿航母逆袭,7冠王03惨北京时间10月6日,欧冠小组赛第3轮继续进行,皇马、凯尔特人、AC米兰、尤文、切尔西、多特蒙德和本菲卡7支前冠军球队齐齐登场亮相,但命运各不相同。皇马21顿涅茨克矿工……一个人命苦福薄的时候,就努力读书01hr有道是,学到用时方恨少。命苦福薄的人,不是没有机遇,也不是缺衣少食,而是机遇来了,却抓不住,只能在机遇面前,跺跺脚,抱怨几句。我们总是说,机遇留给有准备的人……人民日报金句摘抄(87)1。只有回看走过的路、比较别人的路、远眺前行的路,弄清楚我们从哪儿来、往哪儿去,很多问题才能看得深、把得准。2。旗帜决定方向,道路决定命运。3。不忘初心,牢记使命,……不说再见!59岁倪夏莲遗憾出局23次征战世乒赛,成都不是终点1983年4月28日,一位年仅19岁的姑娘懵懵懂懂地踏入了日本东京的球馆,迎来了第三十七届世乒赛的战斗。那一年,这个姑娘成为了世界最强的中国乒乓球队的主力,收获了女团与混……大数据,别再推送松弛感给我了冷知识:伪素颜妆的底妆层数,比夜店妆更厚松弛感太火了。太多相关帖子,以文艺片女星作为开头,以定义松弛感作为核心,以给出松弛感模版为结尾。你看是不是这样:首先,……10套造型,看看48岁超模katemoss的时尚风格变迁之路回顾这位超模的时尚,虽然性格变了,但她始终保持着自己的个性。造型师卡米拉尼克森说,没有人能模仿她的穿着。只要她穿上它,衣服就会变得栩栩如生。摄影师MarioSorr……2022世界最赚钱的11家公司腾讯末尾,中国四大行有三,苹果毫无疑问世界上大多数公司创立之初都是以赚钱为目的,这无可厚非,只有等其中的一些公司大到一定规模后他们才会去考虑社会责任、无偿公益等问题。那么大家是否好奇2022年有哪些是……周笔畅穿白色连衣裙搭配宝蓝色配饰,经典又高级,很有女人味喜欢经典设计的你可以来学习一下一字肩的设计,白色连衣裙用上一字肩,以及斗篷元素也可以,一字肩可以更好的一字肩修身肩部线条的同时,我们还可以稍微用心一些,比如说选择略有斗篷……我国成功发射综合性太阳探测卫星夸父一号10月9日7时43分,我国在酒泉卫星发射中心采用长征二号丁型运载火箭,成功将先进天基太阳天文台夸父一号发射升空,卫星顺利进入预定轨道,发射任务取得圆满成功。夸父一号全称先……青萝卜最好吃的做法,加3个鸡蛋,筷子一搅,营养又美味比肉还香生活没有彩排,美食没有美颜。大家好,今天用萝卜给大家分享一道美食。萝卜有白萝卜,胡萝卜。今天我们要用的是白萝卜,白萝卜的口感比较清脆好吃,可以生吃,可以用来做成美食。今天我们要……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网