待遇任务执行器(dy-task-actuator-simple)文档

简介

  简称 dtas 吧。这是一个尚在起步但无需太多功能的执行器。

  心血来潮,做了一个任务执行器,倒不是一定要重复造轮子,而是没有发现开箱即用的任务执行器。

  ​这不是一个特别高性能的任务调度框架!只是一个任务执行器。唯一的优点就是简单。

  设计时希望 dtas 能够简单调控、限制资源使用、增大资源利用率、实现简易监控。为此采用了多级线程池、阻塞队列、信号量、令牌桶。

  dtas 适用于执行大量的 cpu 密集型、io 密集型、网络请求任务,也可用作并发的异步任务控制。

联系

  我会在每周六下午检查邮箱、留言和 issue

  1. 给我发送邮件: 17625901395@163.com
  2. 在博客园给我留言:https://www.cnblogs.com/dawnings/p/18588469/treatment-task-actuator-dytaskactuatorsimple-document-zka1bj
  3. 在 github 给我 issue:https://github.com/dawnings/dy-task-actuator-simple

支持

  1. 您可在博客园给我打赏。
  2. 作者时间并不充裕,故暂不支持pr,您可在issue中提供支持。

安装

  github 上 main 分支代码就是最新可用的完整代码,如有三方引用会在文档标注。

依赖

  dtas 通过 hutool​ 和 guava​ 减少造轮子。

  所有依赖如下:

artifactId groupId version scope
lombok org.projectlombok 1.18.26 provided
slf4j-api org.slf4j 2.0.16 provided
hutool-all cn.hutool 5.8.34 compile
guava com.google.guava 33.3.1-jre compile
junit junit 4.13.1 test

  项目构建环境如下:

name version
jdk 8
maven 3.6.3

功能清单

builder 构建工具

  • 配置任务名称
  • 通过任务名称获取任务执行器
  • 设定自定义通讯标记
  • 设定启动延迟时间
  • 设定限流器
  • 设定数据采集数量最低门限
  • 设定数据采集数量最高门限(任务队列极限)
  • 设定数据采集间隔最低门限
  • 设定数据采集间隔最高门限
  • 设定并发线程最高数量
  • 设定数据采集执行接口
  • 设定任务消费执行接口
  • 设定任务执行回调接口
  • 设定消费速率监控接口
  • 设定消费速率 X 轴生成器
  • 设定消费速率 X 轴生成通知接口
  • 设定限流器验证接口

执行器

  • 添加任务到等待队列
  • 添加任务到等待队列(阻塞)
  • 添加任务到执行队列
  • 终止执行器
  • 暂定执行器
  • 恢复执行器
  • 调整最大并发线程
  • 获取消费速率表
  • 获取运行状态参数

预实现接口

消费速率 X 轴生成器
  • 每 5s 生成
  • 每 1 分钟生成
  • 每 5 分钟生成
  • 10 分钟生成
限流验证器
  • 默认通过验证器

工具

  • 可动态限制大小的 LinkedHashMap
  • 可动态调控数量的信号量

集成

  • springboot-starter集成

