Springbootwebscoket自定义定时器
问题描述
需要定时通过websocket接口来推送mysql里面最新的数据,自定义了定时器
@Component @Slf4j public class TaskScheduler { @Autowired private TparkOrderInOutMapper tparkOrderInOutMapper; @Autowired UserController userController; /** * 间隔是10秒执行一次 */ @Scheduled(cron = "0/10 * * * * ?") public void pushParkInfo() { userController.findAll(); } }
定时器配置
在启动类里面增加定时器的启动入口。
@SpringBootApplication @MapperScan(basePackages = "com.stop.mapper") //扫描mapper包 @EnableScheduling //配置定时器 public class Application { public static void main(String[] args) { SpringApplication.run(Application.class,args); System.out.println("hello world"); System.out.println("test"); } }
其中,注解@EnableSchedu ling 就是配置定时器。
启动作业
启动作业发现定时器的任务没有执行。查阅资料是因为:
springBoot 默认是使用单线程的Scheduler来处理我们的 @Scheduled注解的定时任务。
我们需要定义一个TaskScheduler的配置类,使用多线程来执行我们的定时任务。
@Configuration public class ScheduledTaskConfiguration implements SchedulingConfigurer { @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar) { final ThreadPoolTaskScheduler taskScheduler = new ThreadPoolTaskScheduler(); taskScheduler.setPoolSize(2); taskScheduler.initialize(); taskRegistrar.setTaskScheduler(taskScheduler); } }
最后运行application的时候,我们可以看到控制上:
我们可以看到上面定时任务按照间隔10秒在执行操作。
关于Springboot webscoket自定义定时器的文章就介绍至此,更多相关Springboot定时器内容请搜索编程宝库以前的文章,希望以后支持编程宝库!
Sink介绍在Fink官网中sink端只是给出了常规的write api.在我们实际开发场景中需要将flink处理的数据写入kafka,hbase kudu等外部系统。 UML关 ...