FastDFS分布式文件系统

这个主要是针对应用型的,很使用,特别是对于电商等

一。编译安装

ubuntu平台:

apt-get install libevent(这个默认就有,没有就装下) libevent-dev

后面一个一定要记着装,否则会出现event.h找不到文件的错误

下载fastdfs

wget http://fastdfs.googlecode.com/files/FastDFS_v4.06.tar.gz

cd tar zxf FastDFS_v4.06.tar.gz

然后需要修改以下文件

make.sh   这个根据实际情况来修改 ,因为如果不该默认会报找不到pthread类的错误

if [ -f /usr/lib/x86_64-linux-gnu/libpthread.so ] || [ -f /usr/local/lib/libpthread.so ] || [ -f /lib64/libpthread.so ] || [ -f /usr/lib64/libpthread.so ] || [ -f /usr/lib/x86_64-linux-gnu/libpthread.a ] || [ -f /usr/local/lib/libpthread.a ] || [ -f /lib64/libpthread.a ] || [ -f /usr/lib64/libpthread.a ]; then

client/fdfs_link_library.sh.in 也是修改为相应路径

if [ "`id -u`" = "0" ]; then
  ln -fs $TARGET_LIB/libfastcommon.so.1 /usr/lib/x86_64-linux-gnu/libfastcommon.so
  ln -fs $TARGET_LIB/libfdfsclient.so.1 /usr/lib/x86_64-linux-gnu/libfdfsclient.so

if [ "$OS_BITS" = "8" ]; then
     ln -fs $TARGET_LIB/libfastcommon.so.1 /usr/lib/x86_64-linux-gnu/libfastcommon.so
     ln -fs $TARGET_LIB/libfdfsclient.so.1 /usr/lib/x86_64-linux-gnu/libfdfsclient.so
  fi
fi

然后sh make.sh   sh make.sh install完成安装

二,编译安装apache模块

下载

wget http://fastdfs.googlecode.com/files/fastdfs-apache-module_v1.15.tar.gz

tar zxf fastdfs-apache-module_v1.15.tar.gz

cd fastdfs-apache-module/src

修改Makefile

这里whereis查询相应的可执行文件路径,如果没有,cp一份过去都行,主要是会找不到build下面的special.mk,因为我的apache2是直接apt-get的

所以这里需要apt-get install apache2-dev

然后make && make install 就可以了

apache配置

vim /etc/fdfs/mod_fastdfs.conf

这里只需要tracker_server改为对应的ip

url_have_group_name 这个一定要注意,如果这里为false,则下面的apache配置里面也不能出现group_name,我这里该为了true

vim /etc/apache2/fastdfs.conf ,这个是在apache2.conf文件里面include进来的,所以实际上只需写在主体里面即可

<Location /group1/M00>
    sethandler fastdfs
</Location>

这里使用了组名,如果上面配置为false的话,这里就只能M00了

这样只要所有指向storeip的域名都能访问返回的url了,不光能用ip访问,域名也能访问,只要指向是正确的,这样就可以有file1.test.com file2.test.com了

三。编译php扩展

这个更加简单phpize ./configure make make install

然后把对应的.so文件载入即可

这里文章最后会把所有配置文件打包提供下载的,居然无法上传附件

四,用php实战

 <?php
$ret = fastdfs_storage_upload_by_filename('url.txt');
$ret1 = fastdfs_storage_upload_by_filename1('url.txt');
$file_info = fastdfs_get_file_info($ret['group_name'],$ret['filename']);
$file_info1 = fastdfs_get_file_info1($ret1);
header("Content-Disposition: attachment; filename= 重命名文件名.txt");
header("Content-Type: application/octet-stream");
header("X-Accel-Redirect: $file_info1"); //fdfs文件路径
header("X-Accel-Buffering: yes");
header("X-Accel-Limit-Rate :102400"); //速度限制 Byte/s
//header("Accept-Ranges: none");//单线程 限制多线程
var_dump($ret,$ret1,$file_info,$file_info1);

把原始文件名存入数据库,然后存入该文件的下载地址,也就是file_id,这个是唯一的,上面的代码就可以实现下载重命名,改为你想要的中文名

然后其它的使用函数可以看源码下面的php-client/README

CentOS平台比较简单,基本上都可以直接编译通过,nginx明白原理配置也一样。

最新文章

  1. stm32软件模拟IIC读取PX4FLOW光流传感器数据
  2. spring.xml命名空间
  3. 一款基于jQuery轮播切换焦点图,可播放多张图片
  4. ExcelApplication 另存Excel的SaveAs函数
  5. 《JavaScript 闯关记》之 BOM
  6. net use \\192.168.54.145 /user:administrator &quot;12345qwert&quot;无法连接,错误码1326
  7. Zepto源码分析-动画(fx fx_method)模块
  8. 深入理解HTTP协议—HTTP协议详解(真的很经典)
  9. HTML5能否会成为Web技术的核心?
  10. [LeetCode] Baseball Game 棒球游戏
  11. BZOJ4423 Bytehattan
  12. The threat to world
  13. goroutine和channel
  14. LwIP协议栈接口
  15. jQuery筛选总结
  16. 外网上传到NAS速度很慢是什么情况?上行1M都不到,但是测试有4M
  17. redis集群的ruby环境
  18. hibernate4.3.5,Final hibernate.cfg.xml的配置
  19. Linux火焰图-centos
  20. Mysql InnoDB 数据更新 锁表

热门文章

  1. java selenium手动最大化chrome浏览器的方法
  2. oracle scott趣事
  3. 函数的arguments
  4. mysql和eclipse连接jdbc驱动配置
  5. [ Java ] String 轉型 ArrayList
  6. 点击之后连接qq
  7. Python基础:编码
  8. Binary Agents FreeCodeCamp
  9. gazebo 7.0 升级到7.15 参考他人博客
  10. 路飞学城Python-Day59(第五模块复习题)