由于网站使用nfs共享方式保存用户上传的图片,附件等资料,然后通过apache下载的方式供用户访问,在网站架构初期,使用这种简单的方式实现了静态资源的读写分离,但随着网站数据量的增加,图片服务器渐渐成为整个网站的短板,缘次催生了使用fastfds的想法,故而先进行一番简单的测试!在开始之前还是先来看看fastfds的介绍信息:

FastDFS is an open source high performance distributed file system (DFS). It's major functions include: file storing, file syncing and file accessing, and design for high capacity and load balancing.

FastDFS is an open source high performance distributed file system. It's major functions include: file storing, file syncing and file accessing (file uploading and file downloading), and it can resolve the high capacity and load balancing problem. FastDFS should meet the requirement of the website whose service based on files such as photo sharing site and vidio sharing site.

FastDFS has two roles: tracker and storage. The tracker takes charge of scheduling and load balancing for file access. The storage store files and it's function is file management including: file storing, file syncing, providing file access interface. It also manage the meta data which are attributes representing as key value pair of the file. For example: width=1024, the key is "width" and the value is "1024".

The tracker and storage contain one or more servers. The servers in the tracker or storage cluster can be added to or removed from the cluster by any time without affecting the online services. The servers in the tracker cluster are peer to peer.

The storarge servers organizing by the file volume/group to obtain high capacity. The storage system contains one or more volumes whose files are independent among these volumes. The capacity of the whole storage system equals to the sum of all volumes' capacity. A file volume contains one or more storage servers whose files are same among these servers. The servers in a file volume backup each other, and all these servers are load balancing. When adding a storage server to a volume, files already existing in this volume are replicated to this new server automatically, and when this replication done, system will switch this server online to providing storage services. When the whole storage capacity is insufficiency, you can add one or more volumes to expand the storage capacity. To do this, you need to add one or more storage servers.

The identification of a file is composed of two parts: the volume name and the file name.

大意为:
fastdfs是一个开源的,高性能的的分布式文件系统,他主要的功能包括:文件存储,同步和访问,设计基于高可用和负载均衡,fastfd非常适用于基于文件服务的站点,例如图片分享和视频分享网站

fastfds有两个角色:跟踪服务和存储服务,跟踪服务控制,调度文件以负载均衡的方式访问;存储服务包括:文件存储,文件同步,提供文件访问接口,同时以key value的方式管理文件的元数据

跟踪和存储服务可以由1台或者多台服务器组成,同时可以动态的添加,删除跟踪和存储服务而不会对在线的服务产生影响,在集群中,tracker服务是对等的

存储系统由一个或多个卷组成,卷与卷之间的文件是相互独立的,所有卷的文件容量累加就是整个存储系统中的文件容量。一个卷可以由一台或多台存储服务器组成,一个卷下的存储服务器中的文件都是相同的,卷中的多台存储服务器起到了冗余备份和负载均衡的作用。在卷中增加服务器时,同步已有的文件由系统自动完成,同步完成后,系统自动将新增服务器切换到线上提供服务。当存储空间不足或即将耗尽时,可以动态添加卷。只需要增加一台或多台服务器,并将它们配置为一个新的卷,这样就扩大了存储系统的容量。

下面几张图可以清楚的说明fastfds的架构和文件上传和下载流程等:

下面将介绍下fastdfs在rhel上的部署过程
tracker服务器:192.168.123.110/24
storage服务器:192.168.123.20/24

一:编译安装

  1. [root@db1 ~]# wget http://cloud.github.com/downloads/libevent/libevent/libevent-2.0.14
  2. -stable.tar.gz
  3. [root@db1 ~]# tar -zxvpf libevent-2.0.14-stable.tar.gz
  4. [root@db1 ~]# cd libevent-2.0.14-stable
  5. [root@db1 libevent-2.0.14-stable]# ./configure --prefix=/usr/local/libevent-2.0.14 &&
  6. make && make install
  7. [root@db1 ~]# wget http://fastdfs.googlecode.com/files/FastDFS_v3.02.tar.gz
  8. [root@db1 ~]# tar -zxvf FastDFS_v3.02.tar.gz
  9. [root@db1 ~]# cd FastDFS
  10. [root@db1 FastDFS]# grep -A 4 '/usr/local/FastDFS' make.sh
  11. TARGET_PREFIX=/usr/local/FastDFS
  12. TARGET_CONF_PATH=/etc/fdfs
  13. WITH_HTTPD=1
  14. WITH_LINUX_SERVICE=1
  15. [root@db1 FastDFS]# ./make.sh C_INCLUDE_PATH=/usr/local/libevent-2.0.14/include
  16. LIBRARY_PATH=/usr/local/libevent-2.0.14/lib
  17. [root@db1 FastDFS]# ./make.sh install
  18. [root@db1 FastDFS]# ls /etc/fdfs/
  19. client.conf  http.conf  mime.types  storage.conf  tracker.conf

二:tracker配置文件

  1. [root@db1 ~]# grep -v '^#' /etc/fdfs/tracker.conf |grep -v '^$'
  2. disabled=false
  3. bind_addr=192.168.123.110
  4. port=22122
  5. connect_timeout=30
  6. network_timeout=60
  7. base_path=/home/data/fastdfs
  8. max_connections=256
  9. work_threads=4
  10. store_lookup=2
  11. store_group=group2
  12. store_server=0
  13. store_path=0
  14. download_server=0
  15. reserved_storage_space = 4GB
  16. log_level=info
  17. run_by_group=
  18. run_by_user=
  19. allow_hosts=*
  20. sync_log_buff_interval = 10
  21. check_active_interval = 120
  22. thread_stack_size = 64KB
  23. storage_ip_changed_auto_adjust = true
  24. storage_sync_file_max_delay = 86400
  25. storage_sync_file_max_time = 300
  26. use_trunk_file = false
  27. slot_min_size = 256
  28. slot_max_size = 16MB
  29. trunk_file_size = 64MB
  30. http.disabled=false
  31. http.server_port=8080
  32. http.check_alive_interval=30
  33. http.check_alive_type=tcp
  34. http.check_alive_uri=/status.html
  35. http.need_find_content_type=true
  36. [root@db1 ~]# grep -v '^#' /etc/fdfs/http.conf  |grep -v '^$'
  37. http.default_content_type = application/octet-stream
  38. http.mime_types_filename=/etc/fdfs/mime.types
  39. http.anti_steal.check_token=false
  40. http.anti_steal.token_ttl=900
  41. http.anti_steal.secret_key=FastDFS1234567890
  42. http.anti_steal.token_check_fail=/home/data/fastdfs/conf/anti-steal.jpg

三:启动tracker服务,需要注意tracker.conf文件最后一行为#include httpd.conf

  1. [root@db1 ~]# /usr/local/FastDFS/bin/fdfs_trackerd /etc/fdfs/tracker.conf
  2. /usr/local/FastDFS/bin/fdfs_trackerd: error while loading shared libraries: libevent-
  3. 2.0.so.5: cannot open shared object file: No such file or directory
  4. [root@db1 ~]# echo '/usr/local/libevent-2.0.14/include/' >> /etc/ld.so.conf
  5. [root@db1 ~]# echo '/usr/local/libevent-2.0.14/lib/' >> /etc/ld.so.conf
  6. [root@db1 ~]# ldconfig
  7. [root@db1 ~]# /usr/local/FastDFS/bin/fdfs_trackerd /etc/fdfs/tracker.conf
  8. [2012-07-04 17:52:25] ERROR - file: tracker_func.c, line: 160, "/home/data/fastdfs"
  9. can't be accessed, error info: No such file or directory
  10. [root@db1 ~]# mkdir -p /home/data/fastdfs
  11. [root@db1 ~]# /usr/local/FastDFS/bin/fdfs_trackerd /etc/fdfs/tracker.conf
  12. [root@db1 ~]# echo $?
  13. 22
  14. [root@db1 ~]# cat  /home/data/fastdfs/logs/trackerd.log
  15. [2012-07-04 17:52:50] ERROR - file: ../common/fdfs_http_shared.c, line: 128, param
  16. "http.mime_types_filename" not exist or is empty
  17. [root@db1 ~]# tail -1 /etc/fdfs/tracker.conf
  18. #include http.conf
  19. [root@db1 ~]# /usr/local/FastDFS/bin/fdfs_trackerd /etc/fdfs/tracker.conf
  20. [root@db1 ~]# echo $?
  21. 0
  22. [root@db1 ~]# ps -ef |grep track
  23. root      3535     1  0 15:47 ?        00:00:00 /usr/local/FastDFS/bin/fdfs_trackerd
  24. /etc/fdfs/tracker.conf
  25. [root@db1 ~]# netstat -ntpl |grep fdfs
  26. tcp        0      0 192.168.123.110:22122       0.0.0.0:*                   LISTEN
  27. 3535/fdfs_trackerd
  28. tcp        0      0 192.168.123.110:8080        0.0.0.0:*                   LISTEN
  29. 3535/fdfs_trackerd

