forked from External/mage
server: fixed server app freeze on another instance already running, improved threads usage (related to #11285);
This commit is contained in:
parent
f0c38cdb87
commit
7d675de876
21 changed files with 203 additions and 106 deletions
|
|
@ -8,7 +8,7 @@ import java.util.concurrent.ExecutionException;
|
|||
import java.util.concurrent.Future;
|
||||
|
||||
/**
|
||||
* Util method to work with threads.
|
||||
* Helper class to work with threads
|
||||
*
|
||||
* @author ayrat, JayDi85
|
||||
*/
|
||||
|
|
@ -16,20 +16,37 @@ public final class ThreadUtils {
|
|||
|
||||
// basic
|
||||
public final static String THREAD_PREFIX_GAME = "GAME";
|
||||
public final static String THREAD_PREFIX_AI_SIMULATION = "AI-SIM";
|
||||
public final static String THREAD_PREFIX_AI_SIMULATION_MAD = "AI-SIM-MAD";
|
||||
public final static String THREAD_PREFIX_AI_SIMULATION_MCTS = "AI-SIM-MCTS";
|
||||
public final static String THREAD_PREFIX_CALL_REQUEST = "CALL";
|
||||
public final static String THREAD_PREFIX_TOURNEY = "TOURNEY";
|
||||
public final static String THREAD_PREFIX_TOURNEY_DRAFT = "TOURNEY DRAFT";
|
||||
public final static String THREAD_PREFIX_TOURNEY_BOOSTERS_SEND = "TOURNEY BOOSTERS SEND";
|
||||
|
||||
// game
|
||||
public final static String THREAD_PREFIX_GAME_JOIN_WAITING = "XMAGE game join waiting";
|
||||
|
||||
// services
|
||||
public final static String THREAD_PREFIX_SERVICE_HEALTH = "XMAGE HEALTH";
|
||||
public final static String THREAD_PREFIX_SERVICE_HEALTH = "XMAGE service health";
|
||||
public final static String THREAD_PREFIX_SERVICE_USERS_LIST_REFRESH = "XMAGE users list refresh";
|
||||
public final static String THREAD_PREFIX_SERVICE_CONNECTION_EXPIRED_CHECK = "XMAGE connection expired check";
|
||||
public final static String THREAD_PREFIX_SERVICE_LOBBY_REFRESH = "XMAGE lobby refresh";
|
||||
public final static String THREAD_PREFIX_SERVICE_NEWS_REFRESH = "XMAGE news refresh";
|
||||
|
||||
// etc
|
||||
public final static String THREAD_PREFIX_TIMEOUT = "XMAGE TIMEOUT";
|
||||
public final static String THREAD_PREFIX_TIMEOUT_IDLE = "XMAGE TIMEOUT_IDLE";
|
||||
|
||||
public final static String THREAD_PREFIX_TIMEOUT = "XMAGE timeout";
|
||||
public final static String THREAD_PREFIX_TIMEOUT_IDLE = "XMAGE timeout_idle";
|
||||
|
||||
// client
|
||||
// TODO: replace single GUI tasks by swing thread (invoke later) or by single executor like (like CALL for server side)
|
||||
public final static String THREAD_PREFIX_CLIENT_SYMBOLS_DOWNLOADER = "XMAGE symbols downloader";
|
||||
public final static String THREAD_PREFIX_CLIENT_IMAGES_DOWNLOADER = "XMAGE images downloader";
|
||||
public final static String THREAD_PREFIX_CLIENT_PING_SENDER = "XMAGE ping sender";
|
||||
public final static String THREAD_PREFIX_CLIENT_SUBMIT_TIMER = "XMAGE submit timer";
|
||||
public final static String THREAD_PREFIX_CLIENT_AUTO_CLOSE_TIMER = "XMAGE auto-close timer";
|
||||
|
||||
// tests
|
||||
public final static String THREAD_PREFIX_TESTS_AI_VS_AI_GAMES = "XMAGE tests ai vs ai";
|
||||
|
||||
public static void sleep(int millis) {
|
||||
try {
|
||||
|
|
@ -88,7 +105,7 @@ public final class ThreadUtils {
|
|||
if (name.startsWith(THREAD_PREFIX_GAME)) {
|
||||
// server game
|
||||
return true;
|
||||
} else if (name.startsWith(THREAD_PREFIX_AI_SIMULATION)) {
|
||||
} else if (name.startsWith(THREAD_PREFIX_AI_SIMULATION_MAD)) {
|
||||
// ai simulation
|
||||
return true;
|
||||
} else if (name.equals("main")) {
|
||||
|
|
|
|||
42
Mage/src/main/java/mage/util/XMageThreadFactory.java
Normal file
42
Mage/src/main/java/mage/util/XMageThreadFactory.java
Normal file
|
|
@ -0,0 +1,42 @@
|
|||
package mage.util;
|
||||
|
||||
import java.util.concurrent.ThreadFactory;
|
||||
import java.util.concurrent.atomic.AtomicInteger;
|
||||
|
||||
/**
|
||||
* Helper class to give debug friendly names for a threads
|
||||
*
|
||||
* @author JayDi85
|
||||
*/
|
||||
public class XMageThreadFactory implements ThreadFactory {
|
||||
|
||||
private final String prefix;
|
||||
private final AtomicInteger counter = new AtomicInteger();
|
||||
private final boolean isDaemon;
|
||||
|
||||
public XMageThreadFactory(String prefix) {
|
||||
this(prefix, true);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param prefix thread's starting name (can be changed by thread itself later)
|
||||
* @param isDaemon mark thread as daemon on non-writeable tasks (e.g. can be terminated at any time without data loss)
|
||||
*/
|
||||
public XMageThreadFactory(String prefix, boolean isDaemon) {
|
||||
this.prefix = prefix;
|
||||
this.isDaemon = isDaemon;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Thread newThread(Runnable r) {
|
||||
int instanceNumber = this.counter.incrementAndGet();
|
||||
|
||||
Thread thread = new Thread(r);
|
||||
thread.setDaemon(this.isDaemon);
|
||||
|
||||
// gives default name, but threads can change it by Thread.currentThread().setName (example: on game or tourney start)
|
||||
thread.setName(String.format("%s - %d", this.prefix, instanceNumber));
|
||||
|
||||
return thread;
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue