【架构设计】分布式文件系统 FastDFS的规律同装使用

本文地址

分享提纲:

  1.概述

  2. 原理

  3. 安装

  4. 使用

  5. 参阅文档

 

1. 概述


 

  1.1)【广泛文件系统】

    Google了一下,流行的开源分布式文件系统有成千上万,介绍如下:

 

    – mogileFS:Key-Value型元文件系统,不支持FUSE,应用程序访问它经常得API,主要为此当web领域处理海量小图,效率比mooseFS高多。

    – fastDFS:国人 余庆老师(GitHub)在mogileFS的基本功及开展改善的key-value型文件系统,同样未支持FUSE,提供于mogileFS更好的性质。

    – mooseFS:支持FUSE,相对比轻量级,对master服务器出单点依赖,用perl编写,性能相对比差,国内用之人头于多

    – glusterFS:支持FUSE,比mooseFS庞大

    – ceph:支持FUSE,客户端就跻身了linux-2.6.34内核,也就是说可以像ext3/rasierFS一样,选择ceph为文件系统。彻底的分布式,没有单点依赖,用C编写,性能比好。基于不熟之btrfs,其自己吗特别勿熟。

    – lustre:Oracle公司之铺级产品,非常巨大,对内核和ext3纵深依赖

    – NFS:老牌网络文件系统,具体不打听,反正NFS最近几乎年没有发展,肯定不克为此

 

  1.2)【fastDFS】

    FastDFS是一个开源的轻量级分布式文件系统,它对文件进行保管,功能包括:文件存储、文件并、文件访问(文件上传、文件下载)等,解决了充分容量存储和负载均衡的题目。特别契合为文件呢载体的在线服务,如相册网站、视频网站等等。

 

 

2. 原理


  2.1)【三个角色】

  具体参见: 分布式文件系统FastDFS设计原理

  FastDFS
系统发生三个角色:跟踪服务器(Tracker Server)、存储服务器(Storage
Server)和客户端(Client)

  • Tracker Server:
    跟踪服务器,主要做调度工作,起及人均的意向;负责管理所有的 storage
    server
    跟 group,每个 storage 在起步后会接连 Tracker,告知自己所属 group
    等信息,并维持周期性心跳。
  • Storage Server:存储服务器,主要提供容量与备份服务;以 group
    为单位,每个 group 内足以来差不多大 storage server,数据交互备份。
  • Client:客户端,上传下载数据的服务器,也不怕是我们和好之路所安排在的服务器。

Oracle 1

 

  2.2)
上传下载以及一块文件简述

  大概达到传流程就是客户端发送上传请求到Tracker Server服务器,接着Tracker Server服务器分配groupStorage Server,当然就是发生一定规则的,选择好Storage Server后再次因早晚规则选择仓储在这个服务器会变动一个file_id,这个file_id 包含字段包括:storage
server ip、文件创建时间、文件大小、文件 CRC32
校验码和随机数;每个存储目录下有个别单 256 * 256
个子目录,后止你晤面知晓一个Storage Server储存目录下起成千上万只文件夹的,storage
会按文件file_id进行有限浅 hash
,路由于到中一个子目录,然后将文件存储到该子目录下,最后生成文书路径:group
名称、虚拟磁盘路径、数据两级目录、file_id和文书后缀就是一个一体化的公文地点。
也许本身懂的吧无是生绝望,下载、同步操作我未写了,这里来平等篇稿子 分布式文件系统FastDFS设计原理 讲解的深详细,我不怕非班门弄斧了,大家好点击去看看。

 

  

3. 安装


  

源码下载:http://code.google.com/p/fastdfs

谋求救助:http://www.csource.org

笔者 余庆老师(GitHub)

实际装教程见 :FastDFS
安装以及使用

        及 【好】分布式文件系统 – FastDFS
在 CentOS
下安排安装配备

  3.1)【安装libevent】

Oracle 2Oracle 3

fastDFS需要安装libevent比较新的版本,将本机的比较低的版本卸载了。

rpm -qa libevent
libevent-1.4.13-1.el6.x86_64
rpm -e --nodeps libevent
安装一个最新稳定版

wget https://github.com/downloads/libevent/libevent/libevent-2.0.18-stable.tar.gz
tar zxvf libevent-2.0.18-stable.tar.gz
cd libevent-2.0.18-stable
./configure
make && make install
为libevent创建软链接到/lib库下,64位系统对应/lib64

ln -s /usr/local/lib/libevent* /lib/
ln -s /usr/local/lib/libevent* /lib64/

安装libevent

  

  3.2)【安装FastDFS】

Oracle 4Oracle 5

