Seaweedfs之Volume读请求重定向

Seaweedfs之Volume读请求重定向

『场景展现』

启动一个 weed master 服务。

weed master -mdir="/tmp/mdata" -defaultReplication="000" 

启动两个 weed volume 服务。

weed volume -dir=/tmp/vol1/ -mserver="127.0.0.1:9333" -port=8080 weed volume -dir=/tmp/vol2/ -mserver="127.0.0.1:9333" -port=8081 

上传一个文件

curl -F "file=1234" "http://127.0.0.1:9333/submit" {"fid":"4,01146873ae","fileName":"","fileUrl":"127.0.0.1:8081/4,01146873ae","size":4} 

通过返回的 fileUrl 可以正常访问到。

curl 127.0.0.1:8081/4,01146873ae 1234 

但是当我们用同一个fid去请求另一台机器的时候,会获取到一个 HTTP 302 Moved Permanently 的结果。

curl -v 127.0.0.1:8080/4,01146873ae  ...  < HTTP/1.1 301 Moved Permanently < Location: http://127.0.0.1:8081/4,01146873ae < Date: Wed, 24 Feb 2016 16:21:49 GMT < Content-Length: 69 < Content-Type: text/html; charset=utf-8 < <a href="http://127.0.0.1:8081/4,01146873ae">Moved Permanently</a>. 

『实现原理』

根据源码验证了一下,

原理在于 volume 本身缓存着 volumeId 到 Localtion(也就是VolumeServer的url地址)的键值对,

根据 volumeId 可以得知应该重定向到哪台 VolumeServer。

缓存时间目前是代码里面写死的10分钟,缓存过期后再去从 MasterServer 获取,

所以这个重定向的功能当 MasterServer 挂掉的时候是无法实现的。即使 VolumeServer 都还存活。

所以之前可能很多人认为 MasterServer 只和上传文件,也就是文件的写操作有关,

和读操作没有任何关系。但是像这个Redirect的事情,就需要借助 MasterServer 实现。

Seaweedfs之Volume读请求重定向

原文  http://yanyiwu.com/work/2016/02/25/seaweedfs-volume-redirect.html

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » Seaweedfs之Volume读请求重定向

赞 (0)
分享到:更多 ()

评论 3

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. Frankonexyunethost無限空間虛擬主機 技術分享部落格 http://blog.unethost.com/回复
  2. Alex4ExeskЗдравствуйте! Качественный у вас сайт! Несколько минут назад в гугле нашел cfw 090130tddbz в компании пром электрик. Рекомендую! Успехов всем!回复
  3. JamesKemGREEN HOUSE 北歐傢俱-台中家具 http://www.greenhouse.net.tw/回复