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

📄 threadpoolmanager.java

📁 网络游戏天堂1的java源代码。。。。。
💻 JAVA
字号:
/*
 * This program 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 2, or (at your option)
 * any later version.
 *
 * This program 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 this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
 * 02111-1307, USA.
 *
 * http://www.gnu.org/copyleft/gpl.html
 */
package l1j.server.server;

import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.RejectedExecutionException;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.ScheduledThreadPoolExecutor;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.logging.Level;
import java.util.logging.Logger;

// import com.l2jserver.mmocore.network.ReceivablePacket;

import javolution.text.TextBuilder;
import l1j.server.Config;

// import l1j.server.server.network.L2GameClient;

public class ThreadPoolManager {

	private static l1j.eric.EricLogger _log =  l1j.eric.EricLogger.getLogger2(ThreadPoolManager.class
			.getName());

	private static ThreadPoolManager _instance;

	private final ScheduledThreadPoolExecutor _effectsScheduledThreadPool;

	private final ScheduledThreadPoolExecutor _generalScheduledThreadPool;

	private final ThreadPoolExecutor _generalPacketsThreadPool;

	private final ThreadPoolExecutor _ioPacketsThreadPool;

	// will be really used in the next AI implementation.
	private final ThreadPoolExecutor _aiThreadPool;

	private final ThreadPoolExecutor _generalThreadPool;

	// temp
	private final ScheduledThreadPoolExecutor _aiScheduledThreadPool;

	private boolean _shutdown;

	public static ThreadPoolManager getInstance() {
		if (_instance == null) {
			_instance = new ThreadPoolManager();
		}
		return _instance;
	}

	private ThreadPoolManager() {
		_effectsScheduledThreadPool = new ScheduledThreadPoolExecutor(
				Config.THREAD_P_EFFECTS, new PriorityThreadFactory(
						"EffectsSTPool", Thread.MIN_PRIORITY));
		_generalScheduledThreadPool = new ScheduledThreadPoolExecutor(
				Config.THREAD_P_GENERAL, new PriorityThreadFactory(
						"GerenalSTPool", Thread.NORM_PRIORITY));

		_ioPacketsThreadPool = new ThreadPoolExecutor(2, Integer.MAX_VALUE, 5L,
				TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>(),
				new PriorityThreadFactory("I/O Packet Pool",
						Thread.NORM_PRIORITY + 1));

		_generalPacketsThreadPool = new ThreadPoolExecutor(4, 6, 15L,
				TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>(),
				new PriorityThreadFactory("Normal Packet Pool",
						Thread.NORM_PRIORITY + 1));

		_generalThreadPool = new ThreadPoolExecutor(2, 4, 5L, TimeUnit.SECONDS,
				new LinkedBlockingQueue<Runnable>(), new PriorityThreadFactory(
						"General Pool", Thread.NORM_PRIORITY));

		// will be really used in the next AI implementation.
		_aiThreadPool = new ThreadPoolExecutor(1, Config.AI_MAX_THREAD, 10L,
				TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>());

		_aiScheduledThreadPool = new ScheduledThreadPoolExecutor(
				Config.AI_MAX_THREAD, new PriorityThreadFactory("AISTPool",
						Thread.NORM_PRIORITY));
	}

	public ScheduledFuture scheduleEffect(Runnable r, long delay) {
		try {
			if (delay < 0) {
				delay = 0;
			}
			return _effectsScheduledThreadPool.schedule(r, delay,
					TimeUnit.MILLISECONDS);
		} catch (RejectedExecutionException e) {
			return null; /* shutdown, ignore */
		}
	}

	public ScheduledFuture scheduleEffectAtFixedRate(Runnable r, long initial,
			long delay) {
		try {
			if (delay < 0) {
				delay = 0;
			}
			if (initial < 0) {
				initial = 0;
			}
			return _effectsScheduledThreadPool.scheduleAtFixedRate(r, initial,
					delay, TimeUnit.MILLISECONDS);
		} catch (RejectedExecutionException e) {
			return null; /* shutdown, ignore */
		}
	}