四:storage配置文件

  1. [root@db2 ~]# grep -v '^#' /etc/fdfs/storage.conf |grep -v '^$'
  2. disabled=false
  3. group_name=group1
  4. bind_addr=192.168.123.20
  5. client_bind=true
  6. port=23000
  7. connect_timeout=30
  8. network_timeout=60
  9. heart_beat_interval=30
  10. stat_report_interval=60
  11. base_path=/home/data/fastdfs
  12. max_connections=256
  13. buff_size = 256KB
  14. work_threads=4
  15. disk_rw_separated = true
  16. disk_rw_direct = false
  17. disk_reader_threads = 1
  18. disk_writer_threads = 1
  19. sync_wait_msec=50
  20. sync_interval=0
  21. sync_start_time=00:00
  22. sync_end_time=23:59
  23. write_mark_file_freq=500
  24. store_path_count=1
  25. store_path0=/home/data/fastdfs
  26. subdir_count_per_path=256
  27. tracker_server=192.168.123.110:22122
  28. log_level=info
  29. run_by_group=
  30. run_by_user=
  31. allow_hosts=*
  32. file_distribute_path_mode=0
  33. file_distribute_rotate_count=100
  34. fsync_after_written_bytes=0
  35. sync_log_buff_interval=10
  36. sync_binlog_buff_interval=10
  37. sync_stat_file_interval=300
  38. thread_stack_size=512KB
  39. upload_priority=10
  40. if_alias_prefix=
  41. check_file_duplicate=0
  42. key_namespace=FastDFS
  43. keep_alive=0
  44. http.disabled=false
  45. httphttp.domain_name=
  46. http.server_port=8888
  47. http.trunk_size=256KB
  48. http.need_find_content_type=true
  49. [root@db2 ~]# grep -v '^#' /etc/fdfs/client.conf  |grep -v '^$'
  50. connect_timeout=30
  51. network_timeout=60
  52. base_path=/home/data/fastdfs
  53. tracker_server=192.168.123.110:22122
  54. log_level=info
  55. http.tracker_server_port=8080
  56. [root@db2 ~]#  grep -v '^#' /etc/fdfs/http.conf |grep -v '^$'
  57. http.default_content_type = application/octet-stream
  58. http.mime_types_filename=mime.types
  59. http.anti_steal.check_token=false
  60. http.anti_steal.token_ttl=900
  61. http.anti_steal.secret_key=FastDFS1234567890
  62. http.anti_steal.token_check_fail=/home/data/fastdfs/conf/anti-steal.jpg

五:启动storage,需要注意storage.conf文件最后一行为#include httpd.conf

  1. [root@db2 ~]# mkdir -p /home/data/fastdfs
  2. [root@db2 ~]# echo '/usr/local/libevent-2.0.14/include/' >> /etc/ld.so.conf
  3. [root@db2 ~]# echo '/usr/local/libevent-2.0.14/lib/' >> /etc/ld.so.conf
  4. [root@db2 ~]# ldconfig
  5. [root@db2 ~]# tail -2 /etc/fdfs/storage.conf
  6. #use "#include" directive to include HTTP other settings
  7. #include http.conf
  8. [root@db2 ~]# /usr/local/FastFDS/bin/fdfs_storaged /etc/fdfs/storage.conf
  9. mkdir data path: 00 ...
  10. mkdir data path: 01 ...
  11. mkdir data path: 02 ...
  12. ———输出省略————
  13. data path: /home/data/fastdfs/data, mkdir sub dir done.
  14. [root@db2 ~]# ps -ef |grep fdfs
  15. root     14451     1  0 16:15 ?        00:00:00 /usr/local/FastFDS/bin/fdfs_storaged
  16. /etc/fdfs/storage.conf
  17. root     14468  8238  0 16:16 pts/1    00:00:00 grep fdfs
  18. [root@db2 ~]# netstat -ntpl |grep fdfs
  19. tcp        0      0 192.168.123.20:8888         0.0.0.0:*                   LISTEN
  20. 14451/fdfs_storaged
  21. tcp        0      0 192.168.123.20:23000        0.0.0.0:*                   LISTEN
  22. 14451/fdfs_storaged

