FastDFS加Redis实现自定义文件名存储海量文件
【四方】2013/08/27软件综合 IP:吉林
FastDFS加Redis实现自定义文件名存储海量文件

FastDFS非常适合存储大量的小文件,遗憾的是本身不支持自定义文件名,文件名是存储成功以后根据存储位置生成的一个file_id。很多应用场景不得不使用自定义文件名,在不修改其源码的情况下,可以在存储客户端fdfs_client增加一个用来存储自定义文件名和fastdfs的file_id之间的映射关系的数据库间接实现自定义文件名的存取和访问,在这里我们选用了reids。顺便说一下,淘宝也有一个类似于FastDFS的文件存储系统TFS,对于自定义文件名,它是用mysql来存储映射关系的,我认为在高并发访问下mysql本身就是瓶颈,因此在这个方案中采用了redis。

准备工作:

fastdfs环境安装...略...(官方:XXXXXXXXXXXXXXXXXXXXXXX/p/fastdfs/

redis环境安装...略...(官方:XXXXXXXXXXXXXXX/)

用python实现,因此需要安装fastdfs的python客户端(下载:XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX/files/fdfs_client-py-1.2.6.tar.gz)

python的redis客户端,到XXXXXXXXXXXXXXXXXXXXXXX/pypi/redis下载

详见博客:XXXXXXXXXXXXXXXXXXXXt/waterbear/blog/150743

01
# -*- coding: utf-8 -*-
02

03

04
#fastdfs tracker, multiple tracker supported
05
fdfs_tracker = {
06
'host_tuple'[s:2]'192.168.2.233','192.168.2.234'),
07
'port':22122,
08
'timeout':30,
09
'name':'Tracker Pool'
10
}
11
#fastdfs meta db, multiple redisdb supported
12
fdfs_redis_dbs = (
13
    ('192.168.2.233',6379,0),
14
    ('192.168.2.233',6379,1)
15
)

转自 开源中国 水熊宝宝 发布于 2013年08月07日 12时, 4评/325阅
来自:计算机科学 / 软件综合
0
已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也

想参与大家的讨论?现在就 登录 或者 注册

所属专业
上级专业
同级专业
【四方】
学者 机友 笔友
文章
135
回复
1318
学术分
1
2013/03/23注册,4年9个月前活动
暂无简介
主体类型:个人
所属领域:无
认证方式:手机号
IP归属地:未同步
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
支持的图片格式:jpg, jpeg, png
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}