当前位置: 首页 > news >正文

宣城网站制作网站建设在电子商务中意义

宣城网站制作,网站建设在电子商务中意义,joomla vs wordpress,php商城网站的要求与数据xxl-job介绍 XXL-JOB是一个分布式任务调度平台#xff0c;其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线#xff0c;开箱即用。 xxl是xxl-job的开发者大众点评的许雪里名称的拼音开头。 设计思想 将调度行为抽象形成“调度…xxl-job介绍 XXL-JOB是一个分布式任务调度平台其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线开箱即用。 xxl是xxl-job的开发者大众点评的许雪里名称的拼音开头。 设计思想 将调度行为抽象形成“调度中心”公共平台而平台自身并不承担业务逻辑“调度中心”负责发起调度请求。 将任务抽象成分散的JobHandler交由“执行器”统一管理“执行器”负责接收调度请求并执行对应的JobHandler中业务逻辑。 因此“调度”和“任务”两部分可以相互解耦提高系统整体稳定性和扩展性 系统组成 调度模块调度中心 负责管理调度信息按照调度配置发出调度请求自身不承担业务代码。调度系统与任务解耦提高了系统可用性和稳定性同时调度系统性能不再受限于任务模块 支持可视化、简单且动态的管理调度信息包括任务新建更新删除GLUE开发和任务报警等所有上述操作都会实时生效同时支持监控调度结果以及执行日志支持执行器Failover。执行模块执行器 负责接收调度请求并执行任务逻辑。任务模块专注于任务的执行等操作开发和维护更加简单和高效 接收“调度中心”的执行请求、终止请求和日志请求等。 总体架构图 执行流程 原理分析 1、执行器的注册和发现 执行器的注册和发现主要是关系两张表 xxl_job_group每个服务注册的实例列表。xxl_job_registry执行器的实例表保存实例信息和心跳信息。 执行器启动线程每隔30秒向注册表xxl_job_registry请求一次更新执行器的心跳信息调度中心启动 线程每隔30秒检测一次xxl_job_registry将超过90秒还没有收到心跳的实例信息从xxl_job_registry删除并更新xxl_job_group服务的实例列表信息。 2、调度中心调用执行器 调度中心的操作 调度中心通过循环不停的 关闭自动提交事务 利用mysql的悲观锁其他事务无法进入 select * from xxl_job_lock where lock_name schedule_lock for update3、读取数据库中的xxl_job_info记录定时任务的相关信息该表中有trigger_next_time字段表示下一次任务的触发时间。拿到距离当前时间5s内的任务列表分为三种情况处理 对于当前时间-任务的下一次触发时间5直接跳过不执行重置trigger_next_time的时间。(超过5s) 对于任务的下一次触发时间当前时间任务的下一次触发时间5的任务不超过5s的 ​ 开线程处理执行触发逻辑根据当前时间更新下一次任务触发时间 ​ 如果新的任务下一次触发时间-当前时间5,放到时间轮中时间轮是一个map private volatile static MapInteger, ListInteger ringData new ConcurrentHashMap();​ 根据新的任务下一次触发时间更新下下一次任务触发时间 对于任务的下一次触发时间当前时间将其放入时间轮中根据任务下一次触发时间更新下下一次任务触发时间 4、commit提交事务同时释放排他锁 5、执行器的操作 执行器接收到调度中心的调度信息将调度信息放到对应的任务的等待队列中执行器的任务处理线程从任务队列中取出调度信息执行业务逻辑将结果放入一个公共的等待队列中每个任务都有一个单独的处理线程和等待队列任务信息放入该队列中执行器有一个专门的回调线程定时批量从结果队列中取出任务结果并且回调告知调度中心 关于更多的详细介绍推荐阅读官方文档[^1] https://www.xuxueli.com/xxl-job/ xxl-job快速入门 Spring Boot集成XXL-JOB 主要需要配置以下两项 配置运行调度中心xxl-job-admin配置运行执行器项目 项目准备及脚本初始化 从如下代码仓库中下载xxl-job-admin https://gitee.com/xuxueli0323/xxl-job 下载完成后使用IDEA打开该项目进行项目构建。 构建完成后执行项目的doc/db文件夹下面的tables_xxl_job.sql数据库脚本进行调度数据库表的初始化。 数据表说明xxl_job_lock任务调度锁表xxl_job_group执行器信息表维护任务执行器信息xxl_job_info调度扩展信息表 用于保存XXL-JOB调度任务的扩展信息如任务分组、任务名、机器地址、执行器、执行入参和报警邮件等等xxl_job_log调度日志表 用于保存XXL-JOB任务调度的历史信息如调度结果、执行结果、调度入参、调度机器和执行器等等xxl_job_log_report调度日志报表用户存储XXL-JOB任务调度日志的报表调度中心报表功能页面会用到xxl_job_logglue任务GLUE日志用于保存GLUE更新历史用于支持GLUE的版本回溯功能xxl_job_registry执行器注册表维护在线的执行器和调度中心机器地址信息xxl_job_user系统用户表 配置调度中心 修改配置文件主要配置datasource 以及 email。 application.properties ### web server.port9100### xxl-job, datasource spring.datasource.urljdbc:mysql://127.0.0.1:3306/ballcat?useUnicodetruecharacterEncodingUTF-8autoReconnecttrueserverTimezoneAsia/Shanghai spring.datasource.usernamexxkfz spring.datasource.passwordxxkfz spring.datasource.driver-class-namecom.mysql.cj.jdbc.Driver注由于小编默认8080端口被占用这里修改了一下项目的端口号 server.port9100 配置完成后启动下面主启动类启动项目 XxlJobAdminApplication.java启动完成后访问地址为http://localhost:8080/xxl-job-admin默认的用户为 admin密码 123456即可进入后台管理系统页面。 至此调度中心配置完成接下来进行执行器的项目配置。 配置执行器项目(整合Spring Boot项目) 该部分官方已经给出具体的案例因此我们只需对本案例进行整合或修改即可。 官方案例对应工程xxl-job-executor-sample-springboot 引入依赖 !-- xxl-job-core -- dependencygroupIdcom.xuxueli/groupIdartifactIdxxl-job-core/artifactIdversion${project.parent.version}/version /dependency注此处版本要与 xxl-job-admin 中版本保持一致 引入配置类 XxlJobConfig.java 我们直接从xxl-job-executor-sample-springboot项目中把XxlJobConfig.java配置类复制到你的项目中即可不需要进行任何的修改。 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;Beanpublic 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;}}修改项目配置文件 # web port server.port8098 # no web #spring.main.web-environmentfalse# log config logging.configclasspath:logback.xml### xxl-job admin address list, such as http://address or http://address01,http://address02 xxl.job.admin.addresseshttp://127.0.0.1:9100/xxl-job-admin### xxl-job, access token xxl.job.accessTokendefault_token### xxl-job executor appname xxl.job.executor.appnamexxkfz-job-fileExport ### xxl-job executor registry-address: default use address to registry , otherwise use ip:port if address is null xxl.job.executor.address ### xxl-job executor server-info xxl.job.executor.ip xxl.job.executor.port9999 ### xxl-job executor log-path xxl.job.executor.logpath/data/applogs/xxl-job/jobhandler ### xxl-job executor log-retention-days xxl.job.executor.logretentiondays30 编写测试类 TaskConfig.java Component Slf4j public class TaskConfig {XxlJob(fileExport)public void execute() {log.debug(文件开始导出了......);} }任务配置 新增执行器 配置任务 测试 点击执行一次查看逻辑是否执行控制台是否打印日志。 注若需要项目一致保持运行选择启动即可。 运行结果 控制台输出日志 以上就是Spring Boot集成XXL-JOB的具体详细过程感谢阅读。 参考资料 [1] XXL-JOB分布式任务调度平台 https://www.xuxueli.com/xxl-job/
http://www.w-s-a.com/news/946769/

