1、安装gcc(编译时需要)
FastDFS是C语言开发,安装FastDFS需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc
1 | yum install -y gcc gcc-c++ |
2、安装libevent(运行时需求)
若安装了桌面图形界面,就不需要安装;FastDFS依赖libevent库;
1 | yum -y install libevent |
3、 安装libfastcommon
libfastcommon是FastDFS官方提供的,libfastcommon包含了FastDFS运行所需要的一些基础库。
(1)上传 libfastcommonV1.0.7.tar.gz到Centos机器上;
(2)将 libfastcommonV1.0.7.tar.gz解压至/usr/local/下:
1 | tar -zxvf libfastcommonV1.0.7.tar.gz -C /usr/local/ |
(3)切换目录到:/usr/local/libfastcommon-1.0.7/ 下,接着进行编译和安装;
1 | cd /usr/local/libfastcommon-1.0.7/ |
(4)libfastcommon安装好后会在/usr/lib64 目录下生成 libfastcommon.so 库文件;
注意:由于FastDFS程序引用usr/lib目录所以需要将/usr/lib64下的库文件拷贝至/usr/lib下。
1 | cp libfastcommon.so /usr/lib |
4、安装tracker
(1)上传 FastDFS_v5.05.tar.gz 到 centos 上;
(2)将FastDFS_v5.05.tar.gz 解压至/usr/local/下
1 | tar -zxvf FastDFS_v5.05.tar.gz -C /usr/local |
(3)切换目录到: /usr/local/FastDFS/ 下,编译和安装;
1 | cd /usr/local/FastDFS/ |
(4)安装成功将安装目录下的conf下的文件拷贝到/etc/fdfs/下;
1 | cp /usr/local/FastDFS/conf/* /etc/fdfs/ |
5、配置和启动tracker
(1)切换目录到: /etc/fdfs/ 目录下;
(2)拷贝一份新的tracker配置文件
1 | cp tracker.conf.sample tracker.conf |
(3)修改tracker.conf ; vim tracker.conf
1 | base_path=/home/yuqing/fastdfs 改为: base_path=/home/fastdfshttp.server_port 改为: 80 |
(4)创建 /home/fastdfs 目录
1 | mkdir /home/fastdfs |
(5)启动tracker,运行如下命令:
1 | /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart |
**注意:在/home/fastdfs/ 目录下生成两个目录, 一个是数据,一个是日志; **
6、配置和启动storage
由于上面已经安装过FastDFS,这里只需要配置storage就好了;
(1)切换目录到: /etc/fdfs/ 目录下;
(2)拷贝一份新的storage配置文件
1 | cp storage.conf.sample storage.conf |
(3)修改storage.conf ; vim storage.conf
1 | group_name=group1 #配置组名 |
(4)创建 /home/fdfs_storage 目录
1 | mkdir /home/fdfs_storage |
(5)启动storage, 运行命令如下:
1 | /usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart |
启动完成后进入 /home/fdfs_storage/data 目录下,显示目录
1 | ls /home/fdfs_storage/data |
7、使用FastDFS自带工具测试(测试访问可能不成功,4.05版本移除基本的http服务,安装完nginx再测试访问)
(1)切换目录到 /etc/fdfs/ 目录下;
(2)拷贝一份新的client配置文件
1 | cp client.conf.sample client.conf |
(3)修改client.conf ; vim client.conf,修改基本路径和tracker_server如下:
1 | the base path to store log files |
(4)拷贝一张图片luzhouYue.jpg 到Centos服务器上的 /usr1 目录下;
(5)进行测试,运行如下:(运行测试程序,读取/etc/fdfs/client.conf 文件,上传/usr1目录下的luzhouYue.jpg文件)
1 | /usr/bin/fdfs_test /etc/fdfs/client.conf upload /usr1/luzhouYue.jpg |
以上图中的文件地址:http://192.168.172.20/group1/M00/00/00/wKisFFpBG9eAHaQvAAAWKd1hQR4158_big.jpg 对应storage服务器上的/home/fdfs_storage/data/00/00/wKisFFpBG9eAHaQvAAAWKd1hQR4158_big.jpg文件;
8、FastDFS 和nginx整合
8.1 在tracker上安装 nginx
在每个tracker上安装nginx,的主要目的是做负载均衡及实现高可用。如果只有一台tracker可以不配置nginx。
一个tracker对应多个storage,通过nginx对storage负载均衡;
8.2 在storage 上安装nginx
(1)上传 fastdfs-nginx-module_v1.16.tar.gz 到Centos服务器上;
(2)解压 fastdfs-nginx-module_v1.16.tar.gz 到 /usr/local目录下;
1 | tar -zxvf fastdfs-nginx-module_v1.16.tar.gz -C /usr/local |
(3)切换目录到: /usr/local/fastdfs-nginx-module/src/ 目录下
1 | cd /usr/local/fastdfs-nginx-module/src/ |
(4)修改config文件,将文件中的所有 /usr/local/ 路径改为 /usr/
修改前
1 | ngx_addon_name=ngx_http_fastdfs_module |
修改后
1 | ngx_addon_name=ngx_http_fastdfs_module |
把/usr/后的local全部删除 (三个)
(5)将fastdfs-nginx-module/src下的mod_fastdfs.conf拷贝至/etc/fdfs/下
1 | cp mod_fastdfs.conf /etc/fdfs/ |
(6)并修改 /etc/fdfs/mod_fastdfs.conf 的内容;vi /etc/fdfs/mod_fastdfs.conf
base_path=/tmp 修改为 base_path=/home/fastdfs
1 | base_path=/home/fastdfs |
(7)将libfdfsclient.so拷贝至/usr/lib下
1 | cp /usr/lib64/libfdfsclient.so /usr/lib/ |
(8)创建nginx/client目录
1 | mkdir -p /var/temp/nginx/client |
8.3 Nginx的安装
(1)上传 nginx-1.8.0.tar.gz 到Centos服务器上;
(2)解压 nginx-1.8.0.tar.gz 到 /usr/local目录下;
1 | tar -zxvf nginx-1.8.0.tar.gz -C /usr/local/ |
(3)安装nginx的依赖库
1 | yum install pcre |
(4)进入nginx解压的目录下:
1 | cd /usr/local/nginx-1.8.0/ |
(5)加入模块命令配置
1 | ./configure \ |
注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录;
(6)编译并安装
1 | make && make install |
(7)拷贝配置文件到 /etc/fdfs 下;
1 | cd /usr/local/FastDFS/conf |
(8)修改nginx配置文件
1 | mkdir /usr/local/nginx/logs # 创建logs目录 |
修改如下
1 | error_log logs/error.log; |
说明:
(a.) server_name指定本机ip;
(b.) location /group1/M00/:group1为nginx 服务FastDFS的分组名称,M00是FastDFS自动生成编号,对应store_path0=/home/fdfs_storage,如果FastDFS定义store_path1,这里就是M01
(9)nginx的启动
1 | cd /usr/local/nginx/sbin/ |
查询nginx进程
1 | ps -ef | grep nginx |
9、在浏览器中访问上传到fastDFS的图片
因为Centos系统有防火墙,需要先关闭掉,才可以在浏览器中访问;
(1)CentOS 7.0默认使用的是firewall作为防火墙;若没有启用iptables 作为防火墙,则使用以下方式关闭防火墙:
1 | systemctl stop firewalld.service #停止firewall |
(2)若已经启用iptables作为防火墙,则使用以下方式关闭:
1 | service iptables stop #临时关闭防火墙 |
(3)在谷歌浏览器中访问刚才上传的图片:
刚才上传的图片地址为:http://192.168.247.132/group1/M00/00/00/wKisFFpBG9eAHaQvAAAWKd1hQR4158_big.jpg