| New file | 
|  |  |  | 
|---|
|  |  |  | package com.dy.common.mw.core; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import org.apache.logging.log4j.LogManager; | 
|---|
|  |  |  | import org.apache.logging.log4j.Logger; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.Timer; | 
|---|
|  |  |  | import java.util.TimerTask; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @Author: liurunyu | 
|---|
|  |  |  | * @Date: 2024/11/21 17:13 | 
|---|
|  |  |  | * @Description | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public class CoreConstantTimer extends TimerTask { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private final static Logger log = LogManager.getLogger(CoreConstantTimer.class.getName()) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Timer timer; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private long coreInterval ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private CoreTask task ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public CoreConstantTimer(long coreInterval, CoreTask task){ | 
|---|
|  |  |  | this.timer = new Timer(); | 
|---|
|  |  |  | this.coreInterval = coreInterval ; | 
|---|
|  |  |  | this.task = task ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public CoreConstantTimer start(){ | 
|---|
|  |  |  | this.timer.schedule(this, 0 , this.coreInterval); | 
|---|
|  |  |  | return this ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void run() { | 
|---|
|  |  |  | if(task != null){ | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | task.execute(); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | log.error("恒久任务" + task.getClass().getName() + "执行时发生异常" + (e.getMessage() == null ? "" : (":" + e.getMessage())), e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|