范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

三XXLJOB)

  pom.xml中引入依赖      com.xuxueli     xxl-job-core     2.3.0 配置XXL-JOB的数据源# xxl-job 配置 xxl:   job:     # 调度中心地址:如调度中心集群部署存在多个地址则用逗号分隔。     admin:        addresses: http://localhost:8080/xxl-job-admin     # 执行器通讯TOKEN:非空时启用     accessToken:     # 执行器配置     executor:       # 执行器AppName:执行器心跳注册分组依据;为空则关闭自动注册       appname: xxl-job-executor-sample       # 执行器端口号 执行器从9101开始往后写       port: 9101       # 执行器注册:默认IP:PORT       address:       # 执行器IP:默认自动获取IP       ip:       # 执行器运行日志文件存储磁盘路径       logpath: ./logs/xxl-job       # 执行器日志文件保存天数:大于3生效       logretentiondays: 30创建XXL-JOB配置类package com.lucksoft.schedule.config;  import com.xxl.job.core.executor.impl.XxlJobSpringExecutor; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;  /**  * xxl-job config  */ @Configuration public class XxlJobConfig {     private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class);      @Value("${xxl.job.admin.addresses}")     private String adminAddresses;      @Value("${xxl.job.accessToken}")     private String accessToken;      @Value("${xxl.job.executor.appname}")     private String appname;      @Value("${xxl.job.executor.address}")     private String address;      @Value("${xxl.job.executor.ip}")     private String ip;      @Value("${xxl.job.executor.port}")     private int port;      @Value("${xxl.job.executor.logpath}")     private String logPath;      @Value("${xxl.job.executor.logretentiondays}")     private int logRetentionDays;       @Bean     public XxlJobSpringExecutor xxlJobExecutor() {         logger.info(">>>>>>>>>>> xxl-job config init.");         XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();         xxlJobSpringExecutor.setAdminAddresses(adminAddresses);         xxlJobSpringExecutor.setAppname(appname);         xxlJobSpringExecutor.setAddress(address);         xxlJobSpringExecutor.setIp(ip);         xxlJobSpringExecutor.setPort(port);         xxlJobSpringExecutor.setAccessToken(accessToken);         xxlJobSpringExecutor.setLogPath(logPath);         xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays);          return xxlJobSpringExecutor;     }  }创建JobHandlerpackage com.lucksoft.schedule.service.jobhandler;  import com.xxl.job.core.context.XxlJobHelper; import com.xxl.job.core.handler.annotation.XxlJob; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component;  import java.io.BufferedInputStream; import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; import java.util.Arrays; import java.util.concurrent.TimeUnit;  /**  * XxlJob开发示例(Bean模式)  *  * 开发步骤:  *      1、任务开发:在Spring Bean实例中,开发Job方法;  *      2、注解配置:为Job方法添加注解 "@XxlJob(value="自定义jobhandler名称", init = "JobHandler初始化方法", destroy = "JobHandler销毁方法")",注解value值对应的是调度中心新建任务的JobHandler属性的值。  *      3、执行日志:需要通过 "XxlJobHelper.log" 打印执行日志;  *      4、任务结果:默认任务结果为 "成功" 状态,不需要主动设置;如有诉求,比如设置任务结果为失败,可以通过 "XxlJobHelper.handleFail/handleSuccess" 自主设置任务结果;  */ @Component public class XxlJobService {     private static Logger logger = LoggerFactory.getLogger(XxlJobService.class);       /**      * 1、简单任务示例(Bean模式)      */     @XxlJob("demoJobHandler")     public void demoJobHandler() throws Exception {         XxlJobHelper.log("XXL-JOB, Hello World.");          for (int i = 0; i < 5; i++) {             XxlJobHelper.log("beat at:" + i);             TimeUnit.SECONDS.sleep(2);         }         // default success     }       /**      * 2、分片广播任务      */     @XxlJob("shardingJobHandler")     public void shardingJobHandler() throws Exception {          // 分片参数         int shardIndex = XxlJobHelper.getShardIndex();         int shardTotal = XxlJobHelper.getShardTotal();          XxlJobHelper.log("分片参数:当前分片序号 = {}, 总分片数 = {}", shardIndex, shardTotal);          // 业务逻辑         for (int i = 0; i < shardTotal; i++) {             if (i == shardIndex) {                 XxlJobHelper.log("第 {} 片, 命中分片开始处理", i);             } else {                 XxlJobHelper.log("第 {} 片, 忽略", i);             }         }      }       /**      * 3、命令行任务      */     @XxlJob("commandJobHandler")     public void commandJobHandler() throws Exception {         String command = XxlJobHelper.getJobParam();         int exitValue = -1;          BufferedReader bufferedReader = null;         try {             // command process             ProcessBuilder processBuilder = new ProcessBuilder();             processBuilder.command(command);             processBuilder.redirectErrorStream(true);              Process process = processBuilder.start();             //Process process = Runtime.getRuntime().exec(command);              BufferedInputStream bufferedInputStream = new BufferedInputStream(process.getInputStream());             bufferedReader = new BufferedReader(new InputStreamReader(bufferedInputStream));              // command log             String line;             while ((line = bufferedReader.readLine()) != null) {                 XxlJobHelper.log(line);             }              // command exit             process.waitFor();             exitValue = process.exitValue();         } catch (Exception e) {             XxlJobHelper.log(e);         } finally {             if (bufferedReader != null) {                 bufferedReader.close();             }         }          if (exitValue == 0) {             // default success         } else {             XxlJobHelper.handleFail("command exit value("+exitValue+") is failed");         }      }       /**      * 4、跨平台Http任务      *  参数示例:      *      "url: http://www.baidu.com " +      *      "method: get " +      *      "data: content ";      */     @XxlJob("httpJobHandler")     public void httpJobHandler() throws Exception {          // param parse         String param = XxlJobHelper.getJobParam();         if (param==null || param.trim().length()==0) {             XxlJobHelper.log("param["+ param +"] invalid.");              XxlJobHelper.handleFail();             return;         }          String[] httpParams = param.split(" ");         String url = null;         String method = null;         String data = null;         for (String httpParam: httpParams) {             if (httpParam.startsWith("url:")) {                 url = httpParam.substring(httpParam.indexOf("url:") + 4).trim();             }             if (httpParam.startsWith("method:")) {                 method = httpParam.substring(httpParam.indexOf("method:") + 7).trim().toUpperCase();             }             if (httpParam.startsWith("data:")) {                 data = httpParam.substring(httpParam.indexOf("data:") + 5).trim();             }         }          // param valid         if (url==null || url.trim().length()==0) {             XxlJobHelper.log("url["+ url +"] invalid.");              XxlJobHelper.handleFail();             return;         }         if (method==null || !Arrays.asList("GET", "POST").contains(method)) {             XxlJobHelper.log("method["+ method +"] invalid.");              XxlJobHelper.handleFail();             return;         }         boolean isPostMethod = method.equals("POST");          // request         HttpURLConnection connection = null;         BufferedReader bufferedReader = null;         try {             // connection             URL realUrl = new URL(url);             connection = (HttpURLConnection) realUrl.openConnection();              // connection setting             connection.setRequestMethod(method);             connection.setDoOutput(isPostMethod);             connection.setDoInput(true);             connection.setUseCaches(false);             connection.setReadTimeout(5 * 1000);             connection.setConnectTimeout(3 * 1000);             connection.setRequestProperty("connection", "Keep-Alive");             connection.setRequestProperty("Content-Type", "application/json;charset=UTF-8");             connection.setRequestProperty("Accept-Charset", "application/json;charset=UTF-8");              // do connection             connection.connect();              // data             if (isPostMethod && data!=null && data.trim().length()>0) {                 DataOutputStream dataOutputStream = new DataOutputStream(connection.getOutputStream());                 dataOutputStream.write(data.getBytes("UTF-8"));                 dataOutputStream.flush();                 dataOutputStream.close();             }              // valid StatusCode             int statusCode = connection.getResponseCode();             if (statusCode != 200) {                 throw new RuntimeException("Http Request StatusCode(" + statusCode + ") Invalid.");             }              // result             bufferedReader = new BufferedReader(new InputStreamReader(connection.getInputStream(), "UTF-8"));             StringBuilder result = new StringBuilder();             String line;             while ((line = bufferedReader.readLine()) != null) {                 result.append(line);             }             String responseMsg = result.toString();              XxlJobHelper.log(responseMsg);              return;         } catch (Exception e) {             XxlJobHelper.log(e);              XxlJobHelper.handleFail();             return;         } finally {             try {                 if (bufferedReader != null) {                     bufferedReader.close();                 }                 if (connection != null) {                     connection.disconnect();                 }             } catch (Exception e2) {                 XxlJobHelper.log(e2);             }         }      }      /**      * 5、生命周期任务示例:任务初始化与销毁时,支持自定义相关逻辑;      */     @XxlJob(value = "demoJobHandler2", init = "init", destroy = "destroy")     public void demoJobHandler2() throws Exception {         XxlJobHelper.log("XXL-JOB, Hello World.");     }     public void init(){         logger.info("init");     }     public void destroy(){         logger.info("destroy");     }   }
  Ps: 具体目录结构如下:
  访问任务调度平台
  1. 访问http://localhost:8080/xxl-job-admin,输入账号/密码:admin/123456
  2. 配置执行器
  3. 任务管理中新增任务
  4. 点击启动,启动任务,启动后点击日志,查看执行日志
  5. 新增任务时具体配置的含义执行器:任务绑定的执行器,任务触发调度时将会自动发现注册成功的执行器, 实现任务自动发现功能; 另一方面也可以方便地进行任务分组。每个任务必须绑定一个执行器, 可在 "执行器管理" 进行设置; 任务描述:任务的描述信息,便于任务管理; 路由策略:当执行器集群部署时,提供丰富的路由策略,包括;
  FIRST(第一个):固定选择第一个机器;
  LAST(最后一个):固定选择最后一个机器;
  ROUND(轮询):;
  RANDOM(随机):随机选择在线的机器;
  CONSISTENT_HASH(一致性HASH):每个任务按照Hash算法固定选择某一台机器,且所有任务均匀散列在不同机器上。
  LEAST_FREQUENTLY_USED(最不经常使用):使用频率最低的机器优先被选举;
  LEAST_RECENTLY_USED(最近最久未使用):最久为使用的机器优先被选举;
  FAILOVER(故障转移):按照顺序依次进行心跳检测,第一个心跳检测成功的机器选定为目标执行器并发起调度;
  BUSYOVER(忙碌转移):按照顺序依次进行空闲检测,第一个空闲检测成功的机器选定为目标执行器并发起调度;
  SHARDING_BROADCAST(分片广播):广播触发对应集群中所有机器执行一次任务,同时系统自动传递分片参数;可根据分片参数开发分片任务; Cron:触发任务执行的Cron表达式; 运行模式:
  BEAN模式:任务以JobHandler方式维护在执行器端;需要结合 "JobHandler" 属性匹配执行器中的任务;
  GLUE模式(Java):任务以源码方式维护在调度中心;该模式的任务实际上是一段时间继承自IJobHandler的Java类代码并 "groovy" 源码方式维护,它在执行器项目中运行,可使用@Resource/@Autowire注入执行器里中的其他服务;
  GLUE模式(Shell):任务以源码方式维护在调度中心;该模式的任务实际上是一段 "shell" 脚本;
  GLUE模式(Python):任务以源码方式维护在调度中心;该模式的任务实际上是一段 "python" 脚本;
  GLUE模式(PHP):任务以源码方式维护在调度中心;该模式的任务实际上是一段 "php" 脚本;
  GLUE模式(NodeJS):任务以源码方式维护在调度中心;该模式的任务实际上是一段 "nodejs" 脚本;
  GLUE模式(PowerShell):任务以源码方式维护在调度中心;该模式的任务实际上是一段 "PowerShell" 脚本; JobHandler:运行模式为 "BEAN模式" 时生效,对应执行器中新开发的JobHandler类"@JobHandler"注解自定义的value值; 阻塞处理策略:调度过于密集执行器来不及处理时的处理策略;
  单机串行(默认):调度请求进入单机执行器后,调度请求进入FIFO队列并以串行方式运行;
  丢弃后续调度:调度请求进入单机执行器后,发现执行器存在运行的调度任务,本次请求将会被丢弃并标记为失败;
  覆盖之前调度:调度请求进入单机执行器后,发现执行器存在运行的调度任务,将会终止运行中的调度任务并清空队列,然后运行本地调度任务; 子任务:每个任务都拥有一个唯一的任务ID(任务ID可以从任务列表获取),当本任务执行结束并且执行成功时,将会触发子任务ID所对应的任务的一次主动调度。 任务超时时间:支持自定义任务超时时间,任务运行超时将会主动中断任务; 失败重试次数;支持自定义任务失败重试次数,当任务失败时将会按照预设的失败重试次数主动进行重试; 报警邮件:任务调度失败时邮件通知的邮箱地址,支持配置多邮箱地址,配置多个邮箱地址时用逗号分隔; 负责人:任务的负责人; 执行参数:任务执行所需的参数,多个参数时用逗号分隔,任务执行时将会把多个参数转换成数组传入;

