fastDFS的介绍就不说了 想了解的人直接百度。
配置说明:
http://bbs.chinaunix.net/thread-1941456-1-1.html
//启动
tracker
1.0.4启动fastDFS
storage (
192.168.41.162
192.168.41.163)
2、测试上传
2.0.1 配置客户端上传文件 (192.168.41.160)
4、PHP客户端配置
<?php
开始吧
--------------------------------------------------
环境:
CentOS 6.3 x64 3台
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
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
//注意,改完前面有个#,不要全部去掉
/usr/local/bin/fdfs_trackerd /etc/fdfs/tracker.conf
//查看端口是否开启,看到22122 和8088就说明启动正常。如果没有,查看/www/
fastDFS/logs里的日志
netstat -tnlp
//创建目录,用于存储文件
。
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里的日志
//这个时候可以看下
storage与
tracker的连接情况
netstat -tnlpa| grep 22122
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
//看到类似上面的返回,说明文件已经成功上传。如果不是,说明配置出错了,查看日志。
//记录下这个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
把 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上面去请求
//当然,在另一个节点上也是可以访问的,手动更改url:
4.0.1 php拓展模块安装 (PHP端)
//php的客户端安装也会依赖 FastDFS本身的一些库文件,所以请保证已经安装了
FastDFS。
cd /root/
FastDFS/php_client/
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make
make install
cat fastdfs_client.ini >> /usr/local/php/etc/php.ini
//验证模块是否被正常加载
/usr/local/php/bin/php -m |grep fastdfs_client
//如果有返回,就说明成功。
cp ../conf//etc/fdfs/ /etc/fdfs/
vi /etc/fdfs//etc/fdfs/
把 14 行改成 tracker_server=192.168.41.160:22122
把 29 行改成 http.tracker_server_port=8088
//重启加载php
/usr/local/php/sbin/php-fpm reload
4.0.2 php拓展模块验证 (PHP端)
//随意创建个文件,上传用
echo 'php_upload_test' >/tmp/upload.txt
//创建个上传test.php 内容如下:
var_dump(function_exists('fastdfs_storage_upload_by_filename'));
$ret = fastdfs_storage_upload_by_filename('
/tmp/upload.txt
');
var_dump($ret);
?>
//执行:
/usr/local/php/bin/php test.php
//看到上面的返回,应该很熟悉吧,说明成功了。用浏览器访问下:
关于fastDFS php插件的使用方法和函数调用方法,可以查看/root/FastDFS/php_client/README