亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? loggingtriggerhistoryplugin.java

?? Java中非常實用流控制工具
?? JAVA
字號:
/*  * 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.plugins.history;import java.text.MessageFormat;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import org.quartz.JobExecutionContext;import org.quartz.Scheduler;import org.quartz.SchedulerException;import org.quartz.Trigger;import org.quartz.TriggerListener;import org.quartz.spi.SchedulerPlugin;/** * Logs a history of all trigger firings via the Jakarta Commons-Logging * framework. *  * <p> * The logged message is customizable by setting one of the following message * properties to a String that conforms to the syntax of <code>java.util.MessageFormat</code>. * </p> *  * <p> * TriggerFiredMessage - available message data are: <table> * <tr> * <th>Element</th> * <th>Data Type</th> * <th>Description</th> * </tr> * <tr> * <td>0</td> * <td>String</td> * <td>The Trigger's Name.</td> * </tr> * <tr> * <td>1</td> * <td>String</td> * <td>The Trigger's Group.</td> * </tr> * <tr> * <td>2</td> * <td>Date</td> * <td>The scheduled fire time.</td> * </tr> * <tr> * <td>3</td> * <td>Date</td> * <td>The next scheduled fire time.</td> * </tr> * <tr> * <td>4</td> * <td>Date</td> * <td>The actual fire time.</td> * </tr> * <tr> * <td>5</td> * <td>String</td> * <td>The Job's name.</td> * </tr> * <tr> * <td>6</td> * <td>String</td> * <td>The Job's group.</td> * </tr> * <tr> * <td>7</td> * <td>Integer</td> * <td>The re-fire count from the JobExecutionContext.</td> * </tr> * </table> *  * The default message text is <i>"Trigger {1}.{0} fired job {6}.{5} at: {4, * date, HH:mm:ss MM/dd/yyyy}"</i> * </p> *  * <p> * TriggerMisfiredMessage - available message data are: <table> * <tr> * <th>Element</th> * <th>Data Type</th> * <th>Description</th> * </tr> * <tr> * <td>0</td> * <td>String</td> * <td>The Trigger's Name.</td> * </tr> * <tr> * <td>1</td> * <td>String</td> * <td>The Trigger's Group.</td> * </tr> * <tr> * <td>2</td> * <td>Date</td> * <td>The scheduled fire time.</td> * </tr> * <tr> * <td>3</td> * <td>Date</td> * <td>The next scheduled fire time.</td> * </tr> * <tr> * <td>4</td> * <td>Date</td> * <td>The actual fire time. (the time the misfire was detected/handled)</td> * </tr> * <tr> * <td>5</td> * <td>String</td> * <td>The Job's name.</td> * </tr> * <tr> * <td>6</td> * <td>String</td> * <td>The Job's group.</td> * </tr> * </table> *  * The default message text is <i>"Trigger {1}.{0} misfired job {6}.{5} at: * {4, date, HH:mm:ss MM/dd/yyyy}. Should have fired at: {3, date, HH:mm:ss * MM/dd/yyyy}"</i> * </p> *  * <p> * TriggerCompleteMessage - available message data are: <table> * <tr> * <th>Element</th> * <th>Data Type</th> * <th>Description</th> * </tr> * <tr> * <td>0</td> * <td>String</td> * <td>The Trigger's Name.</td> * </tr> * <tr> * <td>1</td> * <td>String</td> * <td>The Trigger's Group.</td> * </tr> * <tr> * <td>2</td> * <td>Date</td> * <td>The scheduled fire time.</td> * </tr> * <tr> * <td>3</td> * <td>Date</td> * <td>The next scheduled fire time.</td> * </tr> * <tr> * <td>4</td> * <td>Date</td> * <td>The job completion time.</td> * </tr> * <tr> * <td>5</td> * <td>String</td> * <td>The Job's name.</td> * </tr> * <tr> * <td>6</td> * <td>String</td> * <td>The Job's group.</td> * </tr> * <tr> * <td>7</td> * <td>Integer</td> * <td>The re-fire count from the JobExecutionContext.</td> * </tr> * <tr> * <td>8</td> * <td>Integer</td> * <td>The trigger's resulting instruction code.</td> * </tr> * <tr> * <td>9</td> * <td>String</td> * <td>A human-readable translation of the trigger's resulting instruction * code.</td> * </tr> * </table> *  * The default message text is <i>"Trigger {1}.{0} completed firing job * {6}.{5} at {4, date, HH:mm:ss MM/dd/yyyy} with resulting trigger instruction * code: {9}"</i> * </p> *  * @author James House */public class LoggingTriggerHistoryPlugin implements SchedulerPlugin,        TriggerListener {    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Data members.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    private String name;    private String triggerFiredMessage = "Trigger {1}.{0} fired job {6}.{5} at: {4, date, HH:mm:ss MM/dd/yyyy}";    private String triggerMisfiredMessage = "Trigger {1}.{0} misfired job {6}.{5}  at: {4, date, HH:mm:ss MM/dd/yyyy}.  Should have fired at: {3, date, HH:mm:ss MM/dd/yyyy}";    private String triggerCompleteMessage = "Trigger {1}.{0} completed firing job {6}.{5} at {4, date, HH:mm:ss MM/dd/yyyy} with resulting trigger instruction code: {9}";    private final Log log = LogFactory.getLog(getClass());    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Constructors.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    public LoggingTriggerHistoryPlugin() {    }    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * Interface.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    protected Log getLog() {        return log;    }    /**     * Get the message that is printed upon the completion of a trigger's     * firing.     *      * @return String     */    public String getTriggerCompleteMessage() {        return triggerCompleteMessage;    }    /**     * Get the message that is printed upon a trigger's firing.     *      * @return String     */    public String getTriggerFiredMessage() {        return triggerFiredMessage;    }    /**     * Get the message that is printed upon a trigger's mis-firing.     *      * @return String     */    public String getTriggerMisfiredMessage() {        return triggerMisfiredMessage;    }    /**     * Set the message that is printed upon the completion of a trigger's     * firing.     *      * @param triggerCompleteMessage     *          String in java.text.MessageFormat syntax.     */    public void setTriggerCompleteMessage(String triggerCompleteMessage) {        this.triggerCompleteMessage = triggerCompleteMessage;    }    /**     * Set the message that is printed upon a trigger's firing.     *      * @param triggerFiredMessage     *          String in java.text.MessageFormat syntax.     */    public void setTriggerFiredMessage(String triggerFiredMessage) {        this.triggerFiredMessage = triggerFiredMessage;    }    /**     * Set the message that is printed upon a trigger's firing.     *      * @param triggerMisfiredMessage     *          String in java.text.MessageFormat syntax.     */    public void setTriggerMisfiredMessage(String triggerMisfiredMessage) {        this.triggerMisfiredMessage = triggerMisfiredMessage;    }    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * SchedulerPlugin Interface.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    /**     * <p>     * Called during creation of the <code>Scheduler</code> in order to give     * the <code>SchedulerPlugin</code> a chance to initialize.     * </p>     *      * @throws SchedulerConfigException     *           if there is an error initializing.     */    public void initialize(String name, Scheduler scheduler)        throws SchedulerException {        this.name = name;        scheduler.addGlobalTriggerListener(this);    }    public void start() {        // do nothing...    }    /**     * <p>     * Called in order to inform the <code>SchedulerPlugin</code> that it     * should free up all of it's resources because the scheduler is shutting     * down.     * </p>     */    public void shutdown() {        // nothing to do...    }    /*     * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     *      * TriggerListener Interface.     *      * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~     */    /*     * Object[] arguments = { new Integer(7), new     * Date(System.currentTimeMillis()), "a disturbance in the Force" };     *      * String result = MessageFormat.format( "At {1,time} on {1,date}, there     * was {2} on planet {0,number,integer}.", arguments);     */    public String getName() {        return name;    }    public void triggerFired(Trigger trigger, JobExecutionContext context) {        if (!getLog().isInfoEnabled()) {            return;        }                 Object[] args = {            trigger.getName(), trigger.getGroup(),            trigger.getPreviousFireTime(), trigger.getNextFireTime(),            new java.util.Date(), context.getJobDetail().getName(),            context.getJobDetail().getGroup(),            new Integer(context.getRefireCount())        };        getLog().info(MessageFormat.format(getTriggerFiredMessage(), args));    }    public void triggerMisfired(Trigger trigger) {        if (!getLog().isInfoEnabled()) {            return;        }                 Object[] args = {            trigger.getName(), trigger.getGroup(),            trigger.getPreviousFireTime(), trigger.getNextFireTime(),            new java.util.Date(), trigger.getJobGroup(),            trigger.getJobGroup()        };        getLog().info(MessageFormat.format(getTriggerMisfiredMessage(), args));    }    public void triggerComplete(Trigger trigger, JobExecutionContext context,            int triggerInstructionCode) {        if (!getLog().isInfoEnabled()) {            return;        }                 String instrCode = "UNKNOWN";        if (triggerInstructionCode == Trigger.INSTRUCTION_DELETE_TRIGGER) {            instrCode = "DELETE TRIGGER";        } else if (triggerInstructionCode == Trigger.INSTRUCTION_NOOP) {            instrCode = "DO NOTHING";        } else if (triggerInstructionCode == Trigger.INSTRUCTION_RE_EXECUTE_JOB) {            instrCode = "RE-EXECUTE JOB";        } else if (triggerInstructionCode == Trigger.INSTRUCTION_SET_ALL_JOB_TRIGGERS_COMPLETE) {            instrCode = "SET ALL OF JOB'S TRIGGERS COMPLETE";        } else if (triggerInstructionCode == Trigger.INSTRUCTION_SET_TRIGGER_COMPLETE) {            instrCode = "SET THIS TRIGGER COMPLETE";        }        Object[] args = {            trigger.getName(), trigger.getGroup(),            trigger.getPreviousFireTime(), trigger.getNextFireTime(),            new java.util.Date(), context.getJobDetail().getName(),            context.getJobDetail().getGroup(),            new Integer(context.getRefireCount()),            new Integer(triggerInstructionCode), instrCode        };        getLog().info(MessageFormat.format(getTriggerCompleteMessage(), args));    }    public boolean vetoJobExecution(Trigger trigger, JobExecutionContext context) {        return false;    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本视频在线一区| 99视频在线精品| 一区二区三区视频在线看| 中文字幕乱码久久午夜不卡| 久久久高清一区二区三区| 精品国免费一区二区三区| 91精品国产日韩91久久久久久| 欧美日韩亚洲综合一区| 欧美日韩一区二区在线视频| 欧美日韩一级片网站| 欧美丰满美乳xxx高潮www| 制服丝袜亚洲精品中文字幕| 日韩一区二区三区免费看| 日韩欧美国产一二三区| 久久久99精品免费观看不卡| 国产精品沙发午睡系列990531| 欧美国产精品一区二区三区| 自拍偷自拍亚洲精品播放| 一级日本不卡的影视| 亚洲大型综合色站| 久99久精品视频免费观看| 成人不卡免费av| 欧美日韩国产高清一区| 久久综合九色综合欧美98| 国产片一区二区| 亚洲国产美国国产综合一区二区| 久草热8精品视频在线观看| 成人免费毛片a| 欧美在线999| 久久青草欧美一区二区三区| 亚洲欧美乱综合| 奇米精品一区二区三区在线观看一| 国产精品主播直播| 欧美在线免费观看视频| 欧美国产欧美亚州国产日韩mv天天看完整 | 精品国产乱码久久久久久久久| 久久久亚洲精华液精华液精华液| 国产精品免费丝袜| 美腿丝袜在线亚洲一区| 不卡欧美aaaaa| 日韩欧美国产一区二区三区| 亚洲欧美一区二区三区极速播放 | 免费人成黄页网站在线一区二区| 国内精品免费**视频| 99久久国产综合精品色伊 | 精品国产伦一区二区三区观看体验 | 精品国产麻豆免费人成网站| 综合久久久久久久| 国产在线精品不卡| 欧美日韩国产高清一区二区| 中文字幕一区二区三区在线不卡| 精品一区二区av| 制服视频三区第一页精品| 国产精品家庭影院| 国产九色精品成人porny| 91精品国产乱码| 亚洲成人tv网| 欧美专区在线观看一区| 国产精品视频在线看| 欧美aⅴ一区二区三区视频| 99re视频这里只有精品| 欧美国产精品一区| 国内精品国产成人| 精品粉嫩超白一线天av| 日韩国产精品久久久| 欧美亚洲图片小说| 亚洲另类色综合网站| 99免费精品视频| 国产欧美精品一区二区色综合朱莉| 经典三级视频一区| 日韩免费一区二区| 激情另类小说区图片区视频区| 日韩丝袜情趣美女图片| 麻豆精品新av中文字幕| 日韩你懂的在线播放| 国内精品在线播放| 久久久精品欧美丰满| 国产成人啪免费观看软件| 国产视频一区在线播放| 成人小视频免费在线观看| 国产精品色一区二区三区| 国产成人免费在线观看不卡| 欧美国产激情一区二区三区蜜月| 从欧美一区二区三区| 亚洲日本在线a| 欧美私人免费视频| 日韩不卡一二三区| 亚洲精品一区在线观看| 国产成人免费视频网站| 亚洲欧洲日产国产综合网| 91美女精品福利| 三级在线观看一区二区| 欧美不卡一区二区三区| 不卡视频一二三| 首页综合国产亚洲丝袜| 2022国产精品视频| av午夜一区麻豆| 午夜精品视频在线观看| 26uuu久久天堂性欧美| 97se亚洲国产综合自在线观| 午夜不卡av免费| 国产视频视频一区| 91黄视频在线观看| 久久精品99国产精品| 中文字幕一区视频| 884aa四虎影成人精品一区| 国产精品一区二区免费不卡| 亚洲人成亚洲人成在线观看图片 | 亚洲乱码精品一二三四区日韩在线| 欧美亚洲综合网| 国产91精品露脸国语对白| 亚洲成人av资源| ㊣最新国产の精品bt伙计久久| 欧美日韩一级视频| 99久久精品费精品国产一区二区| 美女网站在线免费欧美精品| 亚洲欧洲在线观看av| 精品理论电影在线| 欧美日韩国产综合一区二区| 国产成人在线电影| 韩国女主播一区二区三区| 一区二区三区成人在线视频| 久久久久久久久免费| 91精品欧美福利在线观看 | 亚洲线精品一区二区三区 | 亚洲综合一区二区| 国产亚洲综合性久久久影院| 欧美精品aⅴ在线视频| 91首页免费视频| 粗大黑人巨茎大战欧美成人| 久久福利资源站| 日韩av成人高清| 亚洲成年人网站在线观看| 一区二区三区在线视频观看| 日本一区二区三区在线不卡| 精品福利av导航| 精品处破学生在线二十三| 日韩精品中文字幕在线不卡尤物 | 日韩欧美中文字幕公布| 欧美另类高清zo欧美| 91久久精品日日躁夜夜躁欧美| av中文字幕不卡| 成人深夜福利app| 成人国产免费视频| 国产成人福利片| 韩国中文字幕2020精品| 国内精品视频666| 狠狠v欧美v日韩v亚洲ⅴ| 九色综合狠狠综合久久| 久久精品99久久久| 韩国一区二区三区| 国产高清成人在线| 丰满少妇久久久久久久| 国产精品18久久久久久久久| 国产一本一道久久香蕉| 国产电影一区在线| 粉嫩av一区二区三区| 成人国产精品免费观看动漫 | 日日夜夜精品视频天天综合网| 亚洲综合一区二区| 天天色 色综合| 免费的国产精品| 国产一区视频在线看| 粉嫩久久99精品久久久久久夜| 国产91在线|亚洲| 欧美日韩精品是欧美日韩精品| 在线亚洲人成电影网站色www| 色婷婷一区二区| 欧美日韩你懂得| 精品国产一区二区在线观看| 国产欧美视频一区二区| 亚洲乱码国产乱码精品精可以看| 午夜久久久久久电影| 国产一区亚洲一区| 91在线播放网址| 欧美一区中文字幕| 国产午夜精品久久久久久免费视| 亚洲视频图片小说| 日韩av中文在线观看| 国产福利精品导航| 欧美三级视频在线播放| 精品国产一区二区三区不卡| 国产精品色婷婷久久58| 亚洲777理论| 粉嫩蜜臀av国产精品网站| 欧美性猛片aaaaaaa做受| xnxx国产精品| 一区二区三区蜜桃| 国产麻豆成人精品| 欧美午夜片在线观看| 国产欧美综合在线观看第十页| 亚洲一区在线视频观看| 国内精品久久久久影院薰衣草| 91福利视频网站| 国产人妖乱国产精品人妖| 丝袜诱惑制服诱惑色一区在线观看| 国产高清在线精品| 制服丝袜亚洲精品中文字幕| 亚洲欧美另类小说| 国产福利一区二区三区视频 |