- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我一直在四处寻找,似乎无法为此找到好的解决方案。我的 Rails 应用程序将其文件存储在 Amazon S3 中。我现在需要将它们发送到远程(第 3 方)服务。
我正在使用 RestClient 像这样发布到第 3 方服务器:
send_file = RestClient::Request.execute(
:method => :post,
:url => "http://remote-server-url.com",
:payload => File.new("some_local_file.avi", 'rb'),
:multipart => true,
etc.... )
它适用于本地文件,但我如何才能将远程文件从 S3 直接发送到此第 3 方服务?
我在这里找到了有人使用 open-uri 的答案:ruby reading files from S3 with open-URI
我自己测试过,它有效。
:payload => open(URI.parse("http://amazon-s3-example.com/some_file.avi"))
但是,我在这里读到一条评论说 open-uri 只是将远程文件加载到内存中。请参阅对此答案的最后评论:https://stackoverflow.com/a/264239/2785592
这不太理想,因为我正在处理可能很大的视频文件。我还在某处读到 RestClient 甚至将本地文件加载到内存中;同样,这并不理想。有谁知道这是不是真的?
当然,我不可能是唯一遇到此问题的人。我知道我可以在发送之前在本地下载 S3 文件,但我希望节省时间和带宽。此外,如果 RestClient 真的 确实 甚至将本地文件加载到内存中,那么在本地下载它并不能为我节省任何东西。呵呵。
如有任何建议,我们将不胜感激。谢谢:)
更新:远程服务器只是一个响应发布请求的 API。我没有能力改变他们的任何事情。
最佳答案
看看: https://github.com/rest-client/rest-client/blob/master/lib/restclient/payload.rb
RestClient 绝对支持流式上传。条件是在 payload 中你传递的东西不是字符串或散列,并且你传递的东西响应读取和大小。 (所以基本上是一个流)。
在 S3 端,您基本上需要抓取一个流,而不是在发送之前读取整个对象。您使用 http://docs.aws.amazon.com/sdkforruby/api/Aws/S3/Client.html#get_object-instance_method你说你想在响应目标中获得一个 IO 对象(不是字符串)。为此,您可以使用 IO.pipe
reader, writer = IO.pipe
fork do
reader.close
s3.get_object(bucket: 'bucket-name', key: 'object-key') do |chunk|
writer.write(chunk)
end
end
writer.close
您将读取器传递给 RestClient::Payload.generate 并将其用作您的负载。如果阅读部分比写作部分慢,您可能仍会在内存中阅读很多内容。你想要的,在写入时只接受你愿意在内存中缓冲的数量。您可以使用 writer.stat.size(在 fork 内)读取流的大小,并在它超过特定大小后旋转它。
关于ruby-on-rails - rails : How to send file from S3 to remote server,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32801731/
我很难理解为什么这段代码无法编译: use std::cell::{Ref, RefCell}; struct St { data: RefCell } impl St { pub f
我从Richard Blum的一本书《 C#网络编程》中读到有关套接字的信息。以下摘录指出,不保证Send()方法可以发送所有传递给它的数据。 byte[] data = new byte[1024]
我有以下程序,它必须一次读取 1MB 的文件,将其发送到服务器(每次总是 1MB)并返回哈希码: #include #include #include #include #include #
代码在底部。 第 207 行的 send() 命令本身可以正常工作。但是,当我在第 218 行添加 send() 命令时,第一个命令失败 - 给出错误“地址错误”。我已经确认第二个 send() 命令
标记包含 !Send 的类型背后的原因是什么?字段(如 Rc 或 NonNull )与 Send特征?例如,标准库的 LinkedList 以这种方式工作:它包含 Option>字段并实现 Send特
我是新手,我正在尝试学习 goroutines 中信号函数的一些基本用法。我在 go 中有一个无限循环。通过这个 for 循环,我通过 channel 将值传递给 goroutine。 我也有一个阈值
如果数据是从另一台计算机(首先)“发送”的,我如何设置我的套接字例程以“发送”(首先)或(切换)“接收”? 谢谢 通用代码: -(void) TcpClient{ char buffer[12
这个问题已经有答案了: Java multiple file transfer over socket (3 个回答) 已关闭 4 年前。 我正在使用 Java Socket 将文件发送到服务器,然后
根据以下示例中的类型,Go编译器似乎将执行两个完全不同的语义操作: chanA <-chanB 如果chanA是类型(chan chan <-字符串),则此操作会将本身类型chanB的类型(chan
我正在尝试在 VBA 中使用 WinSock2 从本地主机 TCP 流发送(以及稍后接收)数据。 目前,我主要尝试从此处复制客户端示例,https://msdn.microsoft.com/en-us
我在我的 Mac OS X Yosemite 控制台中看到了这个: AppleEvents: Send port for process has no send right, port=( port:
我知道Clojure的“代理”是ref,带有“操作”的添加工作队列。 Action 是使用ref的值在第一个位置调用的函数,可以将其传递给其他参数。操作将返回ref的新值。因此,“代理”是一种计算re
我无法将任何对象或数组传递给 IPCRenderer。 通过 ipcs 传递对象或数组时出现错误,我什至尝试通过使用 JSON.stringify 转换为字符串来发送,但它会将其转换为空对象字符串。
我正在使用unix scoket进行数据传输(SOCK_STREAM模式) 我需要发送超过100k个字符的字符串。首先,我发送一个字符串的长度-它是sizeof(int)个字节。 length = s
Clojure API 将这两个函数描述为: (send a f & args) - Dispatch an action to an agent. Returns the agent immedia
def send_Button(): try: myMsg = "ME: " + text.get() msg = text.get() con
Ruby 对象都有一个“发送”方法,但是,我正在尝试使用一个 Java 库 ( netty-tools ),它的一个接口(interface)上有一个“发送”方法。 用法应该是 java_obj.se
Feb 8, 2011 11:56:49 AM com.sun.xml.internal.messaging.saaj.client.p2p.HttpSOAPC onnection post SEVE
来自 man 2 send: MSG_MORE (since Linux 2.4.4) (…) Since Linux 2.6, this flag is also supported for UDP
我的网页中可以有一个按钮,用于将预填充的消息发送到特定号码吗? 我正在尝试 intent://send/+391234567890#Intent;scheme=smsto;package=com.wh
我是一名优秀的程序员,十分优秀!