现有的FastDFS数据库与python交互, 多是通过下载fdfs-client-py,pip本地安装.
不过该模块只适用于Python2, 且适配FastDFS版本较为古老.
在Python3中, 有相对应的py3fdfs模块
安装
pip install py3Fdfs
py3fdfs源于fdfs-client,但在使用过程中, 和旧版略有不同.(py3fdfs官网示例有误)
创建client实例对象的时候不能直接传入配置文件的地址字符串,否则报错.
错误代码:TypeError: type object argument after ** must be a mapping, not str
通过模块内get_tracker_conf函数, 获取配置文件后传入.
例:
from fdfs_client.client import Fdfs_client, get_tracker_conf tracker_path = get_tracker_conf('/etc/fdfs/client.conf') client = Fdfs_client(tracker_path) ret = client.upload_by_filename('./test') print(ret)
!# 上传成功后返回的字典内, 其中'Remote file_id'键对应的值由旧版模块string类型更改为byte类型.
则, 返回的文件id是byte类型
如果项目中有自定义上传类, 需要解码返回的文件id为字符串,否则服务器报错.
错误代码:a bytes-like object is required, not 'str'
例:
class FastDFSStorage(Storage): '''自定义上传类''' def _save(self, name, content): '''_save方法''' conf_path = get_tracker_conf('./utils/fdfs/client.conf') client = Fdfs_client(conf_path) result = client.upload_by_buffer(content.read()) if result.get('Status') != 'Upload successed.': raise Exception('上传文件到FastDFS失败') filename = result.get('Remote file_id') # return filename # return str(filename) return filename.decode()