待遇任务执行器(dy-task-actuator-simple)文档的更多相关文章

  1. 在线API文档管理工具Simple doc

    Simple doc是一个简易的文档发布管理工具,为什么要写Simple doc呢?主要原因还是github的wiki并不好用:没有目录结构,文章没有Hx标签索引,最悲剧的是文章编辑的时候不能直接图片 ...

  2. Spring Boot属性文件配置文档(全部)

    This sample file is meant as a guide only. Do not copy/paste the entire content into your applicatio ...

  3. 最近学习工作流 推荐一个activiti 的教程文档

    全文地址:http://www.mossle.com/docs/activiti/ Activiti 5.15 用户手册 Table of Contents 1. 简介 协议 下载 源码 必要的软件 ...

  4. Spring Boot文档

    本文来自于springboot官方文档 地址:https://docs.spring.io/spring-boot/docs/current/reference/html/ Spring Boot参考 ...

  5. ABP文档 - 通知系统

    文档目录 本节内容: 简介 发送模式 通知类型 通知数据 通知重要性 关于通知持久化 订阅通知 发布通知 用户通知管理器 实时通知 客户端 通知存储 通知定义 简介 通知用来告知用户系统里特定的事件发 ...

  6. ABP文档 - 本地化

    文档目录 本节内容: 简介 应用语言 本地化源 XML文件 注册XML本地化源 JSOn文件 注册JSON本地化源 资源文件 自定义源 获取一个本地文本 在服务端 在MVc控制器里 在MVC视图里 在 ...

  7. SpingMVC 核心技术帮助文档

    声明:本篇文档主要是用于参考帮助文档,没有实例,但几乎包含了SpringMVC 4.2版本的所有核心技术,当前最新版本是4.3,4.2的版本已经经是很新的了,所以非常值得大家一读,对于读完这篇文档感觉 ...

  8. ABP 教程文档 1-1 手把手引进门之 ASP.NET Core & Entity Framework Core(官方教程翻译版 版本3.2.5)

    本文是ABP官方文档翻译版,翻译基于 3.2.5 版本 官方文档分四部分 一. 教程文档 二.ABP 框架 三.zero 模块 四.其他(中文翻译资源) 本篇是第一部分的第一篇. 第一部分分三篇 1- ...

  9. ABP文档笔记 - 通知

    基础概念 两种通知发送方式 直接发送给目标用户 用户订阅某类通知,发送这类通知时直接分发给它们. 两种通知类型 一般通知:任意的通知类型 "如果一个用户发送一个好友请求,那么通知我" ...

  10. Anakia 转换xml文档为其他格式

    一.简介 Anakia 使用JDOM 和Velocity将XML文档转换为特定格式的文档 二.解析xml文档方法 1.DOM java jdk,xml-api.jar 需要加载整个xml文档来构建层次 ...

随机推荐

  1. 14. 迭代器、生成器、模块与包、json模块

    1.迭代器 1.1 迭代器介绍 迭代器是用来迭代取值的工具 每一次迭代得到的结果会作为下一次迭代的初始值,单纯的重复并不是迭代 # while循环实现迭代取值 a = [1, 2, 3, 4, 5, ...

  2. 获取sql语句

    1.$model->_sql(); 方法实际执行的就是 $model->getLastSql(); 2.fetchSql fetchSql用于直接返回SQL而不是执行查询,适用于任何的CU ...

  3. 云原生周刊:KubeSphere 宣布开源 Thanos 的企业级发行版 Whizard

    开源项目推荐 Admiralty Admiralty 是一个 Kubernetes 控制器系统,可以智能地在多个集群之间调度工作负载.它使用简单,并且易于与其他工具集成. Cozystack Cozy ...

  4. 题解:P9784 [ROIR 2020 Day1] 超速

    传送门 洛谷题解 思路 我们设 \(T\) 为所花的总时间,\(d\) 为超速多少. 然后不难知道 $ T = \sum_{i = 1}^{n} \frac{l_i}{v_i+d}$,所以我们实际上是 ...

  5. 认识JVM

    类加载器 运行时数据区 执行引擎 执行引擎的任务就是将字节码指令解释/编译为对应平台上的本地机器指令 JVM架构图

  6. docker容器开启ssh服务

    http://www.dtmao.cc/news_show_703007.shtml Step1 利用CentOS基础镜像,创建一个docker容器,主要这里要指定端口映射,必须要映射到容器内的22端 ...

  7. Cartographer学习——地图概率更新过程

    前言:最近一直在研究建图,对google的开源SLAM框架 Cartographer 进行了源码梳理,发现很多巧妙的算法设计,结合原论文 <Real-time Loop Closure in 2 ...

  8. ROS入门21讲(7)

    十二.launch启动文件的使用方法 1.launch文件:通过XML文件实现多节点的配置和启动(可自动启动ROS Master) 2.Launch文件语法: <launch> <n ...

  9. 全面解释人工智能LLM模型的真实工作原理(三)

    前一篇:<全面解释人工智能LLM模型的真实工作原理(二)> 序言:前面两节中,我们介绍了大语言模型的设计图和实现了一个能够生成自然语言的神经网络.这正是现代先进人工智能语言模型的雏形.不过 ...

  10. Selenium操作:测试form表单

    from表单是经常测试的用例,用户登录.注册等都会用到form表单,本文简单设计了一个用户登录的form表单,并对该form表单进行测试 一.自定义form表单 1.用到的组件 如下图,图中定义了一个 ...