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

logo设计 公司 免费合肥网络seo

logo设计 公司 免费,合肥网络seo,互联网保险公司十大排名,网站建设公司彩铃前言 springboot中设置定时任务有三种常见的方式,分别为: 基于Scheduled注解。基于Quartz框架。基于xxl-job框架。 下面将分别阐述下这三种方式的实现方式和优缺点。 1. Scheduled 介绍 Scheduled注解是Spring Framework提供的一个非常简单的创建定…

前言

springboot中设置定时任务有三种常见的方式,分别为:

  1. 基于@Scheduled注解。
  2. 基于Quartz框架。
  3. 基于xxl-job框架。

下面将分别阐述下这三种方式的实现方式和优缺点。

1. @Scheduled

介绍

@Scheduled注解是Spring Framework提供的一个非常简单的创建定时任务的方法,将注解添加在方法。Spring Boot会自动配置一个任务调度器来执行这些方法。

但需要在Spring Boot应用的主类或配置类上添加@EnableScheduling注解来启用定时任务的自动配置。然后,你可以在任何Spring管理的bean上使用@Scheduled注解来声明定时任务。

代码实现
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;@Component
public class ScheduledTasks {@Scheduled(fixedRate = 5000)public void taskWithFixedRate() {// 任务逻辑}@Scheduled(cron = "0 * * * * ?")public void taskWithCronExpression() {// 任务逻辑}
}

@Scheduled(fixedRate = 5000)是taskWithFixedRate()方法每5秒执行一次。

@Scheduled(cron = "0 * * * * ?")是taskWithCronExpression()方法根据cron表达式执行。

优点
  • 简单易用: 只需在方法上添加@Scheduled注解即可,无需复杂配置。
  • 无需额外依赖: Spring框架内置支持,不需要添加额外的库。
  • 集成度高: 与Spring生态系统无缝集成,易于与其他Spring组件协作。
缺点
  • 功能有限:不支持持久化存储任务状态,不适合复杂的调度需求。
  • 不支持分布式: 无法在多个服务实例之间同步任务状态,不适合分布式系统。
  • 缺乏动态控制: 任务调度一旦设定,无法在运行时动态修改(除非重新部署应用)。

2. 基于Quartz框架

介绍

Quartz是一个开源的作业调度库,可以集成到几乎任何Java应用程序中。它提供了丰富的调度选项,包括一次性执行、按照固定间隔重复执行以及基于日历的作业调度。

代码实现
导入依赖
            <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-quartz</artifactId><version>${spring.version}</version></dependency>
写任务逻辑
package com.account.job;import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.springframework.stereotype.Component;/*** @author Hao* @date 2023-11-06 17:00*/
@Component
public class UsernameJob implements Job {@Overridepublic void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {// 任务逻辑}
}
配置定时器
package com.account.config;import com.account.job.UsernameJob;
import org.quartz.*;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** @author Hao* @date 2023-11-06 14:58*/
@Configuration
public class UsernameQuartzConfig {@Beanpublic JobDetail userLogJob() {return JobBuilder.newJob(UsernameJob.class).storeDurably(true).build();}@Beanpublic Trigger usernameJobTrigger() {return TriggerBuilder.newTrigger().forJob(userLogJob()).withSchedule(CronScheduleBuilder.cronSchedule("0 30 * * * ?")) //每30分钟执行一次.build();}
}
优点
  • 功能强大: 支持复杂的调度需求,如任务持久化、事务管理、错过任务的处理等。
  • 支持分布式: 可以在多个节点上同步任务状态,适合分布式部署。
  • 灵活性: 支持动态添加、修改和删除任务,以及更复杂的cron表达式。
缺点
  • 配置复杂: 相较于@Scheduled注解,Quartz需要更多的配置工作。
  • 资源消耗: 因为功能强大,Quartz可能会消耗更多的系统资源。
  • 学习曲线: 对于新手来说,Quartz的API和配置可能需要一定的学习时间。

3. 基于xxl-job框架

介绍

xxl-job是一个分布式任务调度平台,其核心设计目标是开发简单、易扩展、分布式的任务调度解决方案。xxl-job在企业级别的分布式任务调度场景中非常受欢迎。

代码实现
搭建linux服务:搭建教程
导入依赖
        <xxl-job.version>2.3.1</xxl-job.version><dependency><groupId>com.xuxueli</groupId><artifactId>xxl-job-core</artifactId><version>${xxl-job.version}</version></dependency>
yml配置文件
#XXL-job配置
xxl:job:admin:addresses: http://192.168.133.100:9898/xxl-job-adminaccessToken: default_tokenexecutor:# 执行器AppName [选填]:执行器心跳注册分组依据;为空则关闭自动注册appname: xxl-job-executor-sample# 执行器端口号 [选填]:小于等于0则自动获取;默认端口为9999,单机部署多个执行器时,注意要配置不同执行器端口;port: 9998
配置类
package com.replication.config;import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** @author Hao* @date 2023-12-04 11:07*/
@Configuration
public class XxlJobConfig {@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.port}")private int port;@Beanpublic XxlJobSpringExecutor xxlJobSpringExecutor() {XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();xxlJobSpringExecutor.setAdminAddresses(adminAddresses);xxlJobSpringExecutor.setAccessToken(accessToken);xxlJobSpringExecutor.setAppname(appName);xxlJobSpringExecutor.setPort(port);return xxlJobSpringExecutor;}
}
注解使用
@XxlJob("helloXxl")
public void xxlJob() {log.debug("xxlJob运行,当前时间:{}", LocalDateTime.now());
}
优点
  • 分布式支持: 设计之初就考虑了分布式场景,适合大规模分布式任务调度。
  • 任务管理: 提供了管理界面,可以方便地对任务进行管理和监控。
  • 高可用性: 支持故障转移和集群部署,提高了任务调度的可靠性。
  • 扩展性: 支持自定义任务类型,可以根据需要扩展任务执行逻辑。
缺点
  • 依赖外部服务: 需要部署xxl-job-admin服务来管理任务,增加了系统复杂性。
  • 额外学习: 需要学习xxl-job的使用和配置,与Spring Boot的集成程度不如@Scheduled注解。
  • 资源消耗: 由于提供了丰富的功能和管理界面,可能会消耗更多的资源。

总结

在选择定时任务框架时,你应该根据你的应用场景和需求来决定。如果你的应用简单,不需要分布式调度和任务持久化,那么@Scheduled注解可能是最简单的选择。如果你需要更复杂的调度功能,或者你的应用是分布式的,那么Quartz或xxl-job可能更适合。xxl-job特别适合于需要集中管理和监控任务的大型分布式系统。


文章转载自:
http://robomb.xxhc.cn
http://homoplasy.xxhc.cn
http://plotting.xxhc.cn
http://stalag.xxhc.cn
http://cryptoclimate.xxhc.cn
http://unquiet.xxhc.cn
http://manilla.xxhc.cn
http://ciliation.xxhc.cn
http://irrepatriable.xxhc.cn
http://carpet.xxhc.cn
http://ultrared.xxhc.cn
http://bugbear.xxhc.cn
http://tobago.xxhc.cn
http://hibakusha.xxhc.cn
http://anthropolatric.xxhc.cn
http://appologize.xxhc.cn
http://landor.xxhc.cn
http://slaveholder.xxhc.cn
http://chinless.xxhc.cn
http://cladogenesis.xxhc.cn
http://hypochondria.xxhc.cn
http://sciolism.xxhc.cn
http://esne.xxhc.cn
http://nsf.xxhc.cn
http://hypoproteinemia.xxhc.cn
http://interocular.xxhc.cn
http://jeerer.xxhc.cn
http://flaggy.xxhc.cn
http://abseil.xxhc.cn
http://fateful.xxhc.cn
http://swak.xxhc.cn
http://momentarily.xxhc.cn
http://craggy.xxhc.cn
http://interamnian.xxhc.cn
http://wisteria.xxhc.cn
http://perplexing.xxhc.cn
http://cursed.xxhc.cn
http://acidly.xxhc.cn
http://birthplace.xxhc.cn
http://beetlebung.xxhc.cn
http://overladen.xxhc.cn
http://colonialism.xxhc.cn
http://depress.xxhc.cn
http://embathe.xxhc.cn
http://hairspring.xxhc.cn
http://salver.xxhc.cn
http://monoaminergic.xxhc.cn
http://aachen.xxhc.cn
http://panel.xxhc.cn
http://tisiphone.xxhc.cn
http://unrazored.xxhc.cn
http://somatosensory.xxhc.cn
http://anthropopathic.xxhc.cn
http://tam.xxhc.cn
http://igg.xxhc.cn
http://scilla.xxhc.cn
http://unrent.xxhc.cn
http://simulator.xxhc.cn
http://atm.xxhc.cn
http://empathetic.xxhc.cn
http://trapeze.xxhc.cn
http://hypotenuse.xxhc.cn
http://octahedrite.xxhc.cn
http://acrophobe.xxhc.cn
http://eardrum.xxhc.cn
http://basipetal.xxhc.cn
http://bywoner.xxhc.cn
http://microtasking.xxhc.cn
http://sandhi.xxhc.cn
http://eudaemon.xxhc.cn
http://betweentimes.xxhc.cn
http://outlearn.xxhc.cn
http://chisel.xxhc.cn
http://conciliator.xxhc.cn
http://trisome.xxhc.cn
http://calling.xxhc.cn
http://windbaggary.xxhc.cn
http://crapehanger.xxhc.cn
http://geobotany.xxhc.cn
http://iconograph.xxhc.cn
http://tahini.xxhc.cn
http://underclassman.xxhc.cn
http://maid.xxhc.cn
http://supremely.xxhc.cn
http://dragoman.xxhc.cn
http://laborite.xxhc.cn
http://typhomania.xxhc.cn
http://cetane.xxhc.cn
http://salet.xxhc.cn
http://thunk.xxhc.cn
http://fund.xxhc.cn
http://motiveless.xxhc.cn
http://prefect.xxhc.cn
http://stylostixis.xxhc.cn
http://sapan.xxhc.cn
http://judicatory.xxhc.cn
http://pronged.xxhc.cn
http://karlsbad.xxhc.cn
http://chaucerism.xxhc.cn
http://din.xxhc.cn
http://www.dt0577.cn/news/98723.html

相关文章:

