<br><br><div class="gmail_quote">On Thu, Aug 23, 2012 at 2:04 PM, Clint Byrum <span dir="ltr"><<a href="mailto:clint@ubuntu.com" target="_blank">clint@ubuntu.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Excerpts from Johannes Wettinger's message of 2012-08-23 08:56:48 -0700:<br>
<div class="im">> Hi Gustavo,<br>
><br>
> thanks for your reply.<br>
><br>
> On Thu, Aug 23, 2012 at 10:30 AM, Gustavo Niemeyer<br>
> <<a href="mailto:gustavo.niemeyer@canonical.com">gustavo.niemeyer@canonical.com</a>> wrote:<br>
> >> I'm currently doing some research and prototype implementation in the<br>
> >> field of Cloud standards. In particular, my work is strongly related<br>
> >> to an upcoming standard called "Topology and Orchestration<br>
> >> Specification for Cloud Applications" (TOSCA):<br>
> >> <a href="http://www.tosca-open.org" target="_blank">http://www.tosca-open.org</a><br>
> ><br>
> > Nice, thanks for reaching out. What's your involvement there, out of curiosity?<br>
><br>
> Currently, I'm doing my Master's thesis. The topic of my thesis is<br>
> about integrating DevOps methodologies into model-driven Cloud<br>
> management. TOSCA defines itself as being a means to enable<br>
> model-driven management of Cloud application whereas Juju is more<br>
> focused on the concerns of the DevOps movement. So, TOSCA and Juju<br>
> have a different background, but in the end they own similar meta<br>
> models. This is why I think integrating the two of them could make<br>
> sense.<br>
><br>
<br>
</div>You're seeking to bring a development methodology (modeling) to<br>
operations. Seeing as DevOps is a movement to bring development and<br>
operations closer, it would seem that you could also say "TOSCA is<br>
<div class="im">focused on the concerns of the DevOps movement".<br>
<br>
</div><div class="im">> >> Of course, TOSCA is much more complex<br>
> >> because of its highly generic approach to describe service models.<br>
> >> Just wondering if anyone here is familiar with TOSCA, too?<br>
> ><br>
> > I'd argue that the complexity doesn't come from the generality.<br>
><br>
> What do you think is the reason for the complexity of TOSCA's meta<br>
> model? As an example, let's take a look at the structure of node<br>
> types:<br>
><br>
> - NodeType "MySQL"<br>
> - Interface "Lifecycle"<br>
> - Operation "install"<br>
> - ImplementationArtifact (type = "ScriptArtifact for Windows")<br>
> - ImplementationArtifact (type = "ScriptArtifact for Linux")<br>
> - Operation "configure"<br>
> - Operation ...<br>
> - Interface "Maintenance"<br>
> - Operation "backup-database"<br>
> - ...<br>
><br>
> First, there can be several implementation artifacts assigned to a<br>
> single operation, e.g. offering installation scripts for Windows,<br>
> Linux, etc. This makes a node type portable. How would you implement<br>
> this in Juju? You may have to implement two separate charms such as<br>
> "mysql-server-windows" and "mysql-server-linux", right? Thus, the<br>
> portability of a single charm is quite limited or did I miss<br>
> something?<br>
><br>
<br>
</div>Charms are tied to a "series". Each series is developed and<br>
tested together as a whole to ensure that the various charms work<br>
together. Currently we are targetting releases of Ubuntu with each<br>
series of charms because we have not been presented with a compelling<br>
reason to do otherwise. (actually I haven't even been presented with<br>
any non-compelling reasons. I'm sure users are interested, but nobody<br>
is campaigning for other platforms.)<br>
<br>
However, there is no reason we could not create a "portable" series of<br>
juju charms which do offer conditional logic based on platform. Because<br>
charms are only declarative at a very high level, they are quite flexible.<br>
<div class="im"><br>
> Second, you can define arbitrary interfaces and operations in a node<br>
> type beside the default lifecycle operations (install, start, stop,<br>
> etc.). Hooks in Juju are basically limited to those lifecycle<br>
> operations. But what if you would like to implement maintenance<br>
> operations such as doing a backup of the database?<br>
><br>
<br>
</div><a href="https://bugs.launchpad.net/juju/+bug/809070" target="_blank">https://bugs.launchpad.net/juju/+bug/809070</a><br>
<br>
It has been on the list for a while. There is a simple workaround which<br>
is to do arbitrary operations in the config-changed hook.<br></blockquote><div><br></div><div><br></div><div>Some of this is possible already in a more adhoc fashion, via juju ssh unit command. I've seen a few charms use this already to expose additional service specific commands. Its definitely an open area for more development imo to orchestra this execution (round robin, parallel, etc) and make it accessible more readily from the core.</div>
<div><br></div><div>cheers,</div><div>Kapil</div></div>