[
https://jira.jboss.org/jira/browse/JBASM-3?page=com.atlassian.jira.plugin...
]
Aleksandar Kostadinov commented on JBASM-3:
-------------------------------------------
I looked at the things and would suggest the following solutions:
1. For the listThreadDump() to work, server manager has to RMI connect to the server and
call the method. It currently uses shutdown.jar for the job. So I'm going to change:
1.1. shutdown.jar to *not* be used
1.2. connect to the JBoss server
1.3. call the shutdown() method of jboss.system:type=Server
1.4. wait for server to shutdown (return if successful)
1.5. try calling listThreadDump() and output to server log or stdout (ignoring
exceptions)
1.6. destroy process
positives:
* higher chance to be able to call the method successfully as server connection is not
created after unknown number of services are already undeployed
negatives:
* dumps come in html markup (I tried EAP 4.3 CP02)
* additional dependencies to server manager (jars)
2. for kill-3
jboss-native needs a pre-compiled native library to work on any platform. So I see it as
an overkill for us. Instead I can change server start method to use specially crafted bash
or/and perl script if the executable is found in PATH. Then doing destroy on the spawned
process will cause kill -3 to the server process if it still exists followed by a kill
-9.
We can't send ctrl+c to a terminal so on windows one would be stuck installing cygwin
or perl for the feature to work. As well every platform I've looked at can have perl
and/or bash installed.
Get a threaddump on hung servers
--------------------------------
Key: JBASM-3
URL:
https://jira.jboss.org/jira/browse/JBASM-3
Project: JBoss AS Server Manager
Issue Type: Feature Request
Reporter: Dimitris Andreadis
Assignee: Shelly McGowan
At times where the timeout for shutting down a server has passed, and we try to kill it,
I think it would be a good idea to first send a signal to the server JVM to produce a
threaddump so we capture that in the logs and see what happens in there.
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
https://jira.jboss.org/jira/secure/Administrators.jspa
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira