`
wxb_love
  • 浏览: 95941 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

处理定时任务,超时终止方法

阅读更多
实现功能:处理一批任务,如果某个任务的处理时间超过最大处理时间,则终止该任务的执行,继续执行下一个任务
实现思路:三线程实现,处理一个任务时,启动一个任务处理线程处理方案,再启动一个定时器线程检测是否超时,并通过一个同步变量保证任务时串行执行的。实现代码如下:

疑问:
1、在Java中,类似超时任务的处理有没有其它的实现方式?
2、下面几个异常会无规律地出现,想不明白其中的道理,请明白人帮忙解释一下,
2.1、没有执行“Normal Process”,也没有执行“ending ok!” :为什么interrupt后,doSomething里没有捕获到异常? start task!20
ThreadID:27>>> starting!
ThreadID: MonitorThread running!
ThreadID:27>>> stoping end!
end task!20
2.2、没有执行“ending ok!” :stop后,run里后续处理不做了? start task!18
ThreadID:25>>> starting!
ThreadID: MonitorThread running!
ThreadID:25>>> AbNormal Proccess! processTime=18000
ThreadID:25>>> stoping end!
2.3、执行了2次“AbNormal Proccess! ”,但没有执行“ending ok!” :为什么会打印2次?
start task!10
ThreadID:17>>> starting!
ThreadID: MonitorThread running!
ThreadID:17>>> AbNormal Proccess! processTime=10000ThreadID:17>>> AbNormal Proccess! processTime=10000ThreadID:17>>> stoping end!
end task!10


代码如下:
Java code

package MultiThreadTest;

import java.util.Timer;
import java.util.TimerTask;

public class MainThread {
    private Object lock = new Object();

    public void waitLock() throws InterruptedException {
        synchronized (lock) {
            lock.wait();
        }
    }

    public void notifyLock() {
        synchronized (lock) {
            lock.notify();
        }
    }

    /**
     * @param args
     * @throws InterruptedException
     */
    public static void main(String[] args) {

        MainThread mainThread = new MainThread();

        for (int i = 2; i <= 20; i += 2) {

            System.out.println("start task!" + i);
            ProccessThread proccessThread = new ProccessThread(mainThread,
                    i * 1000);
            MonitorThread monitorThread = new MonitorThread(mainThread);
            long maxProccessTime = 8 * 1000;// 每个任务的最大处理时间
            Timer timer = new Timer();
            timer.schedule(monitorThread, maxProccessTime);
            proccessThread.start();
            try {
                mainThread.waitLock();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            proccessThread.stop();
            timer.cancel();
            System.out.println("end task!" + i);
        }
    }

}

class MonitorThread extends TimerTask {
    private MainThread mt;

    public MonitorThread(MainThread mt) {
        super();
        this.mt = mt;
    }

    @Override
    public void run() {
        System.out.println("ThreadID:" + " MonitorThread running!");
        mt.notifyLock();
    }

}

class ProccessThread implements Runnable {
    private MainThread mt;
    private Thread thread;
    private long processTime;

    public ProccessThread(MainThread mt, long processTime) {
        super();
        this.mt = mt;
        this.processTime = processTime;
    }

    private void doSomething() {
        try {
            // do something
            // thread.sleep(100*1000); //异常情况
            // thread.sleep(1*1000); //正常情况
            thread.sleep(processTime); // 正常情况
            System.out.println("ThreadID:" + thread.getId() + ">>>  Normal Process! processTime=" + processTime);

        } catch (InterruptedException e) {
            // e.printStackTrace();
            System.out.println("ThreadID:" + thread.getId() + ">>>  AbNormal Proccess! processTime=" + processTime);
        }

    }

    public void run() {
        System.out.println("ThreadID:" + thread.getId() + ">>> starting!");
        doSomething();
        mt.notifyLock();
        System.out.println("ThreadID:" + thread.getId() + ">>> ending ok!");

    }

    public void start() {
        thread = new Thread(this);
        thread.start();

    }

    public void stop() {
        thread.interrupt();// 如果任务在正常时间内不能退出,认为产生interrupt,强行地退出 (run方法正常结束)
        thread.stop();
        try {
            Thread.sleep(1 * 1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("ThreadID:" + thread.getId()
                + ">>> stoping end!");
        thread = null;
    }
}
分享到:
评论

相关推荐

    Java实现任务超时处理方法

    Java实现任务超时处理方法是指在Java中对超时任务的处理,主要有两种方式:基于异步任务结果的超时获取和使用延时任务来终止超时操作。 基于异步任务结果的超时获取是通过使用Future对象来实现的。在提交任务时,会...

    Quartz调度、终止执行的任务

    总之,Quartz提供了一套强大的任务调度机制,通过灵活的Job和Trigger配置,我们可以创建各种定时任务。同时,它的暂停、删除功能使得我们能够在运行时动态控制任务的执行状态,以适应不同的业务需求。在实际开发中,...

    C#利用Task实现任务超时多任务一起执行的方法

    C#利用Task实现任务超时多任务一起执行的方法 本文主要介绍了C#利用Task实现任务超时,多任务一起执行的相关知识点。Task是C#中的一个异步编程模型,能够帮助开发者更方便地编写异步代码。下面是本文中所涉及的知识...

    详解PHP实现定时任务的五种方法

    【PHP实现定时任务的方法】 ...在实际应用中,可能需要结合使用这些方法,以达到最佳的定时任务执行效果。例如,可以考虑使用Crontab配合PHP脚本来实现定时任务,同时在脚本中加入控制逻辑,以实现更灵活的管理和维护。

    线程超时死掉

    Future接口提供方法来检测任务是否被执行完,等待任务执行完获得结果,也可以设置任务执行的超时时间。这个设置超时的方法就是实现Java程 序执行超时的关键。 Future接口是一个泛型接口,严格的格式应该是Future...

    java.util.timer实现的简单定时任务

    Java.util.Timer类是Java标准库提供的一种简单但功能有限的定时任务执行机制。它允许开发者在指定的时间间隔或特定时间点执行任务,非常适合处理一次性...通过实践和调试,你将更好地理解和掌握Java中的定时任务处理。

    毕设项目基于SpringBoot+Vue的轻量级定时任务管理系统源码+数据库+项目说明(含前端+后端).zip

    毕设项目基于SpringBoot+Vue的轻量级定时任务管理系统源码+数据库+项目说明(含前端+后端).zip 【1】项目代码完整且功能都验证ok,确保稳定可靠运行后才上传。欢迎下载使用!在使用过程中,如有问题或建议,请及时...

    Job Plus项目是基于SpringBoot+Vue的轻量级定时任务管理系统+源代码+文档说明

    19. 超时控制:支持自定义任务超时时间,任务运行超时将会主动中断任务; 20. 重试机制:支持自定义任务重试次数,当任务失败时将会按照预设的失败重试次数主动进行重试; 21. 消息工厂:默认提供邮件工厂的方式推送...

    ZooKeeper会话超时以及重连机制.pdf

    - **定时任务**:Leader节点内部有一个定时任务,以`tickTime`的频率定期检查所有Session的状态,一旦发现某个Session超过`sessionTimeout`未收到心跳,则认为该Session已经超时。 - **Session清理过程**: - 当...

    分布式任务调度系统调研

    7. **任务超时管理**:自动终止长时间未完成的任务,避免系统资源被占用。 8. **流程任务支持**:多台服务器之间能够协同完成一项大型任务,并按照预定的顺序逐一执行每个子任务。 9. **日志记录与分析**:详细记录...

    xxl-job.docx

    - **任务超时控制**:允许设置任务超时时间,超时后会主动中断任务。 - **任务失败重试**:支持设定失败重试次数,任务失败后自动重试,分片任务支持粒度重试。 - **任务失败告警**:默认使用邮件告警,也可扩展...

    PHP函数执行超时控制扩展ForPHP7控制PHP函数的执行时间

    3. 长时间运行的任务:例如定时任务或后台进程,控制每个任务执行时间防止资源耗尽。 使用这个扩展的方法可能是这样的: ```php use Pangudashu\Timeout; $timeout = 5000; // 毫秒 $function = function() { // ...

    java 定时器

    Java 5引入的`java.util.concurrent`包下的`ScheduledExecutorService`提供了更强大且灵活的定时任务管理功能,例如支持定时器线程池,可以更精确地控制任务执行和取消,以及更好的线程管理和异常处理机制。...

    定时器的封装类,可直接并列com包使用

    3. **停止定时**:当不再需要定时任务时,可以通过调用`cancel()`方法来取消`Timer`,这将终止所有计划的任务。对于正在运行的`TimerTask`,`cancel()`方法不会立即停止,但会在下次调度时避免执行。 ```java timer...

    进程信号的处理过程.docx

    信号处理的一个常见例子是使用`alarm`设置一个定时器,当时间到时产生SIGALRM信号,进程可以注册一个信号处理函数来响应这个信号,从而实现特定的功能,比如超时退出、定时任务等。 总结来说,Linux进程信号的处理...

    php中定时计划任务的实现原理

    3. **定时任务的实现方式**: - **ignore_user_abort()与set_time_limit(0)**:结合使用可以创建一个无限循环的脚本,不受客户端中断或执行时间限制的影响。例如,设置`ignore_user_abort(true)`和`set_time_limit...

    Java线程池学习资料-全

    在Spring中,使用`@Scheduled`注解的定时任务默认在一个单独的线程中执行,如果有多个`@Scheduled`方法,它们会在不同的线程中运行。如果一个定时任务抛出异常,不会直接影响其他定时任务。如果设置了线程池,这些...

    ThreadPoolTest.rar

    - 定时任务执行,如定时备份、数据同步等。 - 并行计算,如大数据分析或图像处理,可以将任务分解为多个子任务并发执行。 在设计线程池时,需要注意以下几点: 1. **适当设置线程池大小**:根据系统的CPU核心数和...

    线程池资源

    - `newScheduledThreadPool(int corePoolSize)`:创建定长线程池,支持定时及周期性任务执行。 2. 使用`ThreadPoolExecutor`直接构造线程池: - `ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, ...

Global site tag (gtag.js) - Google Analytics