spring boot+quartz+websocket+sockJs实现定时发送

 定时任务的管理:

public class QuartzManager {

    /**
     * 开启一个quartz
     * @param scheduler
     * @param conferenceId
     */
    public static void addJob(Scheduler scheduler,Long conferenceId){

        try {
            JobDetail jobDetail = JobBuilder.newJob(ConferenceJob.class)
                    .storeDurably(true).usingJobData("conferenceId",conferenceId)
                    .withIdentity(JobKey.jobKey(conferenceId.toString()))
                    .build();
            Trigger trigger = TriggerBuilder.newTrigger()
                    .forJob(jobDetail).withSchedule(SimpleScheduleBuilder.repeatSecondlyForever().withIntervalInMilliseconds(500))
                    .withIdentity(TriggerKey.triggerKey(conferenceId.toString()))
                    .startNow()
                    .build();
            scheduler.scheduleJob(jobDetail, trigger);
        } catch (SchedulerException e) {
            e.printStackTrace();
        }

    }

    /**
     * 关闭一个 quartz
     * @param scheduler
     * @param conferenceId
     */
    public static  void removeJob(Scheduler scheduler,Long conferenceId){
        try {
            scheduler.pauseTrigger(TriggerKey.triggerKey(conferenceId.toString()));// 停止触发器
            scheduler.unscheduleJob(TriggerKey.triggerKey(conferenceId.toString()));// 移除触发器
            scheduler.deleteJob(JobKey.jobKey(conferenceId.toString()));// 删除任务
        } catch (SchedulerException e) {
            e.printStackTrace();
        }
    }

    /**
     * 获取job
     */
    public static JobDetail findJod(Scheduler scheduler,String jobKey){
        JobDetail jobDetail = null;
        try {
            jobDetail = scheduler.getJobDetail(JobKey.jobKey(jobKey));
        } catch (SchedulerException e) {
            e.printStackTrace();
        }
        return  jobDetail;
    }
}
 
消息发送:

public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

    @Override
    public void configureMessageBroker(MessageBrokerRegistry config) {
        config.enableSimpleBroker("/conference");
        config.setApplicationDestinationPrefixes("/app");
    }

    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/cochat-conference").withSockJS().setClientLibraryUrl("/socket/sockjs.min.js");
    }

}


public class SocketService {

    private SimpMessagingTemplate messagingTemplate;
public void sendMessage(Long conferenceId){ String conferenceMessage = "hello"; messagingTemplate.convertAndSend("/conference/greetings/11"+,conferenceMessage); }}

 
sockJs:
function connect() {
    var sockJS = new SockJS(appPath+'/cochat-conference');
    // var socket = new WebSocket("ws://localhost:8080/cochat-conference");
    stompClient = Stomp.over(sockJS);
    stompClient.connect({}, function (frame) {
        stompClient.subscribe('/conference/greetings/'+conferenceId, function (message) {
            //调用 消息展示
     
            console.log("message"+message);


        });
      
    },function(error){
        console.error(error);
    });
    sockJS.onclose = function() {
        console.log('+++++++++++++++++++++++++++++++================close');
    };

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Spring BootQuartz实现定时任务管理,可以让你更方便地管理和监控你的定时任务。下面是一个使用Spring BootQuartzSpring MVC实现定时任务管理的示例: 首先,在你的Spring Boot应用程序中添加QuartzSpring MVC的依赖项: ```xml <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> ``` 然后,在你的Spring Boot应用程序中创建一个Quartz的调度器,并添加一个Spring MVC的Controller来管理定时任务: ```java @Configuration public class QuartzConfig { @Bean public SchedulerFactoryBean schedulerFactoryBean() { SchedulerFactoryBean schedulerFactoryBean = new SchedulerFactoryBean(); schedulerFactoryBean.setTriggers(myTaskTrigger().getObject()); return schedulerFactoryBean; } @Bean public JobDetailFactoryBean myTaskJob() { JobDetailFactoryBean jobDetailFactoryBean = new JobDetailFactoryBean(); jobDetailFactoryBean.setJobClass(MyTask.class); return jobDetailFactoryBean; } @Bean public CronTriggerFactoryBean myTaskTrigger() { CronTriggerFactoryBean cronTriggerFactoryBean = new CronTriggerFactoryBean(); cronTriggerFactoryBean.setJobDetail(myTaskJob().getObject()); cronTriggerFactoryBean.setCronExpression("0/5 * * * * ?"); // 每5秒执行一次 return cronTriggerFactoryBean; } } @RestController public class TaskController { @Autowired private Scheduler scheduler; @PostMapping("/tasks") public void addTask(@RequestBody TaskInfo taskInfo) throws SchedulerException { JobDetail jobDetail = JobBuilder.newJob(taskInfo.getJobClass()) .withIdentity(taskInfo.getJobName(), taskInfo.getJobGroup()) .build(); CronTrigger trigger = TriggerBuilder.newTrigger() .withIdentity(taskInfo.getTriggerName(), taskInfo.getTriggerGroup()) .withSchedule(CronScheduleBuilder.cronSchedule(taskInfo.getCronExpression())) .build(); scheduler.scheduleJob(jobDetail, trigger); } @DeleteMapping("/tasks/{jobName}/{jobGroup}") public void deleteTask(@PathVariable String jobName, @PathVariable String jobGroup) throws SchedulerException { JobKey jobKey = new JobKey(jobName, jobGroup); scheduler.deleteJob(jobKey); } } ``` 在上面的代码中,我们创建了一个Spring MVC的Controller来管理定时任务。我们使用了Scheduler类来添加和删除定时任务。在添加定时任务时,我们使用了TaskInfo类来封装定时任务的信息。在删除定时任务时,我们使用了jobName和jobGroup来识别定时任务。 最后,在你的定时任务类中实现Job接口,并在类上添加@DisallowConcurrentExecution注解,以确保每个任务执行时只有一个实例: ```java @Component @DisallowConcurrentExecution public class MyTask implements Job { @Override public void execute(JobExecutionContext context) throws JobExecutionException { // 定时任务执行的代码 } } ``` 以上就是使用Spring BootQuartzSpring MVC实现定时任务管理的示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值