<div dir="ltr"><br><div class="gmail_extra"><div class="gmail_quote">On Mon, Oct 28, 2013 at 5:46 PM, Qing He <span dir="ltr"><<a href="mailto:Qing.He@radisys.com" target="_blank">Qing.He@radisys.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">In my hard drive-less use case, I need an in-core-db/cache that can be in the same db cluster with real db (with hard drive) with the same sql api so that the current openstack code do not need to be changed, instead, just a pluggin with some configurations.<br>
</blockquote><div><br></div><div>This is pretty much the original use case that dogpile.cache grew out of, see:</div><div><br></div><div>  <a href="http://docs.sqlalchemy.org/en/rel_0_9/orm/examples.html#dogpile-caching">http://docs.sqlalchemy.org/en/rel_0_9/orm/examples.html#dogpile-caching</a></div>
<div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div class="im"><br>
-----Original Message-----<br>
From: Morgan Fainberg [mailto:<a href="mailto:m@metacloud.com">m@metacloud.com</a>]<br>
Sent: Monday, October 28, 2013 10:22 AM<br>
To: OpenStack Development Mailing List (not for usage questions)<br>
Subject: Re: [openstack-dev] distibuted caching system in front of mysql server for openstack transactions<br>
<br>
</div><div class=""><div class="h5">In light of what Dolph said with regards to Keystone, we are using dogpile.cache to implement memoization in front of our driver calls.<br>
It it has the ability to cache directly as well, but it has been effective (so far) for our use-case.<br>
<br>
That being said, I am unsure if caching in front of MySQL is really what we want.  I believe that we should be caching after processing work (hence memoization mechanism) instead of at the SQL layer.  This also means we can be measured in what we cache (oh hey, it makes no sense to cache X because it needs to be "real time" or there isn't a performance issue with that query / call, but Y does a ton of processing and is an expensive join/temptable query).  In my experience, unless the whole application is designed with caching in mind, caching something as broad as MySQL calls (or any SQL store) is likely going to net exactly what Shawn Hartsock stated, adding a second performance issue.<br>

<br>
--Morgan<br>
<br>
On Mon, Oct 28, 2013 at 10:05 AM, Shawn Hartsock <<a href="mailto:hartsocks@vmware.com">hartsocks@vmware.com</a>> wrote:<br>
>><br>
>> I once heard a quote.. "I had a performance problem, so I added caching.<br>
>> now I have two performance problems."<br>
>><br>
> this. 1,000 times this.<br>
><br>
> Just to float this thought ... make sure it's considered...<br>
><br>
> I've seen a *lot* of people misuse caching when what the really want is memoization.<br>
><br>
> *<br>
> <a href="http://stackoverflow.com/questions/1988804/what-is-memoization-and-how" target="_blank">http://stackoverflow.com/questions/1988804/what-is-memoization-and-how</a><br>
> -can-i-use-it-in-python<br>
> *<br>
> <a href="http://stackoverflow.com/questions/10879137/how-can-i-memoize-a-class-" target="_blank">http://stackoverflow.com/questions/10879137/how-can-i-memoize-a-class-</a><br>
> instantiation-in-python<br>
><br>
> ... I'm not sure what you're trying to do. So YMMV, TTFN, BBQ.<br>
><br>
> # Shawn Hartsock<br>
><br>
> ----- Original Message -----<br>
>> From: "Clint Byrum" <<a href="mailto:clint@fewbar.com">clint@fewbar.com</a>><br>
>> To: "openstack-dev" <<a href="mailto:openstack-dev@lists.openstack.org">openstack-dev@lists.openstack.org</a>><br>
>> Sent: Monday, October 28, 2013 12:12:49 PM<br>
>> Subject: Re: [openstack-dev] distibuted caching system in front of mysql      server for openstack transactions<br>
>><br>
>> Excerpts from Dolph Mathews's message of 2013-10-28 08:40:19 -0700:<br>
>> > It's not specific to mysql (or sql at all), but keystone is using<br>
>> > dogpile.cache around driver calls to a similar effect.<br>
>> ><br>
>> >   <a href="http://dogpilecache.readthedocs.org/en/latest/" target="_blank">http://dogpilecache.readthedocs.org/en/latest/</a><br>
>> ><br>
>> > It can persist to memcache, redis, etc.<br>
>> ><br>
>><br>
>> I once heard a quote.. "I had a performance problem, so I added caching.<br>
>> now I have two performance problems."<br>
>><br>
>> Caching is unbelievably awesome in the jobs it can do well. When the<br>
>> problem is straight forward and the requirements are few, it is just<br>
>> the right thing to relieve engineering pressure to make an<br>
>> application more scalable.<br>
>><br>
>> However, IMO, more than narrow, well defined cache usage is a sign<br>
>> that the application needs some reworking to scale.<br>
>><br>
>> I like the principle of "let's use dogpile so we don't have to<br>
>> reinvent multi-level caching". However, let's make sure we look at<br>
>> each performance issue individually, rather than just throwing them<br>
>> all in a cache box and waving the memcache wand.<br>
>><br>
>> ><br>
>> > <a href="https://github.com/openstack/keystone/blob/master/keystone/common/c" target="_blank">https://github.com/openstack/keystone/blob/master/keystone/common/c</a><br>
>> > ache/core.py<br>
>> ><br>
>> > On Fri, Oct 25, 2013 at 6:53 PM, Qing He <<a href="mailto:Qing.He@radisys.com">Qing.He@radisys.com</a>> wrote:<br>
>> ><br>
>> > >  All,****<br>
>> > ><br>
>> > > Has anyone looked at the options of putting a distributed caching<br>
>> > > system in front of mysql server to improve performance? This<br>
>> > > should be similar to Oracle Coherence, or VMware VFabric<br>
>> > > SQLFire.****<br>
>> > ><br>
>> > > ** **<br>
>> > ><br>
>> > > Thanks,****<br>
>> > ><br>
>> > > ** **<br>
>> > ><br>
>> > > Qing****<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>
>><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>
<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>
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><br clear="all"><div><br></div>-- <br><div><br></div>-Dolph
</div></div>