五:测试文件上传

[root@db2 ~]# /usr/local/FastFDS/bin/fdfs_test /etc/fdfs/client.conf upload /etc/passwd
This is FastDFS client test program v3.02
Copyright (C) 2008, Happy Fish / YuQing
FastDFS may be copied only under the terms of the GNU General
Public License V3, which may be found in the FastDFS source kit.
Please visit the FastDFS Home Page http://www.csource.org/
for more detail.

[2012-07-30 16:25:59] INFO - base_path=/home/data/fastdfs, connect_timeout=30,

network_timeout=60, tracker_server_count=1, anti_steal_token=0, anti_steal_secret_key length=0 tracker_query_storage_store_list_without_group: 
server 1. group_name=group1, ip_addr=192.168.123.20, port=23000 group_name=group1, ip_addr=192.168.123.20, port=23000
storage_upload_by_filename
group_name=group1, remote_filename=M00/00/00/wKh7FFAWRRfcMOGtAAAHKBGhZhE8065783
source ip address: 192.168.123.20
file timestamp=2012-07-30 16:25:59
file size=1832
file crc32=295790097
file url: http://192.168.123.110:8080/group1/M00/00/00/wKh7FFAWRRfcMOGtAAAHKBGhZhE8065783
storage_upload_slave_by_filename
group_name=group1, remote_filename=M00/00/00/wKh7FFAWRRfcMOGtAAAHKBGhZhE8065783_big
source ip address: 192.168.123.20
file timestamp=2012-07-30 16:25:59
file size=1832
file crc32=295790097
file url: http://192.168.123.110:8080/group1/M00/00/00/wKh7FFAWRRfcMOGtAAAHKBGhZhE8065783_big

[root@db2 ~]# /usr/local/FastFDS/bin/fdfs_test /etc/fdfs/client.conf upload 2.jpg
This is FastDFS client test program v3.02
Copyright (C) 2008, Happy Fish / YuQing
FastDFS may be copied only under the terms of the GNU General
Public License V3, which may be found in the FastDFS source kit.
Please visit the FastDFS Home Page http://www.csource.org/
for more detail.

[2012-07-30 16:29:22] INFO - base_path=/home/data/fastdfs, connect_timeout=30, network_timeout=60, tracker_server_count=1, anti_steal_token=0, anti_steal_secret_key length=0 tracker_query_storage_store_list_without_group: 
server 1. group_name=group1, ip_addr=192.168.123.20, port=23000 group_name=group1, ip_addr=192.168.123.20, port=23000
storage_upload_by_filename
group_name=group1, remote_filename=M00/00/00/wKh7FFAWReLzPs4sAAEYquSDGwc472.jpg
source ip address: 192.168.123.20
file timestamp=2012-07-30 16:29:22
file size=71850
file crc32=3833797383
file url: http://192.168.123.110:8080/group1/M00/00/00/wKh7FFAWReLzPs4sAAEYquSDGwc472.jpg
storage_upload_slave_by_filename
group_name=group1, remote_filename=M00/00/00/wKh7FFAWReLzPs4sAAEYquSDGwc472_big.jpg
source ip address: 192.168.123.20
file timestamp=2012-07-30 16:29:22
file size=71850
file crc32=3833797383
file url: http://192.168.123.110:8080/group1/M00/00/00/wKh7FFAWReLzPs4sAAEYquSDGwc472_big.jpg

本文出自 “斩月” 博客,谢绝转载!

