📄 wrapperactionserver.java
字号:
* Starts the runner thread.
*
* @throws IOException If the server socket is unable to bind to the
* specified port or there are any other problems
* opening a socket.
*/
public void start()
throws IOException
{
// Create the server socket.
m_serverSocket = new ServerSocket( m_port, 5, m_bindAddr );
m_runner = new Thread( this, "WrapperActionServer_runner" );
m_runner.setDaemon( true );
m_runner.start();
}
/**
* Stops the runner thread, blocking until it has stopped.
*/
public void stop()
throws Exception
{
Thread runner = m_runner;
m_runnerStop = true;
runner.interrupt();
// Close the server socket so it stops blocking for new connections.
ServerSocket serverSocket = m_serverSocket;
if ( serverSocket != null )
{
try
{
serverSocket.close();
}
catch ( IOException e )
{
// Ignore.
}
}
synchronized( this )
{
while( m_runner != null )
{
try
{
// Wait to be notified that the thread has exited.
this.wait();
}
catch ( InterruptedException e )
{
// Ignore
}
}
}
}
/**
* Registers an action with the action server. The server will not accept
* any new connections until an action has returned, so keep that in mind
* when writing them. Also be aware than any uncaught exceptions will be
* dumped to the console if uncaught by the action. To avoid this, wrap
* the code in a <code>try { ... } catch (Throwable t) { ... }</code>
* block.
*
* @param command Command to be registered. Will override any exiting
* action already registered with the same command.
* @param action Action to be registered.
*/
public void registerAction( byte command, Runnable action )
{
synchronized( m_actions )
{
m_actions.put( new Integer( command ), action );
}
}
/**
* Unregisters an action with the given command. If no action exists with
* the specified command, the method will quietly ignore the call.
*/
public void unregisterAction( byte command )
{
synchronized( m_actions )
{
m_actions.remove( new Integer( command ) );
}
}
/**
* Enable or disable the shutdown command. Disabled by default.
*
* @param enable True to enable to action, false to disable it.
*/
public void enableShutdownAction( boolean enable )
{
if ( enable )
{
registerAction( COMMAND_SHUTDOWN, new Runnable()
{
public void run()
{
WrapperManager.stop( 0 );
}
} );
}
else
{
unregisterAction( COMMAND_SHUTDOWN );
}
}
/**
* Enable or disable the expected halt command. Disabled by default.
* This will shutdown the JVM, but will do so immediately without going
* through the clean shutdown process.
*
* @param enable True to enable to action, false to disable it.
*/
public void enableHaltExpectedAction( boolean enable )
{
if ( enable )
{
registerAction( COMMAND_HALT_EXPECTED, new Runnable()
{
public void run()
{
WrapperManager.stopImmediate( 0 );
}
} );
}
else
{
unregisterAction( COMMAND_HALT_EXPECTED );
}
}
/**
* Enable or disable the restart command. Disabled by default.
*
* @param enable True to enable to action, false to disable it.
*/
public void enableRestartAction( boolean enable )
{
if ( enable )
{
registerAction( COMMAND_RESTART, new Runnable()
{
public void run()
{
WrapperManager.restart();
}
} );
}
else
{
unregisterAction( COMMAND_RESTART );
}
}
/**
* Enable or disable the thread dump command. Disabled by default.
*
* @param enable True to enable to action, false to disable it.
*/
public void enableThreadDumpAction( boolean enable )
{
if ( enable )
{
registerAction( COMMAND_DUMP, new Runnable()
{
public void run()
{
WrapperManager.requestThreadDump();
}
} );
}
else
{
unregisterAction( COMMAND_DUMP );
}
}
/**
* Enable or disable the unexpected halt command. Disabled by default.
* If this command is executed, the Wrapper will think the JVM crashed
* and restart it.
*
* @param enable True to enable to action, false to disable it.
*/
public void enableHaltUnexpectedAction( boolean enable )
{
if ( enable )
{
registerAction( COMMAND_HALT_UNEXPECTED, new Runnable()
{
public void run()
{
// Execute runtime.halt(0) using reflection so this class will
// compile on 1.2.x versions of Java.
Method haltMethod;
try
{
haltMethod =
Runtime.class.getMethod( "halt", new Class[] { Integer.TYPE } );
}
catch ( NoSuchMethodException e )
{
System.out.println( "halt not supported by current JVM." );
haltMethod = null;
}
if ( haltMethod != null )
{
Runtime runtime = Runtime.getRuntime();
try
{
haltMethod.invoke( runtime, new Object[] { new Integer( 0 ) } );
}
catch ( IllegalAccessException e )
{
System.out.println(
"Unable to call runitme.halt: " + e.getMessage() );
}
catch ( InvocationTargetException e )
{
System.out.println(
"Unable to call runitme.halt: " + e.getMessage() );
}
}
}
} );
}
else
{
unregisterAction( COMMAND_HALT_UNEXPECTED );
}
}
/**
* Enable or disable the access violation command. Disabled by default.
* This command is useful for testing how an application handles the worst
* case situation where the JVM suddenly crashed. When this happens, the
* the JVM will simply die and there will be absolutely no chance for any
* shutdown or cleanup work to be done by the JVM.
*
* @param enable True to enable to action, false to disable it.
*/
public void enableAccessViolationAction( boolean enable )
{
if ( enable )
{
registerAction( COMMAND_ACCESS_VIOLATION, new Runnable()
{
public void run()
{
WrapperManager.accessViolationNative();
}
} );
}
else
{
unregisterAction( COMMAND_ACCESS_VIOLATION );
}
}
/**
* Enable or disable the appear hung command. Disabled by default.
* This command is useful for testing how an application handles the
* situation where the JVM stops responding to the Wrapper's ping
* requests. This can happen if the JVM hangs or some piece of code
* deadlocks. When this happens, the Wrapper will give up after the
* ping timeout has expired and kill the JVM process. The JVM will
* not have a chance to clean up and shudown gracefully.
*
* @param enable True to enable to action, false to disable it.
*/
public void enableAppearHungAction( boolean enable )
{
if ( enable )
{
registerAction( COMMAND_APPEAR_HUNG, new Runnable()
{
public void run()
{
WrapperManager.appearHung();
}
} );
}
else
{
unregisterAction( COMMAND_APPEAR_HUNG );
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -