当我对单个文件执行此操作时:aws_s3=AWS::S3.new(S3_CONFIG)bucket=aws_s3.buckets[S3_CONFIG["bucket"]]object=bucket.objects["user/1/photos/image_1.jpg"]new_object=bucket.objects["users/1/photos/image_1.jpg"]object.copy_tonew_object,{:acl=>:public_read}但我想移动整个“/photos”文件夹时抛出NoSuchKey。可能s3key只是每个文件的完整路径。如何做到这一点?aw
这个问题与这个问题相关:TrackingUploadProgressofFiletoS3UsingRubyaws-sdk,但是,由于对此没有明确的解决方案,我想知道在2018年是否有更好/更简单的方法(如果存在的话)使用Ruby通过S3获取文件上传进度?在我当前的设置中,我基本上是在创建一个新的Resource,获取我的存储桶并调用upload_file但我还没有找到任何传递block的选项有助于取得某种进展。...@connection=Aws::S3::Resource.new@s3_bucket=@connection.bucket(bucket)@s3_bucket.objec
我刚刚开始研究使用Amazon的SimpleDB服务作为我计划构建的RoR应用程序的数据存储的可行性。我们将为Web服务器使用EC2,并计划将EC2用于MySQL服务器。但现在的问题是,为什么不使用SimpleDB?应用程序(如果成功)需要在支持的用户数量方面具有很强的可扩展性,需要维护简单高效的代码库,并且需要可靠。我很好奇SO社区对此有何看法。 最佳答案 RubySimpleDB库不如ActiveRecord(默认的RailsDB适配器)那么完整,因此您习惯的许多功能将不存在。从好的方面来说,它是无模式的、可扩展的并且可以很好地
我想使用rubysdk在amazonS3中创建一个空文件夹。我读到S3中没有文件夹概念,所以理论上要创建一个文件夹,您只需创建一个带有尾随“/”的空对象s3=Aws::S3::Client.new(region:'eu-west-1',credentials:creds)s3.put_object(bucket:"my_bucket",key:"my_folder/")这样做会在我的存储桶上创建一个空对象,但是如果我尝试上传这样的文件:s3.put_object(bucket:"my_bucket",key:"my_folder/myfile")它不会在my_folder中创建文件
听起来很简单,但这似乎是一项异常复杂的任务。 最佳答案 如果您使用的是aws-s3gem,则以下代码会将存储桶BUCKET_NAME中的文件夹OLD_FOLDER_NAME重命名为NEW_FOLDER_NAME:bsize=OLD_FOLDER_NAME.sizebucket=AWS::S3::Bucket.find(BUCKET_NAME)bucket.objects({:prefix=>OLD_FOLDER_NAME}).eachdo|o|AWS::S3::S3Object.rename(o.key,NEW_FOLDER_NAM
我正在处理潜在的巨大CSV文件,我想从我的Rails应用程序导出这些文件,并且由于它在Heroku上运行,我的想法是在生成这些CSV文件时将它们直接流式传输到S3。现在,我遇到了一个问题,因为Aws::S3需要一个文件才能执行上传,而在我的Rails应用程序中我想做类似的事情:S3.bucket('my-bucket').object('my-csv')我怎样才能做到这一点? 最佳答案 您可以使用s3分段上传,允许通过将大对象拆分为多个block来上传。https://docs.aws.amazon.com/AmazonS3/lat
我正在使用carrierwave将电影上传到amazons3,效果非常好。现在我想在上传时或上传后给电影加水印,我不知道,最好的方法是什么?我试过这个:movie_controller.rbAction上传视频movie=FFMPEG::Movie.new(@vid.video.url)puts"........................................"putsmovie.inspectif@vid.save只是为了查明视频是否是从stremio中捕获的。但后来我得到了找不到电影的错误,问题是它没有在amazons3存储桶中查找,它在我的本地服务器上查找Nosu
在我的Rails应用中,我在创建时将客户RMA运输标签保存到S3存储桶中。我刚刚更新到aws-sdkgem的V2,现在我设置ACL的代码不起作用。在V1.X中有效的代码:#SaveslabeltoS3buckets3=AWS::S3.newobj=s3.buckets[ENV['S3_BUCKET_NAME']].objects["#{shippinglabel_filename}"]obj.write(open(label.label('pdf').postage_label.label_pdf_url,'rb'),:acl=>:public_read).write似乎已被弃用,所以
我正在熟悉使用带有ruby的S3将文件上传到AmazonWebService。我最近遇到了以下错误:AWS::S3::Errors::AccessDeniedAccessDenied。在谷歌上四处寻找,我发现thispost关于错误。它声称存储桶策略不足以允许通过网络应用程序进行访问,并且还必须为用户提供“管理员访问权限”。我已经尝试过了,它工作正常,但我觉得这表明我没有做对,因为我读过的任何其他文档都没有提到管理员访问权限。我正在使用aws-sdkgem。谁能权衡是否需要管理员访问权限?非常感谢! 最佳答案 现有的答案都没有真
我正在编写代码以向所有使用aws-sdkgem的用户授予读取权限。在gem的文档中,我发现了以下内容:bucket.objects.eachdo|object|putsobject.keyacl=object.aclacl.grant(:read).to("TODO:howcanIspecify'ALL'???")object.acl=acl.to_xmlend这一切都说得通,但是我不太确定如何告诉ALL用户授予读取权限? 最佳答案 您的示例可以工作,但更适合复杂的ACL(访问控制列表)。AmazonS3有许多可用于您的对象的固定a