FastDFS介绍和配置过程的更多相关文章

  1. 分布式文件系统FastDFS介绍和配置过程

    http://ylw6006.blog.51cto.com/470441/948729/ 由于网站使用nfs共享方式保存用户上传的图片,附件等资料,然后通过apache下载的方式供用户访问,在网站架构 ...

  2. FastDFS介绍和配置过程 二

      最近在研究负载均衡和集群,其中涉及到一个主要问题是,如何让集群中的real server共享一套文件系统.在网上查到FastDFS,国人(happy fish,感谢他的开源精神)开发的一套轻量级分 ...

  3. FastDFS介绍和搭建(转载)

    FastDFS介绍和配置过程--http://blog.51cto.com/ylw6006/948729 FastDFS的五篇文章--http://www.cnblogs.com/smartycity ...

  4. FastDFS配置过程

    在我的生产环境中利用FastDFS实现动静分离的方案

  5. FastDFS的安装配置

    一:实验描述: fastdfs 介绍 FastDFS是一个开源的分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等,解决了大容量存储和负载均衡的问题.特别 ...

  6. FastDFS、nginx配置手记

    第一部分   FastDFS介绍 1.FastDFS是什么 FastDFS是一款类Google FS的开源分布式文件系统,它用纯C语言实现,支持Linux.FreeBSD.AIX等UNIX系统.它只能 ...

  7. synergy 两台Windows电脑配置过程

    Synergy 介绍 软件作用 Synergy 两台独立电脑,共享一套鼠标和键盘的工具, 软件原理(我自己想的) 保证两台电脑在一个局域网内,可以相互Ping通的电脑(这样才能直接通过TCP连接) 将 ...

  8. 图解MySQL5.5详细安装与配置过程

    MySQL是一个开源的关系型数据库管理系统,原由瑞典MySQL AB公司开发,目前属于Oracle公司旗下.MySQL是目前世界上开源数据库中最受欢迎的产品之一,是应用最为广泛的开源数据库.MySQL ...

  9. Win7上Git安装及配置过程

    Win7上Git安装及配置过程 文档名称 Win7上Git安装及配置过程 创建时间 2012/8/20 修改时间 2012/8/20 创建人 Baifx 简介(收获) 1.在win7上安装msysgi ...

随机推荐

  1. HtmlHelper扩展实例

    namespace System.Web.Mvc{    public static  class MyHttpHelperExt    { public static string MyLabel( ...

  2. 【codevs3160】最长公共子串 后缀数组

    题目描述 给出两个由小写字母组成的字符串,求它们的最长公共子串的长度. 输入 读入两个字符串 输出 输出最长公共子串的长度 样例输入 yeshowmuchiloveyoumydearmotherrea ...

  3. Qt——设计颜色编辑选取对话框

    Qt中已经有一些封装好的对话框,比如QMessageBox.QColorDialog等,使用起来快捷方便,但缺点是我们无法为它们自定义样式,所以可能难以“融入”我们的项目.既然如此,那就自己做一个把. ...

  4. datepicker约束开始时间和结束时间

    datepicker约束开始时间和结束时间作用就是:选择要搜索的日期范围. <!DOCTYPE html> <html lang="en"> <hea ...

  5. (沒有介紹標準算法的)RMQ問題

    感謝杜哥代碼滋磁 //以下是廢話 RMQ (Range Minimum/Maximum Query)问题是指:对于长度为n的数列A,回答若干询问RMQ(A,i,j)(i,j<=n),返回数列A中 ...

  6. Python 源码剖析(三)【字符串对象】

    三.字符串对象 1.PyStringObject与PyString_Type 2.创建PyStringObject对象 3.Intern 机制 4.字符缓冲池 5.PyStringObject 效率相 ...

  7. bzoj2588: Spoj 10628. Count on a tree(树上第k大)(主席树)

    每个节点继承父节点的树,则答案为query(root[x]+root[y]-root[lca(x,y)]-root[fa[lca(x,y)]]) #include<iostream> #i ...

  8. 【贪心】【UVA10905】 Children's Game

    传送门 Description 给定n个正整数,求他们相连接后能形成的最大整数.例如:12,23这两个数能连接的最大数是2312,. Input 多组数据,每组数据中: 第一行为一个整数n 第二行有n ...

  9. JavaScript时间戳与其格式化

    在 PHP + MySQL (日期类型为datetime) + ajax 应用中,有时候需要用 JavaScript 将时间戳类型格式化为一般的时间类型格式.下面提供一些转换的方法,比较常见的一些总结 ...

  10. 警惕!Unity3D中UnityEngine.Object的一个小陷阱

    先看看如下C#的脚本代码: 猜猜控制台打出来的是什么? In the bool parameter function, value info is:  True 肯定出乎很多人的意料吧? transf ...