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

📄 remotescheduler.java

📁 Quartz is a full-featured, open source job scheduling system that can be integrated with, or used al
💻 JAVA
📖 第 1 页 / 共 3 页
字号:
/*  * 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.impl;import java.rmi.RemoteException;import java.rmi.registry.LocateRegistry;import java.rmi.registry.Registry;import java.util.Date;import java.util.List;import java.util.Set;import org.quartz.Calendar;import org.quartz.JobDataMap;import org.quartz.JobDetail;import org.quartz.JobListener;import org.quartz.Scheduler;import org.quartz.SchedulerContext;import org.quartz.SchedulerException;import org.quartz.SchedulerListener;import org.quartz.SchedulerMetaData;import org.quartz.Trigger;import org.quartz.TriggerListener;import org.quartz.UnableToInterruptJobException;import org.quartz.core.RemotableQuartzScheduler;import org.quartz.core.SchedulingContext;import org.quartz.spi.JobFactory;/** * <p> * An implementation of the <code>Scheduler</code> interface that remotely * proxies all method calls to the equivalent call on a given <code>QuartzScheduler</code> * instance, via RMI. * </p> *  * @see org.quartz.Scheduler * @see org.quartz.core.QuartzScheduler * @see org.quartz.core.SchedulingContext *  * @author James House */public class RemoteScheduler implements Scheduler {    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Data members.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    private RemotableQuartzScheduler rsched;    private SchedulingContext schedCtxt;    private String schedId;    private String rmiHost;    private int rmiPort;    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Constructors.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    /**     * <p>     * Construct a <code>RemoteScheduler</code> instance to proxy the given     * <code>RemoteableQuartzScheduler</code> instance, and with the given     * <code>SchedulingContext</code>.     * </p>     */    public RemoteScheduler(SchedulingContext schedCtxt, String schedId,            String host, int port) {        this.schedCtxt = schedCtxt;        this.schedId = schedId;        this.rmiHost = host;        this.rmiPort = port;    }    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Interface.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    protected RemotableQuartzScheduler getRemoteScheduler()        throws SchedulerException {        if (rsched != null) {            return rsched;        }        try {            Registry registry = LocateRegistry.getRegistry(rmiHost, rmiPort);            rsched = (RemotableQuartzScheduler) registry.lookup(schedId);        } catch (Exception e) {            SchedulerException initException = new SchedulerException(                    "Could not get handle to remote scheduler: "                            + e.getMessage(), e);            initException                    .setErrorCode(SchedulerException.ERR_COMMUNICATION_FAILURE);            throw initException;        }        return rsched;    }    protected SchedulerException invalidateHandleCreateException(String msg,            Exception cause) {        rsched = null;        SchedulerException ex = new SchedulerException(msg, cause);        ex.setErrorCode(SchedulerException.ERR_COMMUNICATION_FAILURE);        return ex;    }    /**     * <p>     * Returns the name of the <code>Scheduler</code>.     * </p>     */    public String getSchedulerName() throws SchedulerException {        try {            return getRemoteScheduler().getSchedulerName();        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * <p>     * Returns the instance Id of the <code>Scheduler</code>.     * </p>     */    public String getSchedulerInstanceId() throws SchedulerException {        try {            return getRemoteScheduler().getSchedulerInstanceId();        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    public SchedulerMetaData getMetaData() throws SchedulerException {        try {            RemotableQuartzScheduler sched = getRemoteScheduler();            return new SchedulerMetaData(getSchedulerName(),                    getSchedulerInstanceId(), getClass(), true, isStarted(),                     isInStandbyMode(), isShutdown(), sched.runningSince(),                     sched.numJobsExecuted(), sched.getJobStoreClass(),                     sched.supportsPersistence(), sched.getThreadPoolClass(),                     sched.getThreadPoolSize(), sched.getVersion());        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * <p>     * Returns the <code>SchedulerContext</code> of the <code>Scheduler</code>.     * </p>     */    public SchedulerContext getContext() throws SchedulerException {        try {            return getRemoteScheduler().getSchedulerContext();        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    ///////////////////////////////////////////////////////////////////////////    ///    /// Schedululer State Management Methods    ///    ///////////////////////////////////////////////////////////////////////////    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>.     * </p>     */    public void start() throws SchedulerException {        try {            getRemoteScheduler().start();        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>.     * </p>     */    public void standby() throws SchedulerException {        try {            getRemoteScheduler().standby();        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * @see org.quartz.Scheduler#pause()     * @deprecated     */    public void pause() throws SchedulerException {        this.standby();    }                /**     * Whether the scheduler has been started.       *      * <p>     * Note: This only reflects whether <code>{@link #start()}</code> has ever     * been called on this Scheduler, so it will return <code>true</code> even      * if the <code>Scheduler</code> is currently in standby mode or has been      * since shutdown.     * </p>     *      * @see #start()     * @see #isShutdown()     * @see #isInStandbyMode()     */        public boolean isStarted() throws SchedulerException {        try {            return (getRemoteScheduler().runningSince() != null);        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }       }        /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>.     * </p>     */    public boolean isInStandbyMode() throws SchedulerException {        try {            return getRemoteScheduler().isInStandbyMode();        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    public boolean isPaused() throws SchedulerException {        return this.isInStandbyMode();    }    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>.     * </p>     */    public void shutdown() throws SchedulerException {        try {            String schedulerName = getSchedulerName();                        getRemoteScheduler().shutdown();                        SchedulerRepository.getInstance().remove(schedulerName);        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>.     * </p>     */    public void shutdown(boolean waitForJobsToComplete)        throws SchedulerException {        try {            String schedulerName = getSchedulerName();                        getRemoteScheduler().shutdown(waitForJobsToComplete);            SchedulerRepository.getInstance().remove(schedulerName);        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>.     * </p>     */    public boolean isShutdown() throws SchedulerException {        try {            return getRemoteScheduler().isShutdown();        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>.     * </p>     */    public List getCurrentlyExecutingJobs() throws SchedulerException {        try {            return getRemoteScheduler().getCurrentlyExecutingJobs();        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    ///////////////////////////////////////////////////////////////////////////    ///    /// Scheduling-related Methods    ///    ///////////////////////////////////////////////////////////////////////////    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>,     * passing the <code>SchedulingContext</code> associated with this     * instance.     * </p>     */    public Date scheduleJob(JobDetail jobDetail, Trigger trigger)        throws SchedulerException {        try {            return getRemoteScheduler().scheduleJob(schedCtxt, jobDetail,                    trigger);        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>,     * passing the <code>SchedulingContext</code> associated with this     * instance.     * </p>     */    public Date scheduleJob(Trigger trigger) throws SchedulerException {        try {            return getRemoteScheduler().scheduleJob(schedCtxt, trigger);        } catch (RemoteException re) {            throw invalidateHandleCreateException(                    "Error communicating with remote scheduler.", re);        }    }    /**     * <p>     * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>,

⌨️ 快捷键说明

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