loadtest.java

来自「定时器开源项目, 相对于 jcrontab, Quartz 算是更完整的一个项目」· Java 代码 · 共 134 行

JAVA
134
字号
/* * Copyright James House (c) 2001-2004 *  * All rights reserved. *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: 1. * Redistributions of source code must retain the above copyright notice, this * list of conditions and the following disclaimer. 2. Redistributions in * binary form must reproduce the above copyright notice, this list of * conditions and the following disclaimer in the documentation and/or other * materials provided with the distribution. *  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *   */package org.quartz.examples;import java.util.Date;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import org.quartz.JobDetail;import org.quartz.Scheduler;import org.quartz.SchedulerFactory;import org.quartz.SimpleTrigger;/** * @author James House */public class LoadTest {    public static void loadTest(SchedulerFactory sf) throws Exception {        Log lg = LogFactory.getLog(LoadTest.class);        lg.info("------- Initializing -------------------");        Scheduler sched = sf.getScheduler();        lg.warn("      *** Deleting existing jobs/triggers ***");        String[] groups = sched.getTriggerGroupNames();        for (int i = 0; i < groups.length; i++) {            String[] names = sched.getTriggerNames(groups[i]);            for (int j = 0; j < names.length; j++)                sched.unscheduleJob(names[j], groups[i]);        }        groups = sched.getJobGroupNames();        for (int i = 0; i < groups.length; i++) {            String[] names = sched.getJobNames(groups[i]);            for (int j = 0; j < names.length; j++)                sched.deleteJob(names[j], groups[i]);        }        lg.info("------- Initialization Complete -----------");        lg.info("------- Scheduling a Big Pile of Jobs -----------");        String schedId = sched.getSchedulerInstanceId();        int count = 1;        for (; count <= 500; count++) {            JobDetail job = new JobDetail("job_" + count, "grp_1",                    DumbDelayJob.class);            job.getJobDataMap().put(DumbDelayJob.KEY_DELAY, 60000L);            // ask scheduler to re-execute this job if it was in progress when            // the scheduler went down...            job.setRequestsRecovery(true);            SimpleTrigger trigger = new SimpleTrigger("trig_" + count, "grp_1");            trigger.setStartTime(new Date(System.currentTimeMillis() + 10000L                    + (count * 100)));            //lg.info(job.getFullName() + " will run at: " +            // trigger.getNextFireTime() + " & repeat: " +            // trigger.getRepeatCount() + "/" + trigger.getRepeatInterval());            sched.scheduleJob(job, trigger);            if (count % 25 == 0) lg.info("...scheduled " + count + " jobs...");        }        lg.info("Finished scheduling " + count + " jobs.");        lg.info("------- Starting Scheduler ----------------");        // jobs don't start firing until start() has been called...        sched.start();        lg.info("------- Started Scheduler -----------------");        lg.info("------- Waiting... -----------------------");        try {            Thread.sleep(600L * 1000L);        } catch (Exception e) {        }        lg.info("------- Shutting Down ---------------------");        sched.shutdown();        lg.info("------- Shutdown Complete -----------------");    }    public static void main(String[] args) throws Exception {        try {            // Configure Log4J            // org.apache.log4j.PropertyConfigurator.configure(System.getProperty("log4jConfigFile",            // "log4j.properties"));            boolean clearJobs = false;            boolean scheduleJobs = true;            for (int i = 0; i < args.length; i++) {                if (args[i].equals("clearJobs")) clearJobs = true;                if (args[i].equals("dontScheduleJobs")) scheduleJobs = false;            }            loadTest(new org.quartz.impl.StdSchedulerFactory());        } catch (Exception e) {            e.printStackTrace();        }    }}// EOF

⌨️ 快捷键说明

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