我正在使用一个监控系统,该系统每隔几个小时就会报告有很多低内存修剪
2013 年 12 月 5 日星期四 01:21:52 UTC 7347 查询缓存 lowmem 修剪在 600 秒内(12.24/秒)
2013 年 12 月 5 日星期四 10:21:52 UTC 600 秒内 10596 次查询缓存 lowmem 修剪(17.66/秒)
2013 年 12 月 5 日星期四 11:26:52 UTC 600 秒内 8979 次查询缓存 lowmem 修剪(14.96/秒)
mysql> SHOW STATUS LIKE 'Qc%';
Variable_name Value
Qcache_free_blocks 2250
Qcache_free_memory 6938840
Qcache_hits 578811080
Qcache_inserts 331501709
Qcache_lowmem_prunes 124066063
Qcache_not_cached 135977294
Qcache_queries_in_cache 5638
Qcache_total_blocks 13625
我的 16MB 查询缓存中大约有 6MB 没有被使用
mysql> SHOW VARIABLES LIKE 'query_cache_size';
+------------------+----------+
| Variable_name | Value |
+------------------+----------+
| query_cache_size | 16777216 |
+------------------+----------+
1 row in set (0.00 sec)
为什么在没有填满缓存的情况下修剪查询?
我应该增加还是减少缓存大小?
附加信息
mysql> FLUSH STATUS;
30分钟后
mysql> SHOW STATUS LIKE '%Qcache%';
+-------------------------+---------+
| Variable_name | Value |
+-------------------------+---------+
| Qcache_free_blocks | 1935 |
| Qcache_free_memory | 5154904 |
| Qcache_hits | 43918 |
| Qcache_inserts | 33074 |
| Qcache_lowmem_prunes | 4443 |
| Qcache_not_cached | 10438 |
| Qcache_queries_in_cache | 6276 |
| Qcache_total_blocks | 14713 |
+-------------------------+---------+
8 rows in set (0.00 sec)
最佳答案
当任何 INSERT/UPDATE/DELETE 语句修改关联表中的数据时,查询缓存会使条目过期。这不会等待缓存填满。
http://dev.mysql.com/doc/refman/5.6/en/query-cache-operation.html说:
If a table changes, all cached queries that use the table become invalid and are removed from the cache. This includes queries that use MERGE tables that map to the changed table. A table can be changed by many types of statements, such as INSERT, UPDATE, DELETE, TRUNCATE TABLE, ALTER TABLE, DROP TABLE, or DROP DATABASE.
关于你的问题:
If using InnoDB and the insertion is at the end of a table, does the query cache expire entries?
是的,没错。例如,查询缓存条目与查询 SELECT COUNT(*) FROM mytable 相关联。插入到 mytable 的末尾将使该查询的缓存结果无效。
查询缓存在决定给定的数据更改是否影响缓存条目方面没有太多智能。它假定如果您更改表中的任何内容,则必须丢弃缓存中以任何方式与该表关联的所有查询。
只有当缓存的结果在插入后发生变化时,它才能应用更多的智能来丢弃某些查询结果。但它会怎么做呢?它必须在插入后再次运行查询,将结果与存储在缓存中的结果进行比较。如果不同,则替换缓存中的结果。
但它必须对缓存中的每个 查询结果执行此操作。请注意,您的状态输出显示您的查询缓存中有 5638 个查询。当然,并非所有这些都与您要插入的同一个表相关联,但我们可以假设其中有许多是。
单个 INSERT 导致重新执行数百或数千个 SELECT 语句以刷新其缓存结果并不是一个好的权衡。
因此折衷方案是对表的更改会清除与该表关联的所有缓存结果,即使这不是绝对必要的。
因此,查询缓存并不是一种非常精确的缓存查询的方法。它对某些工作负载很有帮助,例如,如果您的应用程序倾向于多次重复给定的查询,而表没有收到任何更改。但是we已经看到许多情况下,工作负载使查询缓存没有帮助,在某些情况下,维护查询缓存的开销实际上会损害性能。
如果你想要一些更精确的缓存机制,你必须在你的应用程序中自己编写代码,将某些结果保存到 memcached 或类似的快速内存缓存中。然后,您有责任在数据更改时跟踪哪些条目需要刷新。
关于mysql - 为什么我会收到 lowmen prunes 的通知,即使一半的查询缓存没有被使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20407242/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h