⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 quartzschedulerthread.java

📁 Quartz is a full-featured, open source job scheduling system that can be integrated with, or used al
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/*  * Copyright 2004-2005 OpenSymphony  *  * Licensed under the Apache License, Version 2.0 (the "License"); you may not  * use this file except in compliance with the License. You may obtain a copy  * of the License at  *  *   http://www.apache.org/licenses/LICENSE-2.0  *    * Unless required by applicable law or agreed to in writing, software  * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the  * License for the specific language governing permissions and limitations  * under the License. *  *//* * Previously Copyright (c) 2001-2004 James House */package org.quartz.core;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import org.quartz.JobPersistenceException;import org.quartz.SchedulerException;import org.quartz.Trigger;import org.quartz.spi.TriggerFiredBundle;import java.util.Random;/** * <p> * The thread responsible for performing the work of firing <code>{@link Trigger}</code> * s that are registered with the <code>{@link QuartzScheduler}</code>. * </p> *  * @see QuartzScheduler * @see org.quartz.Job * @see Trigger *  * @author James House */public class QuartzSchedulerThread extends Thread {    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Data members.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    private QuartzScheduler qs;    private QuartzSchedulerResources qsRsrcs;    private Object pauseLock = new Object();    private Object idleLock = new Object();    private boolean signaled;    private boolean paused;    private boolean halted;    private SchedulingContext ctxt = null;    private Random random = new Random(System.currentTimeMillis());    // When the scheduler finds there is no current trigger to fire, how long    // it should wait until checking again...    private static long DEFAULT_IDLE_WAIT_TIME = 30L * 1000L;    private long idleWaitTime = DEFAULT_IDLE_WAIT_TIME;    private int idleWaitVariablness = 7 * 1000;    private long dbFailureRetryInterval = 15L * 1000L;    private final Log log = LogFactory.getLog(getClass());    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Constructors.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    /**     * <p>     * Construct a new <code>QuartzSchedulerThread</code> for the given     * <code>QuartzScheduler</code> as a non-daemon <code>Thread</code>     * with normal priority.     * </p>     */    QuartzSchedulerThread(QuartzScheduler qs, QuartzSchedulerResources qsRsrcs,            SchedulingContext ctxt) {        this(qs, qsRsrcs, ctxt, qsRsrcs.getMakeSchedulerThreadDaemon(), Thread.NORM_PRIORITY);    }    /**     * <p>     * Construct a new <code>QuartzSchedulerThread</code> for the given     * <code>QuartzScheduler</code> as a <code>Thread</code> with the given     * attributes.     * </p>     */    QuartzSchedulerThread(QuartzScheduler qs, QuartzSchedulerResources qsRsrcs,            SchedulingContext ctxt, boolean setDaemon, int threadPrio) {        super(qs.getSchedulerThreadGroup(), qsRsrcs.getThreadName());        this.qs = qs;        this.qsRsrcs = qsRsrcs;        this.ctxt = ctxt;        this.setDaemon(setDaemon);        this.setPriority(threadPrio);        // start the underlying thread, but put this object into the 'paused'        // state        // so processing doesn't start yet...        paused = true;        halted = false;        this.start();    }    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Interface.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    void setIdleWaitTime(long waitTime) {        idleWaitTime = waitTime;        idleWaitVariablness = (int) (waitTime * 0.2);    }    private long getDbFailureRetryInterval() {        return dbFailureRetryInterval;    }    public void setDbFailureRetryInterval(long dbFailureRetryInterval) {        this.dbFailureRetryInterval = dbFailureRetryInterval;    }    private long getRandomizedIdleWaitTime() {        return idleWaitTime - random.nextInt(idleWaitVariablness);    }    /**     * <p>     * Signals the main processing loop to pause at the next possible point.     * </p>     */    void togglePause(boolean pause) {        synchronized (pauseLock) {            paused = pause;            if (paused) {                signalSchedulingChange();            } else {                pauseLock.notify();            }        }    }    /**     * <p>     * Signals the main processing loop to pause at the next possible point.     * </p>     */    void halt() {        synchronized (pauseLock) {            halted = true;            if (paused) {                pauseLock.notify();            } else {                signalSchedulingChange();            }        }    }    boolean isPaused() {        return paused;    }    /**     * <p>     * Signals the main processing loop that a change in scheduling has been     * made - in order to interrupt any sleeping that may be occuring while     * waiting for the fire time to arrive.     * </p>     */    void signalSchedulingChange() {        signaled = true;    }    /**     * <p>     * The main processing loop of the <code>QuartzSchedulerThread</code>.     * </p>     */    public void run() {        boolean lastAcquireFailed = false;                while (!halted) {            try {                // check if we're supposed to pause...                synchronized (pauseLock) {                    while (paused && !halted) {                        try {                            // wait until togglePause(false) is called...                            pauseLock.wait(100L);                        } catch (InterruptedException ignore) {                        }                    }                        if (halted) {                        break;                    }                }                int availTreadCount = qsRsrcs.getThreadPool().blockForAvailableThreads();                if(availTreadCount > 0) {                    Trigger trigger = null;                    long now = System.currentTimeMillis();                    signaled = false;                    try {                        trigger = qsRsrcs.getJobStore().acquireNextTrigger(                                ctxt, now + idleWaitTime);                        lastAcquireFailed = false;                    } catch (JobPersistenceException jpe) {                        if(!lastAcquireFailed) {                            qs.notifySchedulerListenersError(                                "An error occured while scanning for the next trigger to fire.",                                jpe);                        }                        lastAcquireFailed = true;                    } catch (RuntimeException e) {                        if(!lastAcquireFailed) {                            getLog().error("quartzSchedulerThreadLoop: RuntimeException "                                    +e.getMessage(), e);                        }                        lastAcquireFailed = true;                    }                    if (trigger != null) {

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -