<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div>Yeah feels like we are <a href="http://apache.org">apache.org</a>&nbsp;</div><div><br></div><div>+1<br><br><br><div><br></div></div><div><br>Am 02.07.2015 um 11:33 schrieb Tomaž Cerar &lt;<a href="mailto:tomaz.cerar@gmail.com">tomaz.cerar@gmail.com</a>&gt;:<br><br></div><blockquote type="cite"><div><div dir="ltr">So if we are doing +1s, then <br>+1 <br><br>:)<br></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jul 2, 2015 at 9:49 AM, Kabir Khan <span dir="ltr">&lt;<a href="mailto:kabir.khan@jboss.com" target="_blank">kabir.khan@jboss.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Me too<br>
<div class="HOEnZb"><div class="h5">&gt; On 1 Jul 2015, at 20:03, Jason Greene &lt;<a href="mailto:jason.greene@redhat.com">jason.greene@redhat.com</a>&gt; wrote:<br>
&gt;<br>
&gt; I completely agree.<br>
&gt;<br>
&gt;&gt; On Jul 1, 2015, at 11:43 AM, Brian Stansberry &lt;<a href="mailto:brian.stansberry@redhat.com">brian.stansberry@redhat.com</a>&gt; wrote:<br>
&gt;&gt;<br>
&gt;&gt; tl;dr;<br>
&gt;&gt;<br>
&gt;&gt; When an operation that has changed the management model is rolling back,<br>
&gt;&gt; the OperationStepHandlers processing the rollback see the model as it<br>
&gt;&gt; was at the arbitrary point when the rollback began. I propose changing<br>
&gt;&gt; this so they see things as they were prior to the first change to the model.<br>
&gt;&gt;<br>
&gt;&gt; Long version:<br>
&gt;&gt;<br>
&gt;&gt; When an operation mutates either the management Resource tree, or the<br>
&gt;&gt; registry of capabilities (together known as the management model), we<br>
&gt;&gt; clone the management model and thereafter that operation works on the<br>
&gt;&gt; clone. The clone is invisible to other callers until the operations<br>
&gt;&gt; successfully commits. When the operation commits, it publishes the clone<br>
&gt;&gt; and that becomes the official model.<br>
&gt;&gt;<br>
&gt;&gt; I call this copy-on-write, publish-on-commit.<br>
&gt;&gt;<br>
&gt;&gt; If the operation rolls back, the changed model is never published and<br>
&gt;&gt; the clone is just discarded when the operation execution returns.<br>
&gt;&gt;<br>
&gt;&gt; However, while the operation is rolling back, all the<br>
&gt;&gt; OperationStepHandlers that are processing the rollback see the modified<br>
&gt;&gt; clone, not the original model. They are seeing arbitrarily incorrect data.<br>
&gt;&gt;<br>
&gt;&gt; This hasn't been a problem up to now, as our standard OSHs get a copy of<br>
&gt;&gt; whatever part of the Resource tree they are going to modify and keep it<br>
&gt;&gt; for use in rollback. They don't need to re-read the management model to<br>
&gt;&gt; perform rollback.<br>
&gt;&gt;<br>
&gt;&gt; But this doesn't work for the capability registry. If an OSH removes a<br>
&gt;&gt; capability and removes a service, and then in rollback tries to use the<br>
&gt;&gt; capability to figure out how to restore the service, it fails, as<br>
&gt;&gt; management model it can see still shows the capability as being removed.<br>
&gt;&gt;<br>
&gt;&gt; To fix this, I propose discarding the cloned management model as soon as<br>
&gt;&gt; rollback begins. Thereafter, an OSH processing rollback will see the<br>
&gt;&gt; model as it was before the first modification. The removed capability<br>
&gt;&gt; will still be present.<br>
&gt;&gt;<br>
&gt;&gt; I have a commit that does this at [1]. Running the testsuite with it<br>
&gt;&gt; shows no regressions. This doesn't surprise me, as our standard OSHs up<br>
&gt;&gt; to now have had no need to re-read the model during rollback.<br>
&gt;&gt;<br>
&gt;&gt; [1]<br>
&gt;&gt; <a href="https://github.com/bstansberry/wildfly-core/commit/419f350931d5b7e345cf9aa514de08c01bf976be" rel="noreferrer" target="_blank">https://github.com/bstansberry/wildfly-core/commit/419f350931d5b7e345cf9aa514de08c01bf976be</a><br>
&gt;&gt;<br>
&gt;&gt; --<br>
&gt;&gt; Brian Stansberry<br>
&gt;&gt; Senior Principal Software Engineer<br>
&gt;&gt; JBoss by Red Hat<br>
&gt;&gt; _______________________________________________<br>
&gt;&gt; wildfly-dev mailing list<br>
&gt;&gt; <a href="mailto:wildfly-dev@lists.jboss.org">wildfly-dev@lists.jboss.org</a><br>
&gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/wildfly-dev" rel="noreferrer" target="_blank">https://lists.jboss.org/mailman/listinfo/wildfly-dev</a><br>
&gt;<br>
&gt; --<br>
&gt; Jason T. Greene<br>
&gt; WildFly Lead / JBoss EAP Platform Architect<br>
&gt; JBoss, a division of Red Hat<br>
&gt;<br>
&gt;<br>
&gt; _______________________________________________<br>
&gt; wildfly-dev mailing list<br>
&gt; <a href="mailto:wildfly-dev@lists.jboss.org">wildfly-dev@lists.jboss.org</a><br>
&gt; <a href="https://lists.jboss.org/mailman/listinfo/wildfly-dev" rel="noreferrer" target="_blank">https://lists.jboss.org/mailman/listinfo/wildfly-dev</a><br>
<br>
<br>
_______________________________________________<br>
wildfly-dev mailing list<br>
<a href="mailto:wildfly-dev@lists.jboss.org">wildfly-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/wildfly-dev" rel="noreferrer" target="_blank">https://lists.jboss.org/mailman/listinfo/wildfly-dev</a><br>
</div></div></blockquote></div><br></div>
</div></blockquote><blockquote type="cite"><div><span>_______________________________________________</span><br><span>wildfly-dev mailing list</span><br><span><a href="mailto:wildfly-dev@lists.jboss.org">wildfly-dev@lists.jboss.org</a></span><br><span><a href="https://lists.jboss.org/mailman/listinfo/wildfly-dev">https://lists.jboss.org/mailman/listinfo/wildfly-dev</a></span></div></blockquote></body></html>