	public ScheduledFuture scheduleGeneral(Runnable r, long delay) {
		try {
			if (delay < 0) {
				delay = 0;
			}
			return _generalScheduledThreadPool.schedule(r, delay,
					TimeUnit.MILLISECONDS);
		} catch (RejectedExecutionException e) {
			return null; /* shutdown, ignore */
		}
	}

	public ScheduledFuture scheduleGeneralAtFixedRate(Runnable r, long initial,
			long delay) {
		try {
			if (delay < 0) {
				delay = 0;
			}
			if (initial < 0) {
				initial = 0;
			}
			return _generalScheduledThreadPool.scheduleAtFixedRate(r, initial,
					delay, TimeUnit.MILLISECONDS);
		} catch (RejectedExecutionException e) {
			return null; /* shutdown, ignore */
		}
	}

	public ScheduledFuture scheduleAi(Runnable r, long delay) {
		try {
			if (delay < 0) {
				delay = 0;
			}
			return _aiScheduledThreadPool.schedule(r, delay,
					TimeUnit.MILLISECONDS);
		} catch (RejectedExecutionException e) {
			return null; /* shutdown, ignore */
		}
	}

	public ScheduledFuture scheduleAiAtFixedRate(Runnable r, long initial,
			long delay) {
		try {
			if (delay < 0) {
				delay = 0;
			}
			if (initial < 0) {
				initial = 0;
			}
			return _aiScheduledThreadPool.scheduleAtFixedRate(r, initial,
					delay, TimeUnit.MILLISECONDS);
		} catch (RejectedExecutionException e) {
			return null; /* shutdown, ignore */
		}
	}

	/*
	 * public void executePacket(ReceivablePacket<L2GameClient> pkt) {
	 * _generalPacketsThreadPool.execute(pkt); }
	 * 
	 * public void executeIOPacket(ReceivablePacket<L2GameClient> pkt) {
	 * _ioPacketsThreadPool.execute(pkt); }
	 */
	public void executeTask(Runnable r) {
		_generalThreadPool.execute(r);
	}

	public void executeAi(Runnable r) {
		_aiThreadPool.execute(r);
	}

