daemonthread.java

来自「jetspeed源代码」· Java 代码 · 共 122 行

JAVA
122
字号
/*
 * Copyright 2000-2004 The Apache Software Foundation.
 * 
 * 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.
 */

package org.apache.jetspeed.daemon;

import org.apache.jetspeed.services.daemonfactory.DaemonFactory;
import org.apache.jetspeed.services.logging.JetspeedLogFactoryService;
import org.apache.jetspeed.services.logging.JetspeedLogger;

/**
@author <a href="mailto:burton@apache.org">Kevin A. Burton</a>
@version $Id: DaemonThread.java,v 1.20 2004/02/23 02:48:57 jford Exp $
*/
public class DaemonThread extends Thread {

    private Daemon daemon = null;
    
    /**
     * Static initialization of the logger for this class
     */
    private static final JetspeedLogger logger = JetspeedLogFactoryService.getLogger(DaemonThread.class.getName());
    
    /**
    */   
    public DaemonThread( DaemonEntry entry ) {
        
        super( "DaemonThread:" + entry.getName() );
        try {
            this.setDaemon(true);
            this.daemon = DaemonFactory.getDaemon( entry );
            this.setPriority( Thread.MIN_PRIORITY );
        } catch (DaemonException e) {
            //really screwed here.
            logger.error("Error instantiating DaemonThread", e);
        }
    }
    

    public DaemonThread()
    {
        super();
        this.setDaemon(true);
    }
    
    /**
    */
    public Daemon getDaemon() {
        return this.daemon;
    }
    
    /**
    */
    public void run() {
        //at the very minimum this daemon is processing...
        
        DaemonEntry de = this.getDaemon().getDaemonEntry();
        
        logger.info( "DaemonThread: started processing daemon " + de.getName() );

        if ( de.onStartup() ) {
            this.runDaemon( this.getDaemon() );
        }
        

        while( true ) {

            //move the seconds to miliseconds
            try {

                synchronized( this ) {
                    this.wait( de.getInterval() * 1000 );
                }

            } catch (InterruptedException e) {
                //this is a normal situation.  
                //the DaemonFactory may want to stop this thread form 
                //sleeping and call interrupt() on this thread.
            }

            this.runDaemon( this.getDaemon() );
        
        }
    

    }

    /**
    */
    private void runDaemon( Daemon daemon ) {
 
        daemon.setStatus( Daemon.STATUS_PROCESSING );

        logger.info( "DaemonThread -> PROCESSING daemon -> " + daemon.getDaemonEntry().getName() );
        
        try {
            daemon.run();                        
        } catch ( Throwable t ) {
            logger.error( "Could not process Daemon: " + daemon.getDaemonEntry().getName(), t );
        }

        logger.info( "DaemonThread -> *DONE* PROCESSING daemon -> " + daemon.getDaemonEntry().getName() );        

        daemon.setStatus( Daemon.STATUS_PROCESSED );        

    }

    
}

⌨️ 快捷键说明

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