新闻中心
通过S3FS在AWS EC2实例间高效共享与展示文件列表

本文旨在解决在aws ec2多实例环境中,一个ec2实例如何安全、高效地访问并展示另一个ec2实例上文件列表的问题。传统的直接http路径或本地文件系统操作无法满足需求。通过引入s3fs工具,将aws s3存储桶挂载为本地文件系统,我们可以在多个ec2实例间实现文件内容的同步访问与展示,从而构建分布式且易于管理的应用程序架构。
在分布式应用架构中,尤其是在AWS EC2环境下,经常会遇到一个EC2实例(例如管理界面)需要访问并展示另一个EC2实例(例如文件存储服务器)上特定目录文件列表的需求。直接通过HTTP路径访问远程实例上的文件目录,或者尝试将远程路径视为本地文件系统路径进行操作,通常会导致失败,因为这不符合文件系统访问的机制。
挑战分析
考虑以下场景:
一个管理界面EC2实例(实例A)需要显示另一个文件存储EC2实例(实例B)上 /upload_directory/ 目录中的文件列表。
如果实例A尝试使用PHP的 scandir() 函数并指定一个本地路径,例如 upload_directory/,它只
能访问实例A自身的文件。
如果实例A尝试将路径更改为实例B的HTTP地址,例如 http://xx.xxx.xxx.xx/upload_directory/,scandir() 函数将无法解析此URL作为一个可扫描的文件系统路径,因为它是一个网络资源而非本地目录。
// 在本地测试时,此脚本可以工作
$path = "upload_directory/";
$files = scandir($path);
foreach($files as $file) {
if ($file[0] != '.') {
$nothidden[] = $file;
}
}
for ($x=0;$x<count($nothidden);$x++){
// ${'file'.$x} = $nothidden[$x]; // 原始代码中的变量赋值可能不是最佳实践
echo $nothidden[$x] . "<br>";
}
// 当尝试访问远程HTTP路径时,此方法无效
// $path = "http://xx.xxx.xxx.xx/upload_directory/";
// $files = scandir($path); // 会失败这种情况下,仅仅调整安全组出站规则是不足以解决文件系统层面的访问问题的。我们需要一个能够将远程存储“本地化”的解决方案。
解决方案:利用S3FS实现S3存储桶的本地挂载
最有效且推荐的方法是利用AWS S3存储桶作为共享存储介质,并结合S3FS-FUSE工具将其挂载到EC2实例的本地文件系统。这样,两个EC2实例都可以将同一个S3存储桶视为本地目录进行读写操作,从而实现文件列表的共享与展示。
1. 准备AWS S3存储桶
首先,您需要在AWS中创建一个S3存储桶。这个存储桶将用于存储您的文件,并且两个EC2实例都将访问它。
2. 配置IAM权限
为了安全地访问S3存储桶,您应该为EC2实例配置适当的IAM角色。此IAM角色应至少包含对目标S3存储桶的读写权限(例如 s3:GetObject, s3:ListBucket, s3:PutObject, s3:DeleteObject 等)。将此IAM角色附加到您的EC2实例上,这比直接在实例上配置AWS访问密钥更安全。
如果您选择不使用IAM角色,则需要配置AWS访问密钥和秘密访问密钥,但这通常不推荐用于生产环境。
3. 安装S3FS-FUSE
S3FS-FUSE是一个开源工具,允许您将S3存储桶挂载为本地文件系统。在每个需要访问S3存储桶的EC2实例(即实例A和实例B)上,都需要安装S3FS。
请参照S3FS-FUSE的官方GitHub仓库获取最新的安装指南: https://www.php.cn/link/523d6984fa5aa355c0f4b63b564ce892
通常,在Ubuntu等基于Debian的系统上,安装过程可能涉及安装依赖、编译和安装:
# 安装依赖 sudo apt-get update sudo apt-get install automake autotools-dev fuse g++ git libcurl4-gnutls-dev libfuse-dev libssl-dev libxml2-dev make pkg-config # 克隆s3fs仓库 git clone https://www.php.cn/link/523d6984fa5aa355c0f4b63b564ce892.git cd s3fs-fuse # 编译和安装 ./autogen.sh ./configure make sudo make install
4. 挂载S3存储桶
安装S3FS后,您可以在两个EC2实例上将S3存储桶挂载到指定的本地目录。
使用IAM角色挂载(推荐):
如果您的EC2实例已附加具有S3读写权限的IAM角色,则可以使用以下命令进行挂载:
Yaara
使用AI生成一流的文案广告,电子邮件,网站,列表,博客,故事和更多…
95
查看详情
sudo /usr/local/bin/s3fs -o allow_other -o iam_role='您的IAM角色名称' 您的S3桶名称 /mnt/s3fs/pathlocal
- 您的S3桶名称: 替换为您的S3存储桶的实际名称。
- /mnt/s3fs/pathlocal: 替换为您希望在本地挂载S3存储桶的目录。请确保此目录已存在(例如 sudo mkdir -p /mnt/s3fs/pathlocal)。
- -o allow_other: 允许非root用户访问挂载点。
- -o iam_role='您的IAM角色名称': 指定EC2实例的IAM角色名称。
使用AWS访问密钥挂载(不推荐用于生产环境):
如果您没有使用IAM角色,或者出于特定测试目的,您可以在 /etc/passwd-s3fs 文件中存储AWS访问密钥和秘密访问密钥,并设置文件权限为 600。
echo "您的AWS访问密钥ID:您的AWS秘密访问密钥" > /etc/passwd-s3fs sudo chmod 600 /etc/passwd-s3fs sudo /usr/local/bin/s3fs -o allow_other 您的S3桶名称 /mnt/s3fs/pathlocal
重要提示: 上述挂载操作需要在两个EC2实例上都执行。这意味着实例A和实例B都将把同一个S3存储桶挂载到它们各自的 /mnt/s3fs/pathlocal 目录。
5. 配置开机自动挂载
为了确保EC2实例重启后S3存储桶能自动挂载,您可以将挂载命令添加到 /etc/rc.local 文件中。
编辑 /etc/rc.local 文件(如果不存在可能需要创建并赋予执行权限 sudo chmod +x /etc/rc.local):
sudo nano /etc/rc.local
在 exit 0 行之前添加您的挂载命令,例如:
#!/bin/sh -e # # rc.local # # This script is executed at the end of each multiuser runlevel. # Make sure that the script will "exit 0" on success or any other # value on error. # # In order to enable or disable this script just change the execution # bits. # # By default this script does nothing. # 确保挂载点存在 mkdir -p /mnt/s3fs/pathlocal # 使用IAM角色自动挂载S3桶 /usr/local/bin/s3fs -o allow_other -o iam_role='您的IAM角色名称' 您的S3桶名称 /mnt/s3fs/pathlocal exit 0
保存并退出。
6. 更新PHP脚本
一旦S3存储桶在两个EC2实例上都成功挂载到 /mnt/s3fs/pathlocal 路径,并且您将文件上传到S3存储桶(通过实例B,或者直接通过AWS控制台),实例A上的PHP脚本就可以像访问本地文件一样访问这些文件了。
如果您的文件在S3存储桶中是直接位于根目录,或者位于 /upload_directory/ 路径下,那么实例A上的PHP脚本可以修改为:
// 假设S3桶挂载在 /mnt/s3fs/pathlocal
// 并且您的文件在S3桶的根目录或子目录
$path = "/mnt/s3fs/pathlocal/upload_directory/"; // 确保此路径与S3桶内的实际文件路径对应
$files = scandir($path);
if ($files !== false) {
foreach($files as $file) {
if ($file[0] != '.') { // 排除隐藏文件
echo $file . "<br>";
}
}
} else {
echo "无法读取目录或目录不存在。";
}现在,当实例A运行此PHP脚本时,它实际上是在访问通过S3FS挂载的S3存储桶中的文件,从而实现了远程文件列表的展示。
注意事项与最佳实践
- 数据一致性: S3FS提供了对S3的访问,S3本身是一个最终一致性存储。这意味着在某些情况下,文件操作(如上传、删除)后,立即尝试读取可能不会立即反映最新状态。对于文件列表展示,这通常不是大问题,但在高并发写入和即时读取场景下需要注意。
- 性能: 通过S3FS访问S3的性能会受到网络延迟和S3服务本身的影响,可能不如直接访问本地SSD。对于需要极高性能文件操作的应用,可能需要考虑其他方案(如EFS)。
- 成本: 使用S3会产生存储费用、数据传输费用和请求费用。确保了解这些成本模型。
- 安全: 始终优先使用IAM角色来授权EC2实例访问S3,避免在实例上硬编码AWS访问密钥。确保IAM角色的权限是最小必需权限。
- 错误处理: 在您的PHP脚本中,添加对 scandir() 返回值的检查,以优雅地处理目录不存在或无法访问的情况。
- 文件路径: 仔细管理S3存储桶中的文件结构,并确保PHP脚本中的路径与S3FS挂载后的本地路径准确对应。
总结
通过S3FS-FUSE工具将AWS S3存储桶挂载到EC2实例的本地文件系统,我们成功地解决了在分布式EC2环境中访问和展示远程文件列表的难题。这种方法不仅提供了灵活的文件共享机制,还利用了S3的高可用性和持久性。通过合理配置IAM权限和开机自动挂载,可以构建出健壮且易于管理的文件服务架构。
以上就是通过S3FS在AWS EC2实例间高效共享与展示文件列表的详细内容,更多请关注php中文网其它相关文章!
# 不存在
# 国外网站建设文案
# 山东网站建设套餐报价
# 白坭seo优化查询
# 涂书网站建设游戏
# 电商营销推广规则
# 历史年度关键词排名优化
# 软件网站排行榜优化大师
# 公众号关键词seo
# 桂林本地网站建设优化
# zen cart url seo
# 情况下
# 您将
# 上都
# 是在
# php
# 您可以
# 是一个
# 文件系统
# 文件列表
# 您的
# php脚本
# 本地化
# curl
# ssl
# 工具
# ubuntu
# 编码
# github
# git
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
Selenium Python中处理点击后新窗口加载冻结问题的策略与实践
Go调试环境为何无法启动_Go调试器启动失败原因与解决策略
fishbowl官网免费版 fishbowl养鱼网站入口
印象笔记怎样用批量导出备知识库_印象笔记用批量导出备知识库【备份方法】
谷歌浏览器无痕模式怎么开 Chrome开启无痕浏览设置方法【教程】
sublime怎么格式化代码_sublime代码美化与一键排版插件配置
使用J*aScript检测输入元素是否包含在特定类中
“在文档元素之后找到了标记”是什么错误? 检查并修复XML中多个根元素的3个方法
动漫共和国防屏蔽稳定域名-动漫共和国官方正版直达通道
Win11截图该按哪些键 Win11截屏完整流程解析【教程】
C++如何检测键盘输入_C++ _kbhit与_getch函数非阻塞输入
在J*a中如何隐藏复杂性_使用门面模式组织对象交互
C++ explicit关键字防止隐式转换_C++构造函数安全规范
解决Python单元测试中Mock异常方法调用计数为零的问题
React中useState与局部变量:理解组件状态管理与渲染机制
c++如何使用Catch2编写单元测试_c++简洁易用的BDD风格测试框架
QQ邮箱网页版入口登录 QQ邮箱在线邮箱官方通道
一加手机拍照效果不好怎么办 一加哈苏影像调校与专业模式使用教程【高手篇】
Descript怎样用AI剪辑自动去噪_Descript用AI剪辑自动去噪【自动降噪】
Go语言JSON解析深度指南:动态访问与结构体映射实践
Windows10怎么开启存储感知 Windows10系统设置自动清理临时文件释放C盘空间【教程】
火狐浏览器占用内存高卡顿怎么办 火狐浏览器性能优化设置技巧
php源码怎么看淘宝客系统_看php源码淘宝客系统技巧
响应式容器内容自动缩放与宽高比维持教程
怎么在html里运行vbs脚本_html中运行vbs脚本方法【教程】
斑马英语APP如何开启夜间护眼阅读_斑马英语APP夜间模式与低蓝光设置教程
支付宝碰一碰设备是REDMI手机吗 博主拆机辟谣:处理器、内存都不一样
向日葵客户端怎么进行远程CentOS控制_向日葵客户端远程CentOS控制操作教程
在哪找SublimeJ远程工具_SFTP插件配置教程
大麦的“候补”是什么意思 大麦候补购票规则【详解】
2025-2030年全球乘用车销量预测:新能源成增长主力
Excel如何用迷你图显趋势_Excel用迷你图显趋势【趋势小图】
解决 Vaadin 8 中大文件音频播放与定位时出现的 IOException
Lar*el如何正确地在控制器和模型之间分配逻辑_Lar*el代码职责分离与架构建议
将HTML Canvas内容转换为可上传的图像文件(File对象)
TikTok国际版官网直达_TikTok国际版官网直达进入在线观看
抖音小游戏合成大西瓜免费秒玩入口链接 抖音小游戏热门合集秒玩网站
iCloud登录入口网页版 苹果iCloud官网登录
狙击外星人小游戏开始_狙击外星人小游戏立即开始
Golang如何优化CPU绑定任务分配策略_Golang CPU任务分配优化实践
学习通网页版快速入口 学习通官网网页版直接打开
c++ dfs和bfs代码 c++深度广度优先搜索算法
Sublime Text怎么设置垂直标尺_Sublime配置Rulers规范代码长度
C++如何实现一个智能指针_手动实现C++ shared_ptr的引用计数功能
顺丰快件物流信息 官方网站查询入口
怎样在Excel中做仪表盘_Excel仪表盘设计与关键指标展示方法
虚幻5科幻题材ARPG大作遭取消!本是《奇异人生》厂商新作
Vue.js 图片显示异常排查:理解应用挂载范围与DOM ID唯一性
Go语言中对Map值调用带指针接收者方法:原理与最佳实践
Lar*el 8 多关键词数据库搜索优化实践


2025-11-10
浏览次数:次
返回列表