红联Linux门户
Linux帮助

Linux(CentOS 6.4_x86_64)搭建FastDFS文件服务器

发布时间:2015-04-04 16:07:19来源:linux网站作者:liang_love_java

我是参考下面的内容搭建的fastDFS文件服务器,连接的作者使用的是CentOS 6.3 x64,我的操作系统是CentOS 6.4_x86_64,参考连接内容都能搭建成功。

FastDFS_v4.04.tar.gz    http://fastdfs.googlecode.com/files/FastDFS_v4.04.tar.gz
fastdfs-nginx-module_v1.13.tar.gz  http://fastdfs.googlecode.com/files/fastdfs-nginx-module_v1.13.tar.gz
libevent-1.4.14b-stable.tar.gz  https://github.com/downloads/libevent/libevent/libevent-1.4.14b-stable.tar.gz
nginx-1.0.10.tar.gz  http://nginx.org/download/nginx-1.0.10.tar.gz
pcre-8.20.tar.gz  http://sourceforge.net/projects/pcre/files/pcre/8.20/pcre-8.20.tar.gz

tracker server  IP:192.168.41.160
storage server IP:192.168.41.162
storage server IP:192.168.41.163
PHP客户端IP:192.168.41.156


参考文章:
1、安装部署
1.0.1安装依赖包libevent (所有机器)
tar zxvf libevent-1.4.14b-stable.tar.gz
cd libevent-1.4.14b-stable
./configure --prefix=/usr/local/libevent
make
make install
 
1.0.2安装fastDFS (tracker、storage、php端都按照此方法) (所有机器)
tar zxvf FastDFS_v4.04.tar.gz
cd FastDFS
vi make.sh // tracker才需要,storage、php不用操作此步骤
//64行左右 删除#号开启WITH_HTTPD和WITH_LINUX_SERVICE
//开启自带的http,据说最新版已经取消自带的http功能
./make.sh C_INCLUDE_PATH=/usr/local/libevent/include LIBRARY_PATH=/usr/local/libevent/lib
./make.sh install
//到这里安装就完毕了
//可以看到fastDFS的相关配置文件
ls /etc/fdfs/
tracker.conf//负责均衡调度服务器配置文件
client.conf//客户端上传配置文件
http.conf//http服务器配置文件
storage.conf//文件存储服务器配置文件
mime.types//文件类型配置文件
 
1.0.3启动fastDFS tracker (192.168.41.160)
//创建目录,用于记录 tracker日志、storage server等信息。
mkdir -m 777 -p /www/fastDFS
//修改tracker.conf
vi /etc/fdfs/tracker.conf
把 22 行 改成 base_path=/www/fastDFS
把 222行 改成 http.server_port=8088 //如果本机没用到8080可以不修改
把 244行 改成 #include http.conf //注意,改完前面有个#,不要全部去掉

//启动tracker
/usr/local/bin/fdfs_trackerd /etc/fdfs/tracker.conf
//查看端口是否开启,看到22122 和8088就说明启动正常。如果没有,查看/www/fastDFS/logs里的日志
netstat -tnlp
Linux(CentOS 6.4_x86_64)搭建FastDFS文件服务器
 
1.0.4启动fastDFS storage (192.168.41.162 192.168.41.163)
//创建目录,用于存储文件。
mkdir -m 777 -p /www/fastDFS
//修改storage.conf
vi /etc/fdfs/storage.conf
把 33 行 改成 base_path=/www/fastDFS
把 100行 改成 store_path0=/www/fastDFS
把 109行 改成 tracker_server=192.168.41.160:22122//根据自己的IP
把 252行 改成 http.disabled=true //因为我们要用nginx了,这个就关闭它
把 259行 改成 http.server_port=80
//启动storage
/usr/local/bin/fdfs_storaged /etc/fdfs/storage.conf
//查看端口是否开启,看到23000就说明启动正常。如果没有,查看/www/fastDFS/logs里的日志
Linux(CentOS 6.4_x86_64)搭建FastDFS文件服务器
//这个时候可以看下storage与tracker的连接情况
netstat -tnlpa| grep 22122
Linux(CentOS 6.4_x86_64)搭建FastDFS文件服务器


2、测试上传
2.0.1 配置客户端上传文件 (192.168.41.160)
vi /etc/fdfs/client.conf
把 10 行 改成 base_path=/www/fastDFS
把 14 行 改成 tracker_server=192.168.41.160:22122//根据自己的IP
把 29 行 改成 http.tracker_server_port=8088//这个一定要跟tracker.conf里面配置的一样
把 32 行 改成 #include http.conf //注意,改完前面有个#,不要全部去掉
//随意上传个文件
echo 'fastDFS_test' >/tmp/test.txt
fdfs_test /etc/fdfs/client.conf upload /tmp/test.txt
Linux(CentOS 6.4_x86_64)搭建FastDFS文件服务器
//看到类似上面的返回,说明文件已经成功上传。如果不是,说明配置出错了,查看日志。
//记录下这个URL:http://192.168.41.160:8080/group1/M00/00/00/wKgpolFwG-WANaKzAAAADVt_Kt4300_big.txt


3、nginx配置
3.0.1 nginx拓展模块安装 (192.168.41.162 192.168.41.163)
//nginx的安装比较简单,这里不做解释
//曾经有过疑问,既然文件是直接被保持在storage服务器上,那直接用nginx就可以访问了,为什么还要添加这个模块?
//答:
//使用扩展模块来解决文件同步延迟问题
//如果请求文件在当前storage上不存在,通过文件ID反解出源storage,直接请求源storage
//tracker server上不需要任何web server
//在每台storage server上部署web server,直接对外提供HTTP服务
//目前已提供apache和nginx扩展模块
//推荐使用扩展模块方式
//假设nginx已经在系统被安装过。
tar zxvf fastdfs-nginx-module_v1.13.tar.gz
/usr/local/nginx/sbin/nginx -V
//运行后得到原来的编译参数,如:
// --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-openssl=/root/openssl-1.0.0d
cd nginx-1.0.10
./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-openssl=/root/openssl-1.0.0d --add-module=/root/fastdfs-nginx-module/src //fastdfs-nginx-module的路径根据自己的环境修改
make
make install
cp /root/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/
vi /etc/fdfs/mod_fastdfs.conf
把 3 行 改成connect_timeout=20 //默认2秒有点小,可改可不改
把 10行 改成base_path=/www/fastDFS/
把 40行 改成tracker_server=192.168.41.160:22122 ////根据自己的IP
把53行 改成 url_have_group_name = true //使用浏览器访问的时候,需要添加上组名称
把 62行 改成store_path0=/www/fastDFS
ln -s /www/fastDFS/data /www/fastDFS/data/M00
//编辑nginx.conf
vi /usr/local/nginx/conf/nginx.conf
//在server段添加如下内容:
location /group1/M00/ { alias /www/fastDFS/data/; ngx_fastdfs_module; }
/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -s stop
/usr/local/nginx/sbin/nginx
//这里直接用usr/local/nginx/sbin/nginx -s reload 有时候会出现nginx没办法访问。
3.0.2 nginx拓展模块验证 (192.168.41.162 192.168.41.163)
//用浏览器打开我们上面记录的URL:
//http://192.168.41.160:8080/group1/M00/00/00/wKgpolFwG-WANaKzAAAADVt_Kt4300_big.txt
//访问tracker 会被302跳转到一台可用的storage上面去请求
Linux(CentOS 6.4_x86_64)搭建FastDFS文件服务器
//当然,在另一个节点上也是可以访问的,手动更改url:
Linux(CentOS 6.4_x86_64)搭建FastDFS文件服务器
注:以上图片上传到红联Linux系统教程频道中。