<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Aug 1, 2013 at 8:52 PM, Sandy Walsh <span dir="ltr"><<a href="mailto:sandy.walsh@rackspace.com" target="_blank">sandy.walsh@rackspace.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im"><br>
<br>
On 08/01/2013 07:22 PM, Doug Hellmann wrote:<br>
><br>
><br>
><br>
> On Thu, Aug 1, 2013 at 10:31 AM, Sandy Walsh <<a href="mailto:sandy.walsh@rackspace.com">sandy.walsh@rackspace.com</a><br>
</div><div class="im">> <mailto:<a href="mailto:sandy.walsh@rackspace.com">sandy.walsh@rackspace.com</a>>> wrote:<br>
><br>
> Hey y'all,<br>
><br>
> I've had a little thorn in my claw on this topic for a while and thought<br>
> I'd ask the larger group.<br>
><br>
> I applaud the efforts of the people working on the alarming additions to<br>
> Ceilometer, but I've got concerns that we're packaging things the<br>
> wrong way.<br>
><br>
> I fear we're making another Zenoss/Nagios with Ceilometer. It's trying<br>
> to do too much.<br>
><br>
> The current trend in the monitoring work (#monitoringlove) is to build<br>
> your own stack from a series of components. These components take in<br>
> inputs, process them and spit out outputs.<br>
> Collectors/Transformers/Publishers. This is the model CM is built on.<br>
><br>
> Making an all-singing-all-dancing monolithic monitoring package is the<br>
> old way of building these tools. People want to use best-of-breed<br>
> components for their monitoring stack. I'd like to be able to use<br>
</div>> <a href="http://reimann.io" target="_blank">reimann.io</a> <<a href="http://reimann.io" target="_blank">http://reimann.io</a>> for my stream manager, diamond for my<br>
<div><div class="h5">> collector, logstash for<br>
> my parser, etc. Alarming should just be another consumer.<br>
><br>
> CM should do one thing well. Collect data from openstack, store and<br>
> process them, and make them available to other systems via the API or<br>
> publishers. That's all. It should understand these events better than<br>
> any other product out there. It should be able to produce meaningful<br>
> metrics/meters from these events.<br>
><br>
> Alarming should be yet another consumer of the data CM produces. Done<br>
> right, the If-This-Then-That nature of the alarming tool could be<br>
> re-used by the orchestration team or perhaps even scheduling.<br>
> Intertwining it with CM is making the whole thing too complex and rigid<br>
> (imho).<br>
><br>
> CM should be focused on extending our publishers and input plug-ins.<br>
><br>
> I'd like to propose that alarming becomes its own project outside of<br>
> Ceilometer. Or, at the very least, its own package, external of the<br>
> Ceilometer code base. Perhaps it still lives under the CM moniker, but<br>
> packaging-wise, I think it should live as a separate code base.<br>
><br>
><br>
> It is currently implemented as a pair of daemons (one to monitor the<br>
> alarm state, another to send the notifications). Both daemons use a<br>
> ceilometer client to talk to the REST API to consume the sample data or<br>
> get the alarm details, as required. It looks like alarms are triggered<br>
> by sending RPC cast message, and that those in turn trigger the webhook<br>
> invocation. That seems pretty loosely coupled, as far as the runtime<br>
> goes. Granted, it's still in the main ceilometer code tree, but that<br>
> doesn't say anything about how the distros will package it.<br>
><br>
> I'll admit I haven't been closely involved in the development of this<br>
> feature, so maybe my quick review of the code missed something that is<br>
> bringing on this sentiment?<br>
<br>
</div></div>No, you hit the nail on the head. It's nothing with the implementation,<br>
it's purely with the packaging and having it co-exist within ceilometer.<br>
Since it has its own services, uses Oslo, the CM client and operates via<br>
the public API, it should be able to live outside the main CM codebase.<br>
My concern is that it has a different mandate than CM (or the CM mandate<br>
is too broad).<br>
<br>
What really brought it on for me was doing code reviews for CM and<br>
hitting all this alarm stuff and thinking "this is mental context switch<br>
from what CM does, it really doesn't belong here." (though I'm happy to<br>
help out with the reviews)<br></blockquote><div><br></div><div>OK. I think we went back and forth for a while on where to put it, but at the time I think we really only discussed Heat and Ceilometer as options. (Eoghan or Angus, please correct me if I'm remembering those discussions incorrectly.) Now that we have "programs" instead of "projects" maybe it's more clear that a separate repository would be possible, although from a pragmatic standpoint leaving it where it is for the rest of this dev cycle seems reasonable.</div>
<div><br></div><div>Perhaps this is something to discuss at the summit?</div><div><br></div><div>Doug</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
-S<br>
<div class="im"><br>
<br>
><br>
> Doug<br>
><br>
><br>
><br>
> Please, change my view. :)<br>
><br>
> -S<br>
><br>
> Side note: I might even argue that the statistical features of CM are<br>
> going a little too far. My only counter-argument is that statistics are<br>
> the only way to prevent us from sending large amounts of data over the<br>
> wire for post-processing. But that's a separate discussion.<br>
><br>
><br>
> _______________________________________________<br>
> OpenStack-dev mailing list<br>
> <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
</div>> <mailto:<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a>><br>
> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<div class="HOEnZb"><div class="h5">><br>
><br>
><br>
><br>
> _______________________________________________<br>
> OpenStack-dev mailing list<br>
> <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
><br>
<br>
_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</div></div></blockquote></div><br></div></div>