/**
* This file is part of aion-emu <aion-emu.com>.
*
* aion-emu is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* aion-emu is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with aion-emu. If not, see <http://www.gnu.org/licenses/>.
*/
package com.aionemu.loginserver;
import org.apache.log4j.Logger;
import com.aionemu.commons.database.DatabaseFactory;
import com.aionemu.loginserver.network.IOServer;
import com.aionemu.loginserver.utils.ThreadPoolManager;
/**
* @author -Nemesiss-
*/
public class Shutdown extends Thread
{
/**
* Logger for this class
*/
private static final Logger log = Logger.getLogger(Shutdown.class);
/**
* Instance of Shutdown.
*/
private static Shutdown instance = new Shutdown();
/**
* get the shutdown-hook instance the shutdown-hook instance is created by the first call of this function, but it
* has to be registrered externaly.
*
* @return instance of Shutdown, to be used as shutdown hook
*/
public static Shutdown getInstance()
{
return instance;
}
/**
* this function is called, when a new thread starts if this thread is the thread of getInstance, then this is the
* shutdown hook and we save all data and disconnect all clients. after this thread ends, the server will completely
* exit if this is not the thread of getInstance, then this is a countdown thread. we start the countdown, and when
* we finished it, and it was not aborted, we tell the shutdown-hook why we call exit, and then call exit when the
* exit status of the server is 1, startServer.sh / startServer.bat will restart the server.
*/
@Override
public void run()
{
/* Disconnecting all the clients */
try
{
IOServer.getInstance().shutdown();
}
catch (Throwable t)
{
log.error("Can't shutdown IOServer", t);
}
/* Shuting down DB connections */
try
{
DatabaseFactory.shutdown();
}
catch (Throwable t)
{
log.error("Can't shutdown DatabaseFactory", t);
}
/* Shuting down threadpools */
try
{
ThreadPoolManager.getInstance().shutdown();
}
catch (Throwable t)
{
log.error("Can't shutdown ThreadPoolManager", t);
}
}
}