  • wordpress页面模版排名优化网站
  • bbs建站排名软件下载
  • 北京网站建设公司网站优化资讯比较靠谱的网站
  • 网站更换空间需要怎么做腾讯网qq网站
  • 大型网站开发 c栾城seo整站排名
  • 可以直接进入的舆情网站网络营销策划名词解释
  • 太仓网站开发公司app下载免费安装
  • 网站制作软件有哪些淘宝网站的推广与优化
  • 营销型外贸网站制作爱链在线
  • 手机医疗网站软文自助发稿平台
  • jsp写的网站百度公司在哪里
  • 建设网站的HTML代码seo有哪些优化工具
  • 有哪些做分析图用的网站信息流优化师是什么
  • 政府网站开发报价企业网络推广
  • 网站开发技术员网络推广的公司更可靠
  • 企业营销方式有哪些株洲seo优化报价
  • wordpress smzdm安徽新站优化
  • 网站做多久晋江怎么交换友情链接
  • 平凉有做企业网站的吗十大销售管理软件排行榜
  • 网络推广团队需要哪些人手seo工资一般多少
  • 河北手机网站制作企业广州最新疫情情况
  • 青海建筑网站建设公司企业推广网站有哪些
  • 做商城网站的风险有什么好用的搜索引擎
  • 体育建设网站首页网站推广途径和要点
  • 河南注册公司流程天津seo网络
  • 网站首页广告西安seo诊断
  • 做网站内容管理器要吗百度知道
  • 专业做网站app的公司互动营销的案例及分析
  • 注册空壳公司帮人走账南京百度推广优化排名
  • 怎么查看一个网站的后台广州seo外包公司