jjzjj

ruby - 如何在 Ruby 中从内存中 HTTP 发布流数据?

我想上传我在运行时用Ruby生成的数据,就像从block中提供上传数据一样。我找到的所有示例仅展示了如何流式传输必须在请求之前位于磁盘上的文件,但我不想缓冲该文件。除了滚动我自己的套接字连接之外,最好的解决方案是什么?这是一个伪代码示例:post_stream('127.0.0.1','/stream/')do|body|generate_xmldo|segment|body 最佳答案 有效的代码。require'thread'require'net/http'require'base64'require'openssl'class

ruby - JSON的基于流的解析和写入

我分1,000个批处理从服务器获取大约20,000个数据集。每个数据集都是一个JSON对象。坚持这会产生大约350MB的未压缩明文。我的内存限制为1GB。因此,我以追加模式将每1,000个JSON对象作为一个数组写入到一个原始JSON文件中。结果是一个包含20个需要聚合的JSON数组的文件。无论如何我都需要触摸它们,因为我想添加元数据。一般RubyYajlParser使这成为可能:raw_file=File.new(path_to_raw_file,'r')json_file=File.new(path_to_json_file,'w')datasets=[]parser=Yajl::

ruby - Ruby中子进程的流输出

我希望能够在Ruby中流式传输子进程的输出例如p`pinggoogle.com`我想立即看到ping响应;我不想等待流程完成。 最佳答案 您可以执行以下操作而不是使用反引号:IO.popen('pinggoogle.com')do|io|io.each{|s|prints}end干杯! 关于ruby-Ruby中子进程的流输出,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8732

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 - 监控 RTMP 流,如果可用则记录

我正在寻找一种方法来监视流上的事件,以便我可以确定是否有任何内容通过流。如果有,我将开始使用rtmpdump进行录制。我想象这是通过运行一个每60秒检查一次流的cron任务来实现的。如果它确定流正在通过,则调用rtmpdump开始记录它。如果没有,则什么都不做,并在60秒后再次检查。由于rtmpdump只是在没有流数据时出现错误,因此尝试使用它来监视流似乎不是一个好主意,但也许我错了。如果我在逐个案例的基础上手动执行此操作会很容易,但我正在尝试自动执行自动录制流的任务(如果它们可用)。有没有人遇到过这样做的方法?也许我可以在命令行(linux)中使用其他一些工具?如果有帮助,我正在使用

ruby-on-rails - Ruby 1.9.1-p234、Passenger 2.2.5、Rails 2.3-stable 在 POST 请求时关闭流

我已经在Ubuntu服务器上安装了Ruby1.9.1(p234)。我正在尝试在Apache2.2/Passenger2.2.5上部署一个供应商Rails2.3-stable的Rails应用程序。GET请求工作正常,POST请求立即中断并显示以下日志条目:ProcessingUsersController#new(for80.203.77.44at2009-10-2420:54:55)[GET]Parameters:{"controller"=>"users","action"=>"new"}Renderingtemplatewithinlayouts/applicationRender

ruby - Ruby 中的内存流?

ruby是否有我遗漏的内存流?看起来IO仅适用于文件支持的流...我希望在.NET中使用类似于System.IO.MemoryStream的东西? 最佳答案 你在寻找像StringIO这样的东西吗?? 关于ruby-Ruby中的内存流?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/5931263/

ruby - 用 Prawn 控制内容流

假设我们要在占据页面上半部分的第一页上显示一个标题。页面的下半部分应该填满我们的文章文本,文本应该继续流入后续页面直到用完:这是一个非常基本的布局场景,但我不明白如何在Prawn中实现它。这是从他们的在线文档中派生的一些示例代码:pdf=Prawn::Document.newdotext"ThePrince",:align=>:center,:size=>48text"NiccolòMachiavelli",:align=>:center,:size=>20move_down42column_box([0,cursor],:columns=>3,:width=>bounds.width

ruby-on-rails - Rails 如何解析文本/事件流?

我有一个APIurl,它是内容类型为数据流的:text/event-stream。怎么可能收听流?喜欢订阅每个事件来打印数据?我尝试使用ruby​​库em-eventsource我的test.rb文件:require"em-eventsource"EM.rundosource=EventMachine::EventSource.new("my_api_url_goes_here")source.messagedo|message|puts"newmessage#{message}"endsource.startend当我访问我的apiurl时,我可以看到每秒更新的数据。但是当我在终端中

ruby - 从本地文件或 url 打开 IO 流

我知道有其他语言的库可以接受包含本地文件路径或url的字符串,并将其作为可读IO流打开。在ruby​​中有没有简单的方法来做到这一点? 最佳答案 open-uri是标准Ruby库的一部分,它将重新定义open的行为,以便您可以打开url以及本地文件。它返回一个File对象,因此您应该能够调用read和readlines等方法。require'open-uri'file_contents=open('local-file.txt'){|f|f.read}web_contents=open('http://www.stackoverfl