微信注册功能终于恢复了,快冲经过向腾讯客服核实,客服回复目前平台系统正在进行技术升级,期间暂停微信个人账号新用户注册,预计8月初完成升级并恢复注册。本来小编以为,能注册微信的大多都已经注册过了,暂停注册好像也手机不是重点,王凯才是360奇酷极客版发布带来了什么?你和王凯时刻在一起,你可以存储王凯全部的视频作品,在今天360新品手机发布会上,王凯始终站在舞台中间,相反,360手机的亮点却寥寥而已。其实,发布会上,360又重复了可以重复的几点GalaxyS7加拿大版跑分出炉,惨遭小米5碾压!今天,据某科技自媒体爆料,GalaxyS7加拿大版跑分出现在国外某跑分网站,性能与小米5相比稍稍落后。GalaxyS7加拿大版型号为SMG920W8,这和之前的惯例保持一致。Gal红米3,奇酷手机,努比亚Z11小米360努比亚新机扎堆话说现在已经是2016年了,各大手机厂商有开始跑轰战术。快快快!一大波新机来了,赶紧接招吧。今天,一股脑三家公司宣布了新机发布日期,分别是小米,360,努比亚,发布日期分别是12日还敢有销无进,税务局查的就是你,这37个账面涉税风险点请自查会计人在实际处理账务问题的时候,都会遇到各种各样的情况,有些情况,逻辑上看似没有任何问题,往往潜藏着一些涉税风险。所以,在日常工作中,加强对税务知识的学习就显得尤为重要。小编今天结恭喜!个人所得税降了!6月1日起,申报方式大变个税降了!国家税务总局连发两条公告,个体户在现行优惠政策基础上,再减半征收!01hr个税降了!税务局正式发文通知!划重点1个体户个人所得税减半征收对个体工商户经营所得年应纳税所得额顺丰巨亏10亿,原因竟是电子发票?顺丰一季度财报预亏11亿,原因竟是电子发票?电子发票有这么大威力?对财务人有什么影响?1hr快递巨头亏十亿,原因竟然是它?4月8日,顺丰发布了一季度业绩预告。预计一季度净利润亏损9税局突袭!彻查10年内的私户收款记录!这三类隐匿收入方式最危险利用私人账户避税,是大家能想到的最直接的最安全的避税方法了。甚至有法人表示,这种方法屡试不爽。私人账户避税搁以前的确是一种很好的方法。但2021年情况有变。不仅严查私户避税,还会清新款AirPods曝光外观进化到Pro版,却阉割了这一重要功能除了手机,大家对苹果产品最期待的应该就是AirPods系列的耳机了吧,毕竟苹果依靠这一产品引领了一波真无线耳机的热潮。现在,有了苹果全新AirPodsPro的消息。只不过这消息听起魅族17惊艳亮相,这项功能超华为P40Pro小米10虽然自己5G新机迟迟不能发布,但沉默已久的魅族决定打破沉寂,出来活动一下。昨天(4月17日),魅族在线上举办了魅族17mSmart5G快省稳技术分享会,推出了一套为解决5G痛点而生彻查10年内的私户收款记录!2021年这三类隐匿收入方式最危险利用私人账户避税,是大家能想到的最直接的最安全的避税方法了。甚至有法人表示,这种方法屡试不爽。私人账户避税搁以前的确是一种很好的方法。但2021年情况有变。不仅严查私户避税,还会清
机器人工程专业VS邮政工程专业一机器人工程专业解读机器人工程专业是什么?机器人工程属于自动化类专业,基本修业年限为四年,授予工学学士学位。该专业是以控制科学与工程机械工程计算机科学与技术材料科学与工程生物医学工同享科技1。05亿元再融资申请获北交所受理方案出炉2个月股价跌15挖贝网2月9日消息,北交所光伏焊带第一股同享科技(839167)1。05亿元再融资申请获北交所受理,再融资发行价尚未确定,但挖贝君注意到,公司再融资方案出炉2个月以来股价已跌15。捡漏老旗舰还是花大钱买新旗舰?内行人3个观点,有道理最近看到私信里大家关心最多的问题是春节之后应该如何买手机,是该捡漏买去年正在降价的旗舰机还是应该选今年已经发布或者马上发布的新手机?其实作为一个十八线的数码博主,这篇文章从客观的角苏宁易购春节消费榜单出炉懒人家电霸榜,运动潮玩礼盒遭疯抢今年春节,你买了哪些东西?你知道啥产品最火吗?最近,苏宁易购发布了春节消费数据榜单。从中不难发现,春节假期叠加运动会开幕,消费者的购买激情被充分点燃了。赛场内,奥运健儿奋勇夺金吸足网站静态资源为什么要用独立一级域名而不是二级域名?独立域名指的是一级域名而不是二级或三级域名大型网站的静态资源都是放在独立的域名之下的。浏览器的很多机制对网站的访问速度有很大的影响(例如浏览器对静态资源的缓存机制),此外浏览器为提威马汽车扎根中国的硬技术创新代表,推出W6购车礼遇活动威马汽车作为扎根中国的硬技术创新代表,致力于为每个普通人的日常生活奉献非凡的技术。凭借高质量的产品实力卓越的智能体验和创新的用户服务,威马汽车得到了市场和用户的高度认可。自2018央行等4部门稳步推进金融科技标准建设防范借科技名义违法违规从事金融业务央行等4部门稳步推进金融科技标准建设防范借科技名义违法违规从事金融业务财联社2月8日电,央行等4部门印发金融标准化十四五发展规划。其中提到,稳步推进金融科技标准建设。加强云计算区块央行等4部门稳步推进金融科技标准建设防范借科技名义违法违规从事金融业务央行等4部门印发金融标准化十四五发展规划。其中提到,稳步推进金融科技标准建设。加强云计算区块链大数据人工智能生物识别物联网等标准研制和有效应用,引领金融科技规范健康发展。深入实施金废墟中精准识别生命信号触嗅一体机械手有一手来源科技日报请试想这样的场景在地震或塌方后,视觉受限,人体被废墟掩埋,尘土飞沙遮挡视线,情况十分危急,而瓦砾混凝土钢筋等物体使得现场情况更为复杂。这样的情况下,救援人员不仅要及时救冬奥火炬传递首次出现5G无人车全球首台套5G8K全业务转播车开进北京冬奥会36氪5G创新日报0208作者李亚静编辑王与桐5G新应用冬奥火炬传递首次出现5G无人车近日,在北京冬奥开幕式上当众亮相,成就了台资企业的高光时刻。冬奥火炬传递中,首次出现了5G无人车传递火炬,这是奥运会历史建信基金田元泉张湘龙在新能源产业链赛道上快跑在投资的世界中,最大的机会通常来源于时代给予的机会。对这一点,建信新能源行业股票基金基金经理田元泉感受颇深。投资一定要紧跟经济结构和产业的变化,不能闭门造车,被时代甩在后面。田元泉