[jboss-jira] [JBoss JIRA] Commented: (JBAS-3748) Allow bin/run.sh to run in the background and stop jboss, when stopped.
Ian Springer (JIRA)
jira-events at jboss.com
Mon Oct 9 15:25:41 EDT 2006
[ http://jira.jboss.com/jira/browse/JBAS-3748?page=comments#action_12344909 ]
Ian Springer commented on JBAS-3748:
------------------------------------
I tested the version Dmitris checked in on RHEL4. Once I've set the LAUNCH_JBOSS_IN_BACKGROUND flag, i.e.:
export LAUNCH_JBOSS_IN_BACKGROUND=1
everything works as designed.
---
Note, I noticed during my testing that JBoss ignores SIGPIPE. So running "kill -PIPE" on the run.sh process, is a no-op. However, if a "real" SIGPIPE occurs, JBoss becomes disconnected from its output and so run.sh appears to be hung. To reproduce this, run:
export LAUNCH_JBOSS_IN_BACKGROUND=1
./run.sh | more
Then, from another terminal, kill the 'more' process. You should see the run.sh window appear to hang, though JBoss will still be running, with its output going to /dev/null. Not sure if/how we want to handle this situation; one possiblity would be to stop the JBoss process if a SIGPIPE occurs, i.e.:
trap "kill -TERM $JBOSS_PID" PIPE
Another possiblity would be to print a warning, i.e.:
trap "WARNING: run.sh has received a SIGPIPE; JBoss output may no longer be associated with a terminal." PIPE
> Allow bin/run.sh to run in the background and stop jboss, when stopped.
> -----------------------------------------------------------------------
>
> Key: JBAS-3748
> URL: http://jira.jboss.com/jira/browse/JBAS-3748
> Project: JBoss Application Server
> Issue Type: Feature Request
> Security Level: Public(Everyone can see)
> Affects Versions: JBossAS-4.0.5.CR1
> Reporter: John Mazzitelli
> Assigned To: Dimitris Andreadis
> Fix For: JBossAS-4.0.5.GA
>
> Attachments: patch-pidfile.txt, patch.txt, run.sh.patch
>
>
> I want to write an init.d script with the typical start - stop options to start JBossAS. I want to use the method of writing a pid file when started and killing the pid found in the file when stopping.
> I do not want to use the "normal" shutdown mechanism to stop it because that assumes the JBoss instance has exposed its remote MBean interface (and I do not want to assume that). Plus, I want to ensure it is killed, and using the "kill" command is as fool-proof as I need it to be.
> I also want to be able to use run.sh to start the instance (I do not want to have to do all the work run.sh does - setting up the JVM, passing in arguments, worrying about all the cygwin - darwin things, etc. etc.).
> But, if my init.d script starts run.sh, I cannot use $! in my init.d script as the pid file contents because $! is the pid of run.sh script process. It is NOT the pid of the JBoss JVM instance itself. If I then go to kill the run.sh process, it dies, but the JVM process does not. Therefore, the init.d stop option does not work - it cannot stop the JBoss VM.
> I would like to propose to make the following change to run.sh that would facilitate this. This change is backwards compatible. What this change does is - if I set the environment variable "LAUNCH_JBOSS_IN_BACKGROUND" and source run.sh, run.sh will export JBOSS_PID as the pid value of the JVM process. My init.d script (the thing that sources run.sh) will be able to write JBOSS_PID anywhere I want and thus later be able to use it to kill the JBoss VM.
> See attached patch for the change.
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://jira.jboss.com/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the jboss-jira
mailing list