草庐IT

c++ - Gzip 内存压缩

全部标签

ruby-on-rails - 升级到 OSX Lion 后 ruby​​ 进程内存泄漏

几周前我升级到Lion,它完全被RubyonRails环境搞砸了。我已经安装了RVM,不同的ruby​​版本,但似乎找不到解决方案……我认为这是我升级到Lion所能做的最糟糕的决定之一。它只会给我带来问题。无论如何,我已经意识到渲染我的应用程序页面(它在已部署的服务器上以及在其他机器上本地运行良好)会增加20-30mb的ruby​​进程内存,这有点疯狂。所以你可以想象一下,过了一会儿,我的ruby​​进程使用了​​2gb的内存,我的电脑就不能用了。我见过很多人在升级到Lion时遇到问题,但我一直无法为我的案例找到解决方案。有人遇到过同样的问题吗?我有什么想法可以尝试解决这个问题吗?谢谢

ruby - File.realpath() 是否泄漏内存?

我在使用File.realpath()时遇到问题,留下的字符串似乎没有被垃圾收集。在我看来,这像是内存泄漏,但我无法想象这样的事情对于核心库方法来说真的是真的。考虑以下代码:defstring_test(string)putsstringendGC.startreport=MemoryProfiler.reportdos='./foo.txt'.freezestring_test(s)s=nilGC.startendreport.pretty_print这会产生(以及其他冗长的输出):Totalallocated:0bytes(0objects)Totalretained:0bytes

Ruby 压缩流

我正在尝试编写一个ruby​​fcgi脚本,它可以动态压缩目录中的文件,并将输出作为http响应逐block发送。将此压缩作为流操作完成非常重要,否则客户端将因目录过大而超时。我有以下代码:d="/tmp/delivery/"#sendzipheaderheader(MimeTypes::ZIP)#pseudocodefromhereonIO.open(d){|fh|block=fh.readblock(1024)#sendzippedblockashttpresponseprintzip_it(block)}如何实现我在上面的list中编写的伪ruby?

ruby-on-rails - 无法分配内存

由于某种原因,处理图像(carrierwave+minimagick)在服务启动后大约一周停止工作。流量或上传进程没有异常增加。一旦发生ENOMEM错误,一切似乎都会“锁定”,并且任何后续进程也会失败。一旦系统出现这种行为,我该如何“拯救”它甚至阻止这种情况发生?一些错误:Errno::ENOMEM(Cannotallocatememory-exportLANG=C&&identify-ping/tmp/mini_magick20111219-18047-1dhmawm.jpg2>&1):app/uploaders/photo_uploader.rb:70:in`custom_thum

c - Ruby 的最大函数顺序如何重复?

我一直在看maxmethod在Ruby的Enumerable混合(v2.4.1)。这是一个相当简单的方法,但是当存在重复项时它如何排序项目有点令人困惑。例如:x=[1,2,3,4,5,6,7,8,9]x.max{|a,b|a%2b%2}=>110.times{|y|px.max(y){|a,b|a%2b%2}}[][1][1,7]#whyis7thenextelementafter1?[3,1,5]#whynomore7?[7,3,1,5]#7isnowfirst[9,7,3,1,5][9,7,3,1,5,6][9,7,3,1,5,4,6][9,7,3,1,5,2,4,6][9,7,5

ruby - 测试内存

我有一个名为calculate_total的昂贵方法。我需要一个名为total的方法,它将返回calculate_total的结果。对total的后续调用应返回calculate_total的先前结果。我想以测试驱动的方式来做这件事。这是我的测试(我使用的是RSpec):describeItemdodescribe"total"dobeforedo@item=Item.new@item.stub!(:calculate_total=>123)endit"returnsthecalculatedtotal"do@item.total.should==123endit"subsequent

Ruby 等同于 C#'s ' yield' 关键字,或者,在不预分配内存的情况下创建序列

在C#中,您可以这样做:publicIEnumerableGetItems(){for(inti=0;i这将返回一个包含1000万个整数的可枚举序列,而无需在该长度的内存中分配一个集合。有没有一种方法可以在Ruby中做同样的事情?我要处理的具体示例是将矩形数组展平为要枚举的值序列。返回值不必是Array或Set,而是某种只能按顺序而不是索引迭代/枚举的序列。因此,整个序列不需要同时分配到内存中。在.NET中,这是IEnumerable和IEnumerable.对Ruby世界中此处使用的术语的任何澄清都会有所帮助,因为我更熟悉.NET术语。编辑也许我最初的问题还不够清楚——我认为yiel

ruby - 从 Rails 3.0 升级到 Rails 3.2(Ruby 1.9.3 + Passenger)后出现巨大的内存泄漏/膨胀

上周我们将一个在Rails3.0.1上运行的小项目升级到了Rails3.2.2。升级后不久,我们发现偶尔,一天2-3次,我们会看到一个巨大的PhusionPassenger进程(1-5GB)。我们正在运行PhusionPassenger3.0.11和Ruby1.9.3-p0。我们已经尝试了不同的Ruby版本(1.9.2-p290和1.9.3-p125)但没有成功。之后,我们尝试使用Oink来跟踪我们的内存使用情况.不幸的是,Oink没有显示内存膨胀的原因——大型进程似乎不再写入日志文件。当我们降级回Rails3.0.1时,问题就消失了。有没有人有类似的问题?我们确实检查了我们的代码是否

ruby - 如何查找 ruby​​ 对象使用的内存?

ruby中有没有找到ruby对象使用的内存的函数。类似于C有sizeof()函数,PHP有memory_get_usage()函数。ruby是否具有等效的功能/方法? 最佳答案 ObjetSpace#memsize_offromtheRubydocs:Returnconsumingmemorysizeofobj.[1]pry(main)>require'objspace'=>true[2]pry(main)>ObjectSpace.memsize_of('')=>40[3]pry(main)>ObjectSpace.memsize_

ruby - 我应该如何避免内存导致 Ruby 中的错误?

是否已就如何避免因可变状态导致的记忆化错误达成共识?在此示例中,缓存结果的状态发生了变化,因此在第二次调用时给出了错误的结果。classGreeterdefinitialize@greeting_cache={}enddefexpensive_greeting_calculation(formality)caseformalitywhen:casualthen"Hi"when:formalthen"Hello"endenddefgreeting(formality)unless@greeting_cache.has_key?(formality)@greeting_cache[form