	public String[] getStats() {
		return new String[] {
				"STP:",
				" + Effects:",
				" |- ActiveThreads:   "
						+ _effectsScheduledThreadPool.getActiveCount(),
				" |- getCorePoolSize: "
						+ _effectsScheduledThreadPool.getCorePoolSize(),
				" |- PoolSize:        "
						+ _effectsScheduledThreadPool.getPoolSize(),
				" |- MaximumPoolSize: "
						+ _effectsScheduledThreadPool.getMaximumPoolSize(),
				" |- CompletedTasks:  "
						+ _effectsScheduledThreadPool.getCompletedTaskCount(),
				" |- ScheduledTasks:  "
						+ (_effectsScheduledThreadPool.getTaskCount() - _effectsScheduledThreadPool
								.getCompletedTaskCount()),
				" | -------",
				" + General:",
				" |- ActiveThreads:   "
						+ _generalScheduledThreadPool.getActiveCount(),
				" |- getCorePoolSize: "
						+ _generalScheduledThreadPool.getCorePoolSize(),
				" |- PoolSize:        "
						+ _generalScheduledThreadPool.getPoolSize(),
				" |- MaximumPoolSize: "
						+ _generalScheduledThreadPool.getMaximumPoolSize(),
				" |- CompletedTasks:  "
						+ _generalScheduledThreadPool.getCompletedTaskCount(),
				" |- ScheduledTasks:  "
						+ (_generalScheduledThreadPool.getTaskCount() - _generalScheduledThreadPool
								.getCompletedTaskCount()),
				" | -------",
				" + AI:",
				" |- ActiveThreads:   "
						+ _aiScheduledThreadPool.getActiveCount(),
				" |- getCorePoolSize: "
						+ _aiScheduledThreadPool.getCorePoolSize(),
				" |- PoolSize:        " + _aiScheduledThreadPool.getPoolSize(),
				" |- MaximumPoolSize: "
						+ _aiScheduledThreadPool.getMaximumPoolSize(),
				" |- CompletedTasks:  "
						+ _aiScheduledThreadPool.getCompletedTaskCount(),
				" |- ScheduledTasks:  "
						+ (_aiScheduledThreadPool.getTaskCount() - _aiScheduledThreadPool
								.getCompletedTaskCount()),
				"TP:",
				" + Packets:",
				" |- ActiveThreads:   "
						+ _generalPacketsThreadPool.getActiveCount(),
				" |- getCorePoolSize: "
						+ _generalPacketsThreadPool.getCorePoolSize(),
				" |- MaximumPoolSize: "
						+ _generalPacketsThreadPool.getMaximumPoolSize(),
				" |- LargestPoolSize: "
						+ _generalPacketsThreadPool.getLargestPoolSize(),
				" |- PoolSize:        "
						+ _generalPacketsThreadPool.getPoolSize(),
				" |- CompletedTasks:  "
						+ _generalPacketsThreadPool.getCompletedTaskCount(),
				" |- QueuedTasks:     "
						+ _generalPacketsThreadPool.getQueue().size(),
				" | -------",
				" + I/O Packets:",
				" |- ActiveThreads:   " + _ioPacketsThreadPool.getActiveCount(),
				" |- getCorePoolSize: "
						+ _ioPacketsThreadPool.getCorePoolSize(),
				" |- MaximumPoolSize: "
						+ _ioPacketsThreadPool.getMaximumPoolSize(),
				" |- LargestPoolSize: "
						+ _ioPacketsThreadPool.getLargestPoolSize(),
				" |- PoolSize:        " + _ioPacketsThreadPool.getPoolSize(),
				" |- CompletedTasks:  "
						+ _ioPacketsThreadPool.getCompletedTaskCount(),
				" |- QueuedTasks:     "
						+ _ioPacketsThreadPool.getQueue().size(),
				" | -------",
				" + General Tasks:",
				" |- ActiveThreads:   " + _generalThreadPool.getActiveCount(),
				" |- getCorePoolSize: " + _generalThreadPool.getCorePoolSize(),
				" |- MaximumPoolSize: "
						+ _generalThreadPool.getMaximumPoolSize(),
				" |- LargestPoolSize: "
						+ _generalThreadPool.getLargestPoolSize(),
				" |- PoolSize:        " + _generalThreadPool.getPoolSize(),
				" |- CompletedTasks:  "
						+ _generalThreadPool.getCompletedTaskCount(),
				" |- QueuedTasks:     " + _generalThreadPool.getQueue().size(),
				" | -------", " + AI:", " |- Not Done" };
	}

	private class PriorityThreadFactory implements ThreadFactory {
		private final int _prio;

		private final String _name;

		private final AtomicInteger _threadNumber = new AtomicInteger(1);

		private final ThreadGroup _group;

		public PriorityThreadFactory(String name, int prio) {
			_prio = prio;
			_name = name;
			_group = new ThreadGroup(_name);
		}

		/*
		 * (non-Javadoc)
		 * 
		 * @see java.util.concurrent.ThreadFactory#newThread(java.lang.Runnable)
		 */
		public Thread newThread(Runnable r) {
			Thread t = new Thread(_group, r);
			t.setName(_name + "-" + _threadNumber.getAndIncrement());
			t.setPriority(_prio);
			return t;
		}

		public ThreadGroup getGroup() {
			return _group;
		}
	}

	/**
	 * 
	 */
	public void shutdown() {
		_shutdown = true;
		try {
			_effectsScheduledThreadPool.awaitTermination(1, TimeUnit.SECONDS);
			_generalScheduledThreadPool.awaitTermination(1, TimeUnit.SECONDS);
			_generalPacketsThreadPool.awaitTermination(1, TimeUnit.SECONDS);
			_ioPacketsThreadPool.awaitTermination(1, TimeUnit.SECONDS);
			_generalThreadPool.awaitTermination(1, TimeUnit.SECONDS);
			_aiThreadPool.awaitTermination(1, TimeUnit.SECONDS);
			_effectsScheduledThreadPool.shutdown();
			_generalScheduledThreadPool.shutdown();
			_generalPacketsThreadPool.shutdown();
			_ioPacketsThreadPool.shutdown();
			_generalThreadPool.shutdown();
			_aiThreadPool.shutdown();
			l1j.eric.gui.J_Main.getInstance().addConsolPost("All ThreadPools are now stoped");

		} catch (InterruptedException e) {
			_log.log(Level.SEVERE, e.getLocalizedMessage(), e);

		}
	}

