Cluster模式潜在问题学习笔记---分布式调度之Elastic-Job介绍

Cluster模式潜在问题学习笔记—分布式调度之Elastic-Job介绍

1.Elastic-Job介绍

Elastic-Job是当当⽹开源的⼀个分布式调度解决⽅案,基于Quartz⼆次开发的,由两个相互独⽴的⼦项⽬Elastic-Job-Lite和Elastic-Job-Cloud组成。我们要学习的是 Elastic-Job-Lite,它定位为轻量级⽆中⼼化解决⽅案,使⽤Jar包的形式提供分布式任务的协调服务,⽽Elastic-Job-Cloud⼦项⽬需要结合Mesos以及Docker在云环境下使⽤。

2.主要功能介绍

  1. 分布式调度协调:在分布式环境中,任务能够按指定的调度策略执⾏,并且能够避免同⼀任务多实例重复执⾏
  2. 丰富的调度策略基于成熟的定时任务作业框架Quartz cron表达式执⾏定时任务
  3. 弹性扩容缩容当集群中增加某⼀个实例,它应当也能够被选举并执⾏任务;当集群减少⼀个实例时,它所执⾏的任务能被转移到别的实例来执⾏。
  4. 失效转移某实例在任务执⾏失败后,会被转移到其他实例执⾏
  5. 错过执⾏作业重触发若因某种原因导致作业错过执⾏,⾃动记录错过执⾏的作业,并在上次作业完成后⾃动触发。
  6. ⽀持并⾏调度⽀持任务分⽚,任务分⽚是指将⼀个任务分为多个⼩任务项在多个实例同时执⾏。
  7. 作业分⽚⼀致性当任务被分⽚后,保证同⼀分⽚在分布式环境中仅⼀个执⾏实例。

3. Elastic-Job-Lite应⽤

  1. jar包(API) + 安装zookeeper软件
  2. Elastic-Job依赖于Zookeeper进⾏分布式协调,所以需要安装Zookeeper软件(3.4.6版本以上)
  3. 关于Zookeeper,此处我们不做详解,在阶段三会有深度学习,我们此处需要明⽩Zookeeper的本质功能:存储+通知。
  4. 安装Zookeeper(此处单例配置)
    1. 我们使⽤3.4.10版本,在linux平台解压下载的zookeeper-3.4.10.tar.gz
    2. 进⼊conf⽬录,cp zoo_sample.cfg zoo.cfg
    3. 进⼊bin⽬录,启动zk服务
    4. 启动 ./zkServer.sh start
    5. 停⽌ ./zkServer.sh stop
    6. 查看状态 ./zkServer.sh status
  5. Zookeeper的树形节点结构图
    在这里插入图片描述

4.Elastic-Job-Lite轻量级去中⼼化的特点

在这里插入图片描述

5.调度任务分片理解

  1. ⼀个⼤的⾮常耗时的作业Job,⽐如:⼀次要处理⼀亿的数据,那这⼀亿的数据存储在数据库中,如果⽤⼀个作业节点处理⼀亿数据要很久,在互联⽹领域是不太能接受的,互联⽹领域更希望机器的增加去横向扩展处理能⼒。
  2. 所以,ElasticJob可以把作业分为多个的task(每⼀个task就是⼀个任务分⽚),每⼀个task交给具体的⼀个机器实例去处理(⼀个机器实例是可以处理多个task的),但是具体每个task执⾏什么逻辑由我们⾃⼰来指定。
    在这里插入图片描述
  3. Strategy策略定义这些分⽚项怎么去分配到各个机器上去,默认是平均去分,可以定制,⽐如某⼀个机器负载 ⽐较⾼或者预配置⽐较⾼,那么就可以写策略。
  4. 分⽚和作业本身是通过⼀个注册中⼼协调的,因为在分布式环境下,状态数据肯定集中到⼀点,才可以在分布式中沟通。

6. 弹性扩容

在这里插入图片描述

  1. 新增加⼀个运⾏实例app3,它会⾃动注册到注册中⼼,注册中⼼发现新的服务上线,注册中⼼会通知ElasticJob 进⾏重新分⽚,那么总得分⽚项有多少,那么就可以搞多少个实例机器,⽐如完全可以分1000⽚
    最多就可以有多少app实例,,,,机器能成的主,完全可以分1000⽚,那么就可以搞1000台机器⼀起执⾏作业
  2. 注意:
    1. 分⽚项也是⼀个JOB配置,修改配置,重新分⽚,在下⼀次定时运⾏之前会重新调⽤分⽚算法,那么这个分⽚算法的结果就是:哪台机器运⾏哪⼀个⼀⽚,这个结果存储到zk中的,主节点会把分⽚给分好放到注册中⼼去,然后执⾏节点从注册中⼼获取信息(执⾏节点在定时任务开启的时候获取相应的分⽚)。
    2. 如果所有的节点挂掉值剩下⼀个节点,所有分⽚都会指向剩下的⼀个节点,这也是ElasticJob的⾼可⽤。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值