wget http://fastdfs.googlecode.com/files/FastDFS_v3.06.tar.gz
tar zxvf FastDFS_v3.06.tar.gz
cd FastDFS
./make.sh
./make.sh install

安装FastDFS

  

  3.3)【配置FastDFS】 

 

Oracle 6Oracle 7

环境:
tracker server
192.168.1.5
storage server
192.168.1.51
192.168.1.52

1、配置并启动 tracker server
①配置 tracker.conf

mkdir /data/fastdfs
vim /etc/fdfs/tracker.conf
base_path=/data/fastdfs
②启动 tracker

/usr/local/bin/fdfs_trackerd /etc/fdfs/tracker.conf
③开机启动

vim /etc/rc.local
/usr/local/bin/fdfs_trackerd /etc/fdfs/tracker.conf
2、配置并启动 storage server
①配置 tracker.conf

mkdir /data/fastdfs
mkdir /data/images
vim /etc/fdfs/storage.conf
base_path=/data/fastdfs
store_path0=/data/images
tracker_server=192.168.1.5:22122
②启动 tracker

/usr/local/bin/fdfs_storage /etc/fdfs/storage.conf
③开机启动

vim /etc/rc.local
/usr/local/bin/fdfs_storage /etc/fdfs/storage.conf
3、为storage节点安装fastdfs-nginx-module模块
①安装模块
安装Nginx详见:
需重新编译Nginx

wget http://fastdfs.googlecode.com/files/fastdfs-nginx-module_v1.10.tar.gz
tar zxvf fastdfs-nginx-module_v1.10.tar.gz
wget http://nginx.org/download/nginx-1.2.0.tar.gz
tar zxvf nginx-1.2.0.tar.gz
cd nginx-1.2.0
./configure --prefix=/usr/local/nginx --add-module=../fastdfs-nginx-module/src
make && make install
cd ..
②配置
编辑nginx.conf

vim /usr/local/nginx/conf/nginx.conf
server {
    listen       80;
    server_name  localhost;

    location /M00 {
        alias /datata;
        ngx_fastdfs_module;
    }
    ......
}
给 storage 的存储目录做一个软连接

ln -s /datata/ /datata/M00
拷贝mod_fastdfs.conf 到 /etc/fdfs/

cp fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/
vim /etc/fdfs/mod_fastdfs.conf
base_path=/data/fastdfs
tracker_server=192.168.1.5:22122
store_path0=/data/images
启动nginx

/usr/local/nginx/sbin/nginx

配置FastDFS

 

 

4. 使用


  4.1)【具体以】

 

Oracle 8Oracle 9

1、上传文件
FastDFS安装包中,自带了客户端程序,通过程序可以进行文件上传。在使用这个客户端程序之前,首先需要配置client.conf,然后再进行文件上传及下载。
在tracker上修改客户端配置文件client.conf

vim /etc/fdfs/client.conf
base_path=/data/fastdfs
tracker_server=192.168.1.5:22122
vim a.html
This Is FastDFS Test.
上传文件

/usr/local/bin/fdfs_test /etc/fdfs/client.conf upload a.html
This is FastDFS client test program v3.06

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-04-29 12:42:53] INFO - base_path=/data/tracker, 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.1.51, port=23000
server 2. group_name=group1, ip_addr=192.168.1.52, port=23000

group_name=group1, ip_addr=192.168.1.51, port=23000
storage_upload_by_filename
group_name=group1, remote_filename=M00/00/00/wKgBM0-cxs32qFyYAAAADigvbpc90.html
source ip address: 192.168.1.51
file timestamp=2012-04-29 12:42:53
file size=14
file crc32=674197143
file url: http://192.168.1.5/group1/M00/00/00/wKgBM0-cxs32qFyYAAAADigvbpc90.html
storage_upload_slave_by_filename
group_name=group1, remote_filename=M00/00/00/wKgBM0-cxs32qFyYAAAADigvbpc90_big.html
source ip address: 192.168.1.51
file timestamp=2012-04-29 12:42:53
file size=14
file crc32=674197143
file url: http://192.168.1.5/group1/M00/00/00/wKgBM0-cxs32qFyYAAAADigvbpc90_big.html
上传成功
试试用

http://192.168.1.51/M00/00/00/wKgBM0-cxs32qFyYAAAADigvbpc90_big.html

访问看看吧。

实际以

 

 

 

5. 参考文档


  5.1) 分布式文件系统 –
FastDFS 简单了解一下

  5.2) 分布式文件系统FastDFS设计原理

  5.3) FastDFS
安装以及采取

  5.4) 【好】 分布式文件系统 – FastDFS 配置 Nginx
模块和上污染测试
 

 

 

 

相关文章