admin 发表于 2016-4-15 17:28

Linux下搭建FastDFS分布式存储环境

下面的实验准备搭建一个FastDFS分布式存储环境,网络拓扑如下


首先,在每一台服务器上安装FastDFS
# yum install libevent libevent-devel libevent-headers -y
# ./make.sh
# ./make.sh install
安装成功之后,可以看到/etc下其相应的配置文件


配置tracker服务器,192.168.1.1
修改/etc/fdfs/tracker.conf配置文件
base_path=/tracker
启动服务
# fdfs_trackerd tracker.conf


配置storage服务器
192.168.1.2和192.168.1.3 修改/etc/fdfs/storage.conf配置文件
group_name=group1
base_path=/storage
store_path0=/storage
tracker_server=192.168.1.1:22122

192.168.1.10修改/etc/fdfs/storage.conf配置文件
group_name=group2
base_path=/storage
store_path0=/storage
tracker_server=192.168.1.1:22122

启动storage服务
# fdfs_storaged storage.conf
data path: /storage/data, mkdir sub dir...
mkdir data path: 00 ...
mkdir data path: 01 ...
mkdir data path: 02 ...
mkdir data path: 03 ...

......
mkdir data path: FE ...
mkdir data path: FF ...
data path: /storage/data, mkdir sub dir done.




环境已经搭建完成,现在在192.168.1.1 Tracker服务器上进行测试。
修改/etc/fdfs/client.conf 配置文件
base_path=/tmp/fastdfs
tracker_server=192.168.1.1:22122

执行命令上传文件
# fdfs_upload_file client.conf /root/jquery-easyui-1.4.zip
group1/M00/00/00/wKgBA1QnlouAcPe0AAu0LAhS8cw4.4.zip



从返回的信息看,文件已经上传到group1的指定位置,
group1的存储服务器192.168.1.2和192.168.1.3的/storage/data/00/00路径下可以找到该文件。

如果需要下载文件,可以使用如下命令


Tracker的配置文件/etc/fdfs/tracker.conf的store_lookup参数

# the method of selecting group to upload files
# 0: round robin
# 1: specify group
# 2: load balance, select the max free space group to upload file
store_lookup=0

0表示轮调算法,1表示指定group,2表示负载均衡,找剩余空间最大的group
如果选择1,则还需要指定store_group参数.
# which group to upload file
# when store_lookup set to 1, must set store_group to the group name
store_group=group2

admin 发表于 2016-4-15 17:32

以上搭建FastDFS使用的版本是v4.05。
这个版本已经比较旧了

最新的版本是v5.04,由于作者重构了代码,所以安装过程还是有一些不一致.
最新版本下载地址:http://sourceforge.net/projects/fastdfs/files/
安装可以参考压缩包内的INSTALL文件。

实验还是搭建一个FastDFS环境,并增加Nginx模块
所用软件:
FastDFS_v5.04.tar.gz
libfastcommon-master.zip
fastdfs-nginx-module_v1.16.tar.gz
nginx-1.6.2.tar.gz

与之前版本不同的是,v5.04首先需要安装libfastcommon
下载地址:https://github.com/happyfish100/libfastcommon.git

1.安装libfastcommon
在每一台服务器上,解压libfastcommon,进入libfastcommon-master目录执行
./make.sh
./make.sh install



可以看到libfastcommon.so安装到了/usr/lib64/libfastcommon.so

但是FastDFS主程序设置的lib目录是/usr/local/lib
所以需要创建软链接.
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


2.安装FastDFS主程序
这个版本似乎已经不需要libevent依赖
在每台服务器,解压缩FastDFS_v5.04.tar.gz,进入FastDFS目录
执行
./make.sh
./make.sh install
如果上步的软链接创建成功,就应该会非常顺利。

配置Tracker服务器(192.168.1.70)   
vim /etc/fdfs/tracker.conf文件,修改如下内容
base_path=/tracker
然后执行命令
fdfs_trackerd tracker.conf

配置Storage服务器(192.168.1.80,192.168.1.30)
vim /etc/fdfs/storage.conf
group_name=group1
base_path=/storage
store_path0=/storage
tracker_server=192.168.1.70:22122
然后执行命令
fdfs_storaged storage.conf


执行测试,修改Tracker服务器192.168.1.70的配置文件/etc/fdfs/client.conf
tracker_server=192.168.1.170:22122
执行命令
# fdfs_upload_file client.conf /home/nginx/FastDFS_v5.04.tar.gz
group1/M00/00/00/wKgBHlQvrQGARrS6AAU9tcFAzok.tar.gz


3.解压fastdfs-nginx-module
FastDFS通过Tracker服务器,将文件放在Storage服务器存储,
但是同组之间的服务器需要复制文件,有延迟的问题.
假设Tracker服务器将文件上传到了192.168.1.80,文件ID已经返回客户端,
这时,后台会将这个文件复制到192.168.1.30,如果复制没有完成,客户端就用这个ID在192.168.1.30取文件,肯定会出现错误
这个fastdfs-nginx-module可以重定向连接到源服务器取文件,避免客户端由于复制延迟的问题,出现错误。

修改fastdfs-nginx-module的config文件
原来的内容是
CORE_INCS="$CORE_INCS /usr/local/include/fastdfs /usr/local/include/fastcommon/"

vim /home/nginx/fastdfs-nginx-module/src/config,修改为
CORE_INCS="$CORE_INCS /usr/include/fastdfs /usr/include/fastcommon"

各个版本的位置并不统一.所以需要根据自己的版本修改位置。

来自:http://www.linuxidc.com/

页: [1]
查看完整版本: Linux下搭建FastDFS分布式存储环境