FastDFS单节点部署
1、FastDFS入门
1.1 分布式文件系统
分布式文件系统 (Distributed File System) 是一个软件/软件服务器,这个软件可以用来管理文件。但这个软件所管理的文件通常不是在一个服务器节点上,而是在多个服务器节点上,这些服务器节点通过网络相连构成一个庞大的文件存储服务器集群,这些服务器都用于存储文件资源,通过分布式文件系统来管理这些服务器上的文件。
常见的分布式文件系统有:FastDFS、GFS、HDFS、Lustre 、Ceph 、GridFS 、mogileFS、TFS 等。其实均是类GFS的文件系统。
- 分布式文件系统与传统文件系统对比
- 传统方式弊端:
- 如果用户数量多,IO操作比较多,对磁盘访问压力很大
- 如果磁盘发生故障,会造成数据丢失
- 存储容量有限
FastDFS分布式文件系统的优点:
- 解决传统方式的单点故障问题,如果某一个节点出现故障,还有其他的节点可以用来读取和写入文件
- 可以提供数据备份避免因磁盘损坏导致的文件丢失
- 可以提供扩容的机制,无限增加文件存放的空间上限
FastDFS特点:
-
分组存储,简单灵活;
-
对等结构,不存在单点;
-
文件ID由FastDFS生成,作为文件访问凭证。FastDFS不需要传统的nameserver或metaserver;
-
大、中、小文件均可以很好支持,可以存储海量小文件;
-
一台storage支持多块磁盘,支持单盘数据恢复;
-
提供了nginx扩展模块,可以和nginx无缝衔接;
-
支持多线程方式上传和下载文件,支持断点续传;
-
存储服务器上可以保存文件附加属性。
1.2 FastDFS 简介
FastDFS 是一个开源的轻量级分布式文件系统,为互联网应用量身定做,简单、灵活、高效,采用 C 语言开发,由阿里巴巴开发并开源。
FastDFS 对文件进行管理,功能包括:文件存储、文件同步、文件访问(文件上传、文件下载、文件删除)等,解决了大容量文件存储的问题,特别适合以文件为载体的在线服务,如相册网站、文档网站、图片网站、视频网站等等。
FastDFS 充分考虑了冗余备份、线性扩容等机制,并注重高可用、高性能等指标,使用FastDFS 很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务。
1.3 FastDFS 发展历史
2008 年 4 月项目启动,7 月发布第一个版本 V1.00,两年时间内持续升级到 V1.29
2010 年 8 月推出 V2.00
2011 年 6 月推出 V3.00
2012 年 10 月推出 V4.0.0
2013 年 12 月推出 V5.0.0
截止目前最新版是 V5.11(2017 年 6 月发布)
FastDFS 系统架构从第一个版本发布后一直没有大的调整,高版本完全兼容低版本的数据,可以做到平滑升级,推荐更新升级到最新版本
FastDFS 代码托管在 github 上:https://github.com/happyfish100/fastdfs
1.4 FastDFS 整体架构
FastDFS 文件系统由两大部分构成,一个是客户端,一个是服务端。
客户端通常指我们的程序,比如我们的 Java 程序去连接 FastDFS、操作 FastDFS,那我们的 Java 程序就是一个客户端,FastDFS 提供专有 API 访问,目前提供了 C、Java 和 PHP 几种编程语言的 API,用来访问 FastDFS 文件系统。业务请求的发起方,通过专有接口,使用TCP/IP协议与跟踪器服务器或存储节点进行数据交互。
服务端由两个部分构成:一个是跟踪器(tracker),一个是存储节点(storage)
跟踪器(tracker)主要做调度工作,在内存中记录集群中存储节点storage的状态信息,是前端Client和后端存储节点storage的枢纽。因为相关信息全部在内存中,Tracker server的性能非常高,一个较大的集群(比如上百个 group)中有3台就足够了。
跟踪器,主要做调度工作,管理集群,在访问上起到负载均衡的作用。 `tracker`也可以实现集群。每个`tracker`节点地位平等。
作用:引导客户端去哪台服务器存储数据,实际上是客户端与存储服务器直接进行通信的,并不需要通过`Tracker`进行中转。
存储节点(storage)用于存储文件,包括文件和文件属性(meta data)都保存到存储服务器磁盘上,完成文件管理的所有功能:文件存储、文件同步和提供文件访问等。
存储节点,完成文件管理的所有功能:存储、同步和提供存取接口,FastDFS同时对文件的`metadata`进行管理。需要连接`tracker`端,定期报告自己的情况(是否活着,剩余容量,负载情况)分为多个组,每个组之间保存的文件是不同的。每个组内部可以有多个成员,组成员内部保存的内容是一样的,组成员的地位是一致的,没有主从的概念。
`Storage`是可以实现横向扩容的,向里面添加组服务器,且同一个组里面的文件是一样的,一台服务器挂了,还有别的服务器可以提供访问。(实现高可用)一台服务器很忙,可以将访问分配给其他服务器,实现负载均衡。
FastDFS上传文件交互过程
client
询问tracker
上传到的storage
,不需要附加参数;tracker
返回一台可用的storage
client
直接和storage
通讯完成文件上传
FastDFS下载文件交互过程
client
询问tracker
下载文件的storage
,参数为文件标识(卷名和文件名);tracker
返回一台可用的storage
;client
直接和storage
通讯完成文件下载
1.5 FastDFS 线上使用者
UC (http://www.uc.cn/ ,存储容量超过 10TB)
支付宝(http://www.alipay.com/)
京东商城(http://www.jd.com/)
淘淘搜(http://www.taotaosou.com/)
飞信(http://feixin.10086.cn/)
赶集网(http://www.ganji.com/)
淘米网(http://www.61.com/)
迅雷(http://www.xunlei.com/)
蚂蜂窝(http://www.mafengwo.cn/)
5173(http://www.5173.com/)
华师京城教育云平台(http://www.hsjdy.com.cn/)
视友网(http://www.cuctv.com/)
搜道网(http://www.sodao.com/)
58 同城(http://www.58.com/)
商务联盟网(http://www.biz72.com/)
中青网(http://www.youth.cn/)
保利威视(http://www.freeovp.com/)
梦芭莎(http://www.moonbasa.com/)
51CTO(http://www.51cto.com/)
搜房网(http://www.soufun.com/)
2、FastDFS 环境搭建
2.1 FastDFS 安装
2.1.1 安装前的准备
(1)检查 Linux 上是否安装了 gcc、libevent、libevent-devel
yum list installed | grep gcc
yum list installed | grep libevent
yum list installed | grep libevent-devel
(2) 如果没有安装,则需进行安装
yum install gcc libevent libevent-devel -y
2.1.2 安装 libfastcommon库
libfastcommon 库是 FastDFS 文件系统运行需要的公共 C 语言函数库
注意:目前最新版本的 v1.0.39 和最新版的 FastDFS5.11 不兼容,所有我们这里使用的版本是 v1.0.36 下载地址:https://github.com/happyfish100
(1) 将下载好的 libfastcommon 文件上传到 linux服务器(/soft)
(2) 解压下载下来的 tar.gz 压缩包到当前目录
tar -zxvf libfastcommon-1.0.36.tar.gz
(3) 切换到解压后的 libfastcommon 目录
cd libfastcommon-1.0.36
(4) 执行 make 脚本进行编译
./make.sh
注意: make 编译的时候如果报错,需解决错误后再次进行 make,通常发生错误是由于 Linux 缺少某些依赖库导致,根据错误提示解决错误
(5) 执行 make install 进行安装
./make.sh install
#安装完成提示libfastcommon安装在了如下两个位置
#/usr/lib/libfastcommon.so
#/usr/lib64/libfastcommon.so
#可分别进入这两个目录并查看
cd /usr/lib && ls | grep libfastcommon.so
cd /usr/lib64 && ls | grep libfastcommon.so
#由于FastDFS主程序设置的目录为/usr/local/lib/,所以我们需要创建/usr/lib64/下的一些核心执行程序的软连接文件,执行以下命令
# ln -s /usr/lib64/libfastcommon.so /usr/local/lib/libfastcommon.so \
# && ln -s /usr/lib64/libfastcommon.so /usr/lib/libfastcommon.so \
# && ln -s /usr/lib64/libfdfsclient.so /usr/local/lib/libfdfsclient.so \
# && ln -s /usr/lib64/libfdfsclient.so /usr/lib/libfdfsclient.so
#如果是fastdfs5.0.8,上述创建软连接,可能会提示已经存在,但是为了保证没有漏掉,建议还是都执行一遍
至此 libfastcommon 库安装完毕
2.1.3 安装 FastDFS
FastDFS没有 Windows 版本,不能在Windows下使用。
FastDFS需要安装部署在Linux环境下,我们这里使用的是 fastdfs-5.11版本(201901)
下载地址: https://github.com/happyfish100/fastdfs/archive/V5.11.tar.gz
(1) 将下载好的 FastDFS 文件上传到 Linux(home/soft)
(2) 解压下载下来的 tar.gz 压缩包到当前目录
tar -zxvf fastdfs-5.11.tar.gz
(3) 切换到解压后 FastDFS 的目录
cd fastdfs-5.11
(4) 执行 make 脚本进行编译
./make.sh
(5) 执行 make install 进行安装
./make.sh install
# 验证
cd /etc/fdfs && ll #查看配置文件列表
cd /etc/init.d && ll |grep fdfs #查看服务脚本
cd /usr/bin && ll |grep fdfs #查看执行脚本
# 全局替换执行脚本目录(5.0.8及以后的版本就不需要执行这一步了)
vim /etc/init.d/fdfs_storaged #编辑fdfs_storaged文件,执行全局替换
:%s+/usr/local/bin+/usr/bin #(键盘输入才有效)
vim /etc/init.d/fdfs_trackerd #编辑fdfs_trackerd文件,执行全局替换
:%s+/usr/local/bin+/usr/bin #(键盘输入才有效)
至此 FastDFS 安装完成
- 所有编译出来的文件存放在/usr/bin 目录下
- 所有配置文件存放在/etc/fdfs 目录下
(6) 查看安装后的效果
- 查看 FastDFS 相关的可执行程序
ll /usr/bin/fdfs*
- 查看 FastDFS 的配置文件
ll /etc/fdfs/
(7) 另外注意需要把解压后的 fastdfs-5.11/conf 目录下的两个文件拷贝到/etc/fdfs/ ,否则后续会有很多奇怪问题不好解决
cp http.conf /etc/fdfs/
cp mime.types /etc/fdfs/
这两个文件后续需要用到,所以先拷贝过去
2.2FastDFS 配置
2.2.1 去掉/etc/fdfs/目录下 FastDFS 配置文件的后缀名
[root@fastdfs01 fastdfs-5.11]# cd /etc/fdfs/
[root@fastdfs01 fdfs]# mv client.conf.sample client.conf
[root@fastdfs01 fdfs]# mv storage.conf.sample storage.conf
[root@fastdfs01 fdfs