[
https://issues.jboss.org/browse/AS7-5929?page=com.atlassian.jira.plugin.s...
]
Brian Stansberry edited comment on AS7-5929 at 11/27/12 10:10 AM:
------------------------------------------------------------------
I think the trick is probably within ControlledProcessState itself. A boolean field
"restartRequired" that gets set in setRestartRequired():
{code}
synchronized (service) {
if (stateRef.compareAndSet(was, State.RESTART_REQUIRED, receiver[0], newStamp)) {
service.stateChanged(State.RESTART_REQUIRED);
restartRequired = true;
break;
}
}
{code}
and cleared in revertRestartRequired():
{code}
synchronized (service) {
if (state.compareAndSet(State.RESTART_REQUIRED, State.RUNNING, theirStamp,
this.stamp.incrementAndGet())) {
service.stateChanged(State.RUNNING);
restartRequired = false;
}
}
{code}
and read in setRunning():
{code}
synchronized (service) {
State newRunningState = restartRequired ? State.RESTART_REQUIRED : State.RUNNING;
state.set(newRunningState, stamp.incrementAndGet());
service.stateChanged(newRunningState);
}
{code}
All writes and reads to restartRequired are guarded by synchronized (service) so it is
thread safe.
was (Author: brian.stansberry):
I think the trick is probably within ControlledProcessState itself. A boolean field
"restartRequired" that gets set in setRestartRequired():
{code}
synchronized (service) {
if (stateRef.compareAndSet(was, State.RESTART_REQUIRED, receiver[0], newStamp)) {
service.stateChanged(State.RESTART_REQUIRED);
restartRequired = true;
break;
}
}
{code}
and cleared in revertRestartRequired():
synchronized (service) {
if (state.compareAndSet(State.RESTART_REQUIRED, State.RUNNING, theirStamp,
this.stamp.incrementAndGet())) {
service.stateChanged(State.RUNNING);
restartRequired = false;
}
}
and read in setRunning():
synchronized (service) {
State newRunningState = restartRequired ? State.RESTART_REQUIRED : State.RUNNING;
state.set(newRunningState, stamp.incrementAndGet());
service.stateChanged(newRunningState);
}
All writes and reads to restartRequired are guarded by synchronized (service) so it is
thread safe.
:reload operation clears up the restart-required process-state
--------------------------------------------------------------
Key: AS7-5929
URL:
https://issues.jboss.org/browse/AS7-5929
Project: Application Server 7
Issue Type: Bug
Components: Server
Affects Versions: 7.1.3.Final (EAP)
Reporter: Jeff Mesnil
Assignee: Bartosz Baranowski
For the patching service, the patch command leaves the server in a restart-required
state
{noformat}
[standalone@localhost:9999 /] patch
/home/jmesnil/Developer/jboss-as/build/target/jboss-as-7.2.0.Alpha1-SNAPSHOT/patch.zip
{
"outcome" : "success",
"response-headers" : {
"operation-requires-restart" : true,
"process-state" : "restart-required"
}
}
{noformat}
If I try to change the AS7 configuration, the CLI warns me that a restart is required,
for example:
{noformat}
[standalone@localhost:9999 hornetq-server=default] ./queue=foo:add(queue-address=foo)
{
"outcome" => "success",
"response-headers" => {"process-state" =>
"restart-required"}
}
{noformat}
However, when I reload the server using the /:reload command, the process-state header is
cleared out:
{noformat}
[standalone@localhost:9999 hornetq-server=default] /:reload
{"outcome" => "success"}
[standalone@localhost:9999 hornetq-server=default] ./queue=bar:add(queue-address=bar)
{"outcome" => "success"}
{noformat}
This is not correct: until the server is restarted (not reloaded), the result of my patch
operation will not be taken into account (eg changing the AS7 module path).
Reloading the server should not clear its process-state if it is set to
"restart-required"
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see:
http://www.atlassian.com/software/jira