小编ks7*_*s78的帖子

如何创建 s3ql 文件系统并在启动时自动挂载?

我一直在 Ubuntu 10.04 上试验s3ql,用它来挂载 Amazon S3 存储桶。但是,我真的很喜欢它自动安装它们。有谁知道这是怎么做到的吗?


解决方案:

感谢 s3ql 的Nikratio 的帮助,我终于能够在系统启动时自动挂载 S3 存储桶。你肯定想看看手册,但这里是如何做到这一点的基础知识!

第一步是创建一个 authinfo 文件。此文件应放置在将使用它的用户的主目录中的 .s3ql 目录中。authinfo 文件包含登录信息,允许 s3ql 在没有提示的情况下挂载存储桶。下面是您的 authinfo 文件应该是什么样子的示例。第一行包含您的 Amazon 安全凭证。第二个包含存储桶的位置和密码。如果需要,您可以向该文件添加多个存储桶行,但我在本示例中仅使用一个。此时,存储桶密码可以是任何内容。

backend s3 machine any login YourAWSAccessKeyID password YourAWSSecretAccessKey
storage-url s3://mybucket password EncryptionPasswordOfYourChoosing
Run Code Online (Sandbox Code Playgroud)

encryption_password_of_your_choosing用于通过S3QL加密/解密所有文件写入从S3 /读取。

存储桶名称在所有 AWS 中必须是唯一的:没有两个用户可以使用相同的存储桶名称,因此最好登录 Amazon Web Services 并尝试不同的名称,直到找到可用的名称。一种好的命名方案是使用您将从中访问存储桶的域+服务器的名称(即“staging.example.com”或“east.coast.01.example.com”,或任何合适的名称)。

要创建文件系统,请使用以下命令:

mkfs.s3ql s3://mybucket
Run Code Online (Sandbox Code Playgroud)

它会提示您输入加密密码。这应该与 authinfo 文件中的存储桶密码相同。

现在您的文件系统已创建,您可以使用以下命令挂载它:

mount.s3ql s3://mybucket /mnt/s3/bucket
Run Code Online (Sandbox Code Playgroud)

当然,您的存储桶名称和挂载点会有所不同。

现在,如果我们想在启动时自动挂载这个存储桶,我们需要在 /etc/init.d 中添加一个 upstart 脚本。幸运的是,s3ql 附带了一个,即 s3ql.conf。

我在 mount.s3ql 命令中添加了“--allow-other”,以允许 root 以外的用户访问已安装的存储桶。

#
# …
Run Code Online (Sandbox Code Playgroud)

server boot scripts mount

5
推荐指数
1
解决办法
5449
查看次数

标签 统计

boot ×1

mount ×1

scripts ×1

server ×1