无法在goofys挂载的文件夹中生成zip文件

时间:2018-04-04 09:20:43

标签: amazon-s3 amazon-linux

我尝试使用goofys在已安装目录中创建一个zip文件,但是因为这些错误消息失败了:

$ su - foo-user
$ zip hoge.zip hoge
updating: hoge
zip I/O error: Operation not supported
zip error: Input file read failure (was zipping hoge)

有什么线索可以解决这个问题吗?

我尝试了什么

在另一个目录中创建一个zip文件并在挂载点中复制它成功。 所以它似乎不像许可/授权问题。

$ zip /tmp/hoge.zip hoge
  adding: hoge (stored 0%)
$ ll /tmp/hoge.zip
-rw-rw-r-- 1 foo-user foo-user   163 Apr  4 17:52 hoge.zip
$ cp /tmp/hoge.zip (path of the mount-point)
$ ll
total 5
-rw-r--r-- 1 foo-user foo-user    5 Mar 26 10:56 hoge
-rw-r--r-- 1 foo-user foo-user  163 Apr  4 17:48 hoge.zip

系统配置

  • 操作系统:亚马逊Linux(EC2)
  • Goofys版本:0.19.0-use

挂载点的权限:

drwxr-xr-x  2 foo-user foo-user 4096 Apr  4 17:48 s3

输入文件的权限:

-rw-r--r-- 1 foo-user foo-user 5 Mar 26 10:56 hoge

设置/etc/fstab

(path of goofys installed)/goofys#(s3-bucket-name) (path of the mount point) fuse _netdev,allow_other,--file-mode=0644,--uid=502,--gid=502 0 0

foo-user的Uid / gid:

$ id
uid=502(foo-user) gid=502(foo-user) groups=502(foo-user)

2 个答案:

答案 0 :(得分:3)

S3不是文件系统。 Goofys尝试(令人钦佩地)弥合文件系统和对象存储之间的差距,但是存在不可克服的阻抗不匹配,需要妥协或限制。高飞选择了最佳表现之路:

  

在S3上难以支持或者转化为多次往返的事情要么失败(随机写入)......

     

https://github.com/kahing/goofys/blob/master/README.md

Zip文件创建使用随机写入。这可以解释为什么使用-b选项可以解决问题。通过创建临时文件然后复制它,可以避免随机写入存储桶。

对S3的随机写入只能通过显着延迟写入或通过每次随机写入反复覆盖对象来实现,这样做不会很好并且可能牺牲可靠性,耐用性或一致性。

答案 1 :(得分:0)

goofys无法创建zip文件,因为sqlbot建议使用随机写入。 s3fs是支持此功能的类似程序。