nginx负载均衡同步上传文件的问题 - SegmentFault
因为使用nginx均衡负载,由于分发请求到不同服务器,这样如果只想把上传的图片只保存到一台服务器就会出问题。
百度到的方法:
第一种方法是代码里面使用ftp 把文件同步到保存服务器
第二种方法是如果不是保存文件的服务器,使用curl 把文件提交到保存服务器再重新存一次。
第三种方法就是直接使用保存服务器的ip来调接口了。第三种方法我们这边先不考虑。
不知道大神们,遇到这种情况是怎么实现这种需求的
回复内容:
大神们,我现在有个问题,帮我看下:
因为使用nginx均衡负载,由于分发请求到不同服务器,这样如果只想把上传的图片只保存到一台服务器就会出问题。
百度到的方法:
第一种方法是代码里面使用ftp 把文件同步到保存服务器
第二种方法是如果不是保存文件的服务器,使用curl 把文件提交到保存服务器再重新存一次。
第三种方法就是直接使用保存服务器的ip来调接口了。第三种方法我们这边先不考虑。
不知道大神们,遇到这种情况是怎么实现这种需求的
- 3 小时前提问
- 评论
- 邀请回答
请先 登录 后评论
默认排序 时间排序
2 个回答
宿主的nginx对于上传的location做特殊处理, 只让一台机器来负责文件上传, 不完美但是有效, 可以作为一段时间的过度方案
搭建一个分布式文件系统, 挂载到所有的服务器上, 处理文件上传后写只写入这个特定目录, nginx中规划一个location指向这个这个目录(例如/data/upload), 缺点就是要多维护一个这个分布式文件系统 (和你的第一种思路有点像, 但分布式文件系统不需要"同步")
使用外部CDN文件上传来解决这个问题, 七牛, 又拍云都可以
1.专门整几台服务器用来存这些静态资源;
2.整出几个盘,弄成网络盘(nfs),专门用来存储这些文件,每个服务器都去挂载这几个盘,和windows的共享文件夹类似;
3.上传成功之后返回一个文件的url,这个url就是文件的地址了;
推荐阅读
-
Win2003利用dfs(分布式文件系统)在负载均衡下的文件同步配置方案
-
基于Docker部署Tomcat集群、 Nginx负载均衡的问题小结
-
Java负载均衡服务器实现上传文件同步
-
20台服务器网站根目录想保持一致(比如负载均衡),是如何进行保持文件同步更新的?越详细越好
-
nginx负载均衡同步上传文件的问题 - SegmentFault
-
nginx+php 上传文件失败的问题client_max_body_size
-
nginx负载均衡同步上传文件的问题 - SegmentFault
-
nginx负载均衡造成的数据查询不同步
-
Win2003利用dfs(分布式文件系统)在负载均衡下的文件同步配置方案
-
上传文件的PHP脚本不工作的问题(目录权限问题)php-fpm+nginx