相关文章:

  • 网站如何优化推广连锁店管理网站开发
  • 伊宁市做网站功能性质网站
  • 北京哪个网站制作公司优化大师免费安装下载
  • 同江佳木斯网站设计做网站联系电话
  • 设计上海展会2023seo网站模板下载
  • 开发一个卖东西的网站多少站长工具永久
  • 公司网站怎么突然多了好多友情链接如何删除宁波有几个区
  • 临沂seo网站推广wordpress新编辑器
  • c2c网站设计店面logo设计制作
  • 网站建设任务执行书重庆今天新闻事件
  • 怎样发布自己的网站南宁制作网站公司
  • wordpress装多站点百度查一下
  • 怎么优化一个网站搭建网站免费空间
  • 山东建设和城乡建设厅注册中心网站首页wordpress安装教材
  • 个人风采网站制作毕节网站开发公司电话
  • 网络网站销售设计主题和设计理念
  • 做网站一般用什么服务器承德专业做网站
  • 松北区建设局网站网站建设分为几种
  • 网站建设的合同 体会智联招聘网站建设情况
  • 记的网站域名wordpress地方信息主题
  • 淄博好的建网站公司网站建设 海口
  • 有人做网站花了10几万2017做啥网站能致富
  • 做网站有什么软件cod建站平台
  • 合肥学校网站建设怎么做免费的产品图片网站
  • 营养早餐网站的设计与制作建设通网站怎么查项目经理在建
  • 浑南区建设局网站永州网站建设公司推荐
  • 做外贸都得有网站吗绵阳网站建设制作
  • 功能性的网站建设北京餐饮品牌设计公司
  • php做网站优势视频直播软件
  • 怎么安装php网站哪个网站是专门为建设方服务的