	public boolean isShutdown() {
		return _shutdown;
	}

	/**
	 * 
	 */
	public void purge() {
		_effectsScheduledThreadPool.purge();
		_generalScheduledThreadPool.purge();
		_aiScheduledThreadPool.purge();
		_ioPacketsThreadPool.purge();
		_generalPacketsThreadPool.purge();
		_generalThreadPool.purge();
		_aiThreadPool.purge();
	}

	/**
	 * 
	 */
	public String getPacketStats() {
		TextBuilder tb = new TextBuilder();
		ThreadFactory tf = _generalPacketsThreadPool.getThreadFactory();
		if (tf instanceof PriorityThreadFactory) {
			tb.append("General Packet Thread Pool:\r\n");
			tb.append("Tasks in the queue: "
					+ _generalPacketsThreadPool.getQueue().size() + "\r\n");
			tb.append("Showing threads stack trace:\r\n");
			PriorityThreadFactory ptf = (PriorityThreadFactory) tf;
			int count = ptf.getGroup().activeCount();
			Thread[] threads = new Thread[count + 2];
			ptf.getGroup().enumerate(threads);
			tb.append("There should be " + count + " Threads\r\n");
			for (Thread t : threads) {
				if (t == null) {
					continue;
				}
				tb.append(t.getName() + "\r\n");
				for (StackTraceElement ste : t.getStackTrace()) {
					tb.append(ste.toString());
					tb.append("\r\n");
				}
			}
		}
		tb.append("Packet Tp stack traces printed.\r\n");
		return tb.toString();
	}

	public String getIOPacketStats() {
		TextBuilder tb = new TextBuilder();
		ThreadFactory tf = _ioPacketsThreadPool.getThreadFactory();
		if (tf instanceof PriorityThreadFactory) {
			tb.append("I/O Packet Thread Pool:\r\n");
			tb.append("Tasks in the queue: "
					+ _ioPacketsThreadPool.getQueue().size() + "\r\n");
			tb.append("Showing threads stack trace:\r\n");
			PriorityThreadFactory ptf = (PriorityThreadFactory) tf;
			int count = ptf.getGroup().activeCount();
			Thread[] threads = new Thread[count + 2];
			ptf.getGroup().enumerate(threads);
			tb.append("There should be " + count + " Threads\r\n");
			for (Thread t : threads) {
				if (t == null) {
					continue;
				}
				tb.append(t.getName() + "\r\n");
				for (StackTraceElement ste : t.getStackTrace()) {
					tb.append(ste.toString());
					tb.append("\r\n");
				}
			}
		}
		tb.append("Packet Tp stack traces printed.\r\n");
		return tb.toString();
	}

	public String getGeneralStats() {
		TextBuilder tb = new TextBuilder();
		ThreadFactory tf = _generalThreadPool.getThreadFactory();
		if (tf instanceof PriorityThreadFactory) {
			tb.append("General Thread Pool:\r\n");
			tb.append("Tasks in the queue: "
					+ _generalThreadPool.getQueue().size() + "\r\n");
			tb.append("Showing threads stack trace:\r\n");
			PriorityThreadFactory ptf = (PriorityThreadFactory) tf;
			int count = ptf.getGroup().activeCount();
			Thread[] threads = new Thread[count + 2];
			ptf.getGroup().enumerate(threads);
			tb.append("There should be " + count + " Threads\r\n");
			for (Thread t : threads) {
				if (t == null) {
					continue;
				}
				tb.append(t.getName() + "\r\n");
				for (StackTraceElement ste : t.getStackTrace()) {
					tb.append(ste.toString());
					tb.append("\r\n");
				}
			}
		}
		tb.append("Packet Tp stack traces printed.\r\n");
		return tb.toString();
	}
}

⌨️ 快捷键说明

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