公司原有的平台,使用传统的方式保存图片,在集群环境下,图片散落在不同的机器上,虽然通过各种同步机制去同步汇总,但是会有各类问题,比如延时,图片同步不成功等。于是考虑把图片服务抽象出来,单独部署,对各个子平台,提供restful接口,图片的储存,我们采用Fastdfs。
版本说明:
FastDFS 5.04
fastdfs_client_java_v1.24.tar
fastdfs-nginx-module_v1.16.tar
libfastcommon-1.0.7.tar
nginx-1.6.2.tar.gz
下载地址:
http://sourceforge.net/projects/fastdfs/files/
http://nginx.org/
与之前版本不同的是,v5.04首先需要安装libfastcommon
下载地址:https://github.com/happyfish100/libfastcommon.git
一. 首先安装libfastcommon
tar -zxvf libfastcommon-1.0.7.tar
cd libfastcommon-1.0.7
./make.sh
./make.sh install
但是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
二. 安装FastDFS主程序
tar -zxvf FastDFS_v5.04.tar.gz
cd FastDFS
./make.sh
./make.sh install
如果要修改fastdfs安装路径,编辑make.sh,修改TARGET_PREFIX 修改为 /usr/local/fastdfs
三. 配置tracker
cd /etc/fdfs
mv tracker.conf.sample tracker.conf
vi tracker.conf
修改 base_path=/usr/local/fastdfs_tracker ps:需新建该目录
启动tracker fdfs_trackerd /etc/fdfs/tracker.conf (restart,stop,start)
查看storage状态:fdfs_monitor /etc/fdfs/storage.conf | egrep "ip_addr|Storage|Group"
修改client配置 /etc/fdfs/client.conf
tracker_server=192.168.101.222:22122 这里配置的是tracker机器的ip
bath_path=/usr/local/fastdfs_tracker
四. 配置stroage
cd /etc/fdfs
mv storage.conf.sample storage.conf
vi storage.conf
修改
group_name=group1
base_path=/usr/local/fastdfs_storage ps:需新建该目录
store_path0=/usr/local/fastffs_storage
tracker_server=192.168.101.222:22122
创建软连接,在/storage目录下创建软连接,将其链接到实际存放数据的目录,
ln -s /usr/local/fastdfs_storage/data /usr/local/fastdfs_storage/M00
启动storage:fdfs_storaged /etc/fdfs/storage.conf
查看storage状态:fdfs_monitor /etc/fdfs/storage.conf | egrep "ip_addr|Storage|Group"
测试上传:fdfs_upload_file client.conf /root/soft/test.txt
fdfs_test /etc/fdfs/client.conf upload test.txt 另外一种测试方式
如果得到以下结果,说明Fastdfs成功保存了
http://192.168.101.222/group1/M00/00/00/wKhl3lRk1EyAP6gMAAAACsZ1ls8407.txt
五.storage上安装nginx和fastdfs module
解压module : tar -zxvf fastdfs-nginx-module_v1.16.tar.gz
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"
各个版本的位置并不统一.所以需要根据自己的版本修改位置。
复制fastdfs-nginx-module源码中的配置文件到/etc/fdfs
cp /root/soft/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs
修改该配置文件
group_name=group1
tracker_server=192.168.101.222:22122
store_path0=/usr/local/fastdfs_storage
base_path=/usr/local/fastdfs_storage
如果访问的时候,带group name ,需要修改/etc/fdfs/mod_fastdfs.conf set url_have_group_name = true
复制FastDFS的配置到/etc/fdfs : cp http.conf mime.types /etc/fdfs/
六. storege上nginx安装
nginx的安装比较简单,主要是要加上fastdfs module.
./configure \
--prefix=/usr/local/nginx \
--with-http_stub_status_module \
--with-http_ssl_module \
--add-module=/root/soft/fastdfs-nginx-module/src
然后就是make&& make install
最后配置nginx.conf,在里面加上:
root /usr/local/fastdfs_storage/data;
ngx_fastdfs_module;
}
nginx reload后,即可通过nginx来访问上传的图片了