一种上传图片立即回显的解决方案
2011-08-08 22:22
169 查看
在实际项目中遇到过这样一个问题:
上传的图片需要马上回显,而前端负载均衡考虑未支持会话保持来防止恶意攻击,也就是说上传请求落在A服务器上,而紧接着的回显请求落在B服务器上,需要保证同时回显最新的图片。
可能一上来就有人说可以用开源分布式文件系统,但正真能驾驭这些开源产品的人有多少呢?那么,有没有简单可靠的方案呢?
方案应该满足以下几个基本原则:
1、可用性:能通过加机器适应负载增加
2、可靠性:一台机器挂掉不影响服务
3、简单可依赖:实现上容易且易于理解
一种解决方案:image服务器+memcache方式
1、上传时(请求落到server-A):文件命名中包含服务器时间信息,如当前时间戳,上传成功后保存在server-A本地,同时写一条memcached记录,key为文件名。
2、同步:多台image-server同构接受读请求,定时差异化同步image(最简单的async),如5分钟同步一次,保证最终文件的一致性。
3、读取(回显即普通读取):根据文件名获取上传时间,如果小于当前时间-同步周期(如5分钟,考虑同步延迟,可为10分钟),则直接从本地读取,否则,从memcache中读取。
4、如果单台memcached不够用,则可以按文件名hash存储到多台memcached中。
解决方案的实现:
第一步,在action(如php)实现即可,比较简单。
第二步,采用开源文件同步工具,如async。
第三步,简单使用apache的rewrite功能,对不存在的文件重定向到某个action,在action中memcached去获取。
第四步,程序中增加配置即可。
解决方案的问题:
1、一台memcache挂掉,会造成一部分请求404,解决方案为memcached同步。
2、memcache中item被lru换出,会造成一部分请求404,解决方案为预先评估好数据量。
3、如果image服务器太多,同步时diff的过程会比较慢,而且同步速度取决于差异化程度,解决方案可采用更有效率的diff方式(tree hash)。
上传的图片需要马上回显,而前端负载均衡考虑未支持会话保持来防止恶意攻击,也就是说上传请求落在A服务器上,而紧接着的回显请求落在B服务器上,需要保证同时回显最新的图片。
可能一上来就有人说可以用开源分布式文件系统,但正真能驾驭这些开源产品的人有多少呢?那么,有没有简单可靠的方案呢?
方案应该满足以下几个基本原则:
1、可用性:能通过加机器适应负载增加
2、可靠性:一台机器挂掉不影响服务
3、简单可依赖:实现上容易且易于理解
一种解决方案:image服务器+memcache方式
1、上传时(请求落到server-A):文件命名中包含服务器时间信息,如当前时间戳,上传成功后保存在server-A本地,同时写一条memcached记录,key为文件名。
2、同步:多台image-server同构接受读请求,定时差异化同步image(最简单的async),如5分钟同步一次,保证最终文件的一致性。
3、读取(回显即普通读取):根据文件名获取上传时间,如果小于当前时间-同步周期(如5分钟,考虑同步延迟,可为10分钟),则直接从本地读取,否则,从memcache中读取。
4、如果单台memcached不够用,则可以按文件名hash存储到多台memcached中。
解决方案的实现:
第一步,在action(如php)实现即可,比较简单。
第二步,采用开源文件同步工具,如async。
第三步,简单使用apache的rewrite功能,对不存在的文件重定向到某个action,在action中memcached去获取。
第四步,程序中增加配置即可。
解决方案的问题:
1、一台memcache挂掉,会造成一部分请求404,解决方案为memcached同步。
2、memcache中item被lru换出,会造成一部分请求404,解决方案为预先评估好数据量。
3、如果image服务器太多,同步时diff的过程会比较慢,而且同步速度取决于差异化程度,解决方案可采用更有效率的diff方式(tree hash)。
相关文章推荐
- 一种上传图片立即回显的解决方案
- 多张图片上传,支持上传后立即回显,删除(同时删除数据库相对地址)
- js实现上传图片立即回显
- ueditor1.4.3jsp版成功上传图片后却回显不出来与在线管理显示不出图片的解决方案
- 左侧图片 右侧块的实现方法---解决3像素bug的一种解决方案,不用浮动用绝对定位和margin-left
- 微信网页IOS上传图片旋转解决方案
- asp.net文件上传解决方案(图片上传、单文件上传、多文件上传、检查文件类型)
- 从浏览器上传图片到数据库的一种方式
- IOS上传图片有很多方法,一种是通过IOS提交NSData数据
- ASP.NET MVC 4.0 CKEditor jquery 文章管理 图片上传 解决方案
- asp.net 自定义控件实现无刷新上传图片,立即显示缩略图,保存图片缩略图
- JSP/HTML 上传图片后立即在页面显现该图片
- Android Retrofit 2.0框架上传图片解决方案(一张与多张的处理)
- PHP JS JQ 异步上传并立即显示图片
- 图片上传本地预览(回显)插件
- Spring中文件上传,图片上传以及回显
- SAE Storage + Android微信内置浏览器图片上传解决方案
- 基于Java Web的文件上传进度显示的一种解决方案
- 解决ue上传图片被压缩的一种方法
- dedecms 自定义模型中图片字段无法选择及无法上传问题的解决方案