繁体   English   中英

NHibernate - Memcached性能不佳

[英]NHibernate - Poor performance with Memcached

我安装了Membase并创建了一个新的memcached存储桶。 在设置中,为了简单起见,我选择设置端口ID为1111的专用端口。

在我的web.config中我有这个:

<configSections>
  <section name="memcache" type="NHibernate.Caches.MemCache.MemCacheSectionHandler, NHibernate.Caches.MemCache" requirePermission="false" />
  ...
</configSections>

<memcache>
  <memcached host="127.0.0.1" port="1111" />
</memcache>

在我的NHibernate配置部分:

<property name="cache.use_query_cache" >true</property>
<property name="cache.use_second_level_cache">true</property>
<property name="cache.provider_class">NHibernate.Caches.MemCache.MemCacheProvider, NHibernate.Caches.MemCache</property>

在我的每个NHibernate类映射中,我都在class标签的右上角:

<cache usage="nonstrict-read-write" />

当我运行它时,我的查询比使用Syscache时要慢一个数量级。 有什么看起来不对吗? 我设置这样的东西还是比较新的。

在此先感谢您的任何帮助。

您的配置似乎没有任何明显的问题。 Syscache正在使用ASP.NET缓存提供程序,并且您的应用程序和缓存之间没有网络通信,但理论上它应该比在localhost上运行的memcached快一点(假设您有足够的内存来避免交换)。

您可能想尝试使用分析器运行您的应用程序,以查看实际花费的时间。 此外,您应该确保memcached实际上用于返回缓存的查询并且不发出sql查询 - 记录sql并期望仅在第一次执行查询时才能看到它。

我使用Membase的一个memcached的水桶enyim memcached的客户端 ,类似于你这样的配置,我很高兴与性能。 membase还提供一个很好的管理控制台,您可以在其中查看有关缓存使用情况的各种有用统计信

此外,与您的问题无关,但请确保您在启用它之前了解查询缓存的工作原理。 请参阅ayende的这两篇 帖子

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM