fastdfs slave file mode 的应用场景及好处

fastdfs slave mode
fastdfs slave mode

fastdfs Java版本的上传api中有多种方式,当初对众多的接口还是比较疑惑,最近仔细看了Java api的文档和测试源码,对slave mode的上传模式有了更深的了解。
fastdfs的slave mode应用场景主要是在应用层面的特殊需求,如一个原始图片有多份压缩图片(水印,缩略图)或者不同尺寸的文件,这样在原始文件上传完毕后,对由其派生的图片(切图)可以设定文件关联。

设置文件关联并不能节省fastdfs的存储,我能想到的好处就是在应用层面的处理上,可以节约下载地址的存储,如缓存和数据库资源,因为知道了原始图片的地址后可以拼出来其他格式的图片,根据需要任意调用,而不必为每个文件存储其下载地址。

如文件类型如下:

mypic.jpg(原始图片)
mypic_waterfall.jpg
mypic_thum.jpg
mypic_16x16.jpg
mypic_120x120.jpg

根据API
原始图片上传方式:

client.upload_file(local_filename, null, meta_list);

返回的remoteID

remote_filename: group1/M00/00/00/wKgE_lMOtqKAGnL2AACf6PqdpKk9691.gz

缩略图上传方式:

master_filename = remote_filename;   //获取原始文件的remoteID
prefix_name = "thum";  //指定prefix
client.upload_file(group_name, master_filename, prefix_name, local_filename, null, meta_list); //注意,这里的local_filename是根据原图切图之后新生成的图片
返回的remoteID
remote_filename: group1/M00/00/00/wKgE_lMOtqKAGnL2AACf6PqdpKk9691-thum.gz

基本就是这样,fastdfs通过client.upload_file的slave mode接口可以与master fileID建立关联,在应用层面起到了节约部分资源的作用。