FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储、文件同步、文件访问(文件上传、文件下载)等,解决了大容量存储和负载均衡的问题。特别适合以文件为载体的在线服务。(百科)

本文详细介绍了FastDFS在centos系统上的详细安装过程,在从机上使用了nginx实现了http的访问请求,我们开始吧。。(转载请标明,谢谢)

fdfs工具包下载地址http://pan.baidu.com/s/1eQHCSJw

使用winscp将工具包复制到服务器中

1、节点和关闭服务(关闭防火墙)

sudo service iptables stop

sudo chkconfig iptables off

sudo vi /etc/selinux/config 修改 selinux=disable

2、开始安装 fastdfs,主机Tracker、从机storage安装方法一样

3、检查 gcc 编译器系统中是否安装

sudo yum install -y gcc gcc-c++

4、FastDFS_v5.05依赖libfastcommon,不再依赖libevent。

5、安装libfastcommon

(1)安装unzip包,将libfastcommon解压到/usr/local下

sudo yum install -y unzip zip

sudo unzip libfastcommon-1.0.7.zip -d /usr/local

(2)编译并运行

cd /usr/local/libfastcommon-1.0.7

sudo ./make.sh

sudo ./make.sh install

由于FastDFS主程序设置的lib目录是/usr/local/lib,所以需要创建软链接.

sudo ln -s /usr/lib64/libfastcommon.so /usr/local/lib/libfastcommon.so

sudo ln -s /usr/lib64/libfastcommon.so /usr/lib/libfastcommon.so

sudo ln -s /usr/lib64/libfdfsclient.so /usr/local/lib/libfdfsclient.so

sudo  ln -s /usr/lib64/libfdfsclient.so /usr/lib/libfdfsclient.so

6、安装FastDFS

(1)解压FastDFS至 /usr/local

  sudo tar -zxvf FastDFS_v5.05.tar.gz -C /usr/local

(2)编译并安装

cd /usr/local/FastDFS

sudo ./make.sh

sudo ./make.sh install

安装完成,如果安装失败,检查一下软连接,主机从机都必须这样配置

7、配置Tracker和Storage

(1)Tracker,创建 tracker.conf

  cd /etc/fdfs/

  sudo cp tracker.conf.sample tracker.conf

   创建数据存储目录

  mkdir /mnt/fastdfs_tracker

  修改tracker.conf配置文件

  base_path=/mnt/fastdfs_tracker

  启动该配置文件

  fdfs_trackerd /etc/fdfs/tracker.conf

  

(2)Storage,创建 storage.conf

  cd /etc/fdfs/

sudo cp storage.conf.sample storage.conf

  创建数据存储目录

  sudo mkdir /mnt/fastdfs_storage_info

sudo mkdir /mnt/fastdfs_storage_data

  修改storage.conf配置文件

  base_path=/mnt/fastdfs_storage_info

  store_path0=/mnt/fastdfs_storage_data

tracker_server=主机IP:端口(默认22122)

第一次启动该配置文件(该动作有点慢耐心等待)

fdfs_storaged  /etc/fdfs/storage.conf

注:出错请查看日志:

cat /mnt/fastdfs_tracker/logs/tracker.log

cat /mnt/fastdfs_storage_info/logs/storage.log

telnet检查主从是否通信

http://jingyan.baidu.com/article/3c48dd34709e70e10be35835.html

使用fdfs_test /etc/fdfs/client.conf upload 1.png 测试fastdf有没有正常工作,正确显示如下图:

8、在storage上安装的nginx主要为了提供http的访问服务,同时解决group中storage服务器的同步延迟问题

(1)解压nginx插件fastdfs-nginx-module,以及依赖包 pcre、zlib

sudo tar -zxvf  FastDFS_v5.05.tar.gz -C /usr/local

sudo tar -zxvf  pcre-8.34.tar.gz -C /usr/local

sudo tar -zxvf  zlib-1.2.8.tar.gz -C /usr/local

(2)解压安装nginx

sudo tar -zxvf nginx-1.7.8.tar.gz -C /usr/local

sudo ./configure

--prefix=/usr/local/nginx --add-module=/usr/local/fastdfs-nginx-module/src     --with-pcre=/usr/local/src/pcre-8.34/ --with-zlib=/usr/local/src/zlib-1.2.8

(如果提示错误,可能缺少依赖的软件包,需先安装依赖包,再次运行./configure)

sudo make

sudo make install

9、将FastDFS的nginx插件模块的配置文件copy到FastDFS配置文件目录。

(1)cp/usr/local/fastdfs-nginx-module/src/mod_fastdfs.conf  /etc/fdfs/

(2)将fastdfs安装包中的http.conf、mime.types 两个文件拷贝到/etc/fdfs中

sudo cp /usr/local/FastDFS/conf/http.conf  /etc/fdfs/

sudo cp /usr/local/FastDFS/conf/mime.types  /etc/fdfs/

(3)编辑/usr/local/nginx/conf配置文件目录下的nginx.conf,设置添加storage信息并保存。

sudo vi /usr/local/nginx/conf/nginx.conf

将server段中的listen端口号改为8080:

listen       8080;

在server段中添加:

location ~/group1/M00 {

      root /mnt/fastdfs_storage_data;

ngx_fastdfs_module;

}

可以设置多个组,上面只设置了一个组‘group1’根据具体情况而定

location ~/group[1-3]/M00 {

      root /mnt/fastdfs_storage_data;

ngx_fastdfs_module;

}

(4)编辑/etc/fdfs配置文件目录下的mod_fastdfs.conf,设置storage信息并保存。

sudo vi /etc/fdfs/mod_fastdfs.conf

一般只需改动以下几个参数即可:

base_path=/fdfs/storage           #保存日志目录

tracker_server=主机IP:22122 #tracker服务器的IP地址以及端口号

storage_server_port=23000         #storage服务器的端口号

group_name=group1                 #当前服务器的group名

url_have_group_name = true        #文件url中是否有group名

store_path_count=1                #存储路径个数,需要和store_path个数匹配

store_path0=/fdfs/storage         #存储路径

http.need_find_content_type=true  #从文件扩展名查找文件类型(nginx时为true)

有的版本没有该选项不要管它

根据你上面设置的组个数设置

group_count = 1                  #设置组的个数

在末尾增加1个组的具体信息:(设置几组就添加几组)

[group1]

group_name=group1

storage_server_port=23000

store_path_count=1

store_path0=/mnt/fastdfs_storage_data

/*[group2]

group_name=group2

storage_server_port=23000

store_path_count=1

store_path0=/mnt/fastdfs_storage_data

[group3]

group_name=group3

storage_server_port=23000

store_path_count=1

store_path0=/mnt/fastdfs_storage_data*/

(5)建立M00至存储目录的软连接

sudo ln -s /mnt/fastdfs_storage_data  /mnt/fastdfs_storage_data/M00

测试软连接有没有设置成功

ll /fdfs/storage/data/M00

lrwxrwxrwx. 1 root root 19 3月  26 03:44 /fdfs/storage/data/M00 -> /fdfs/storage/data/

10、运行nginx

(1)运行nginx之前,先要把防火墙中对应的端口打开(本例中为8080)。

不是root用户都要sudo

[root@storage1 nginx-1.4.7]# iptables -I INPUT -p tcp -m state --state NEW -m tcp --dport 8080 -j ACCEPT

[root@storage1 nginx-1.4.7]# /etc/init.d/iptables save

(2)启动nginx,确认启动是否成功。(查看是否对应端口8080是否开始监听)

[root@storage1 nginx-1.4.7]# /usr/local/nginx/sbin/nginx

ngx_http_fastdfs_set pid=40638

[root@storage1 nginx-1.4.7]# netstat -unltp | grep nginx

tcp    0    0.0.0.0:8080            0.0.0.0:*              LISTEN      40639/nginx

也可查看nginx的日志是否启动成功或是否有错误。

[root@storage1 nginx-1.4.7]# cat /usr/local/nginx/logs/error.log

ngx_http_fastdfs_process_init pid=40640

[2014-03-26 03:47:17] INFO - local_host_ip_count: 2,  127.0.0.1  从机IP

[2014-03-26 03:47:17] INFO - fastdfs apache / nginx module v1.15, response_mode=proxy, base_path=/tmp, url_have_group_name=1, group_count=3, connect_timeout=2, network_timeout=30, tracker_server_count=1, if_alias_prefix=, local_host_ip_count=2, need_find_content_type=1, default_content_type=application/octet-stream, anti_steal_token=0, token_ttl=0s, anti_steal_secret_key length=0, token_check_fail content_type=, token_check_fail buff length=0, load_fdfs_parameters_from_tracker=1, storage_sync_file_max_delay=86400s, use_storage_id=0, storage server id count=0, flv_support=1, flv_extension=flv

[2014-03-26 03:47:17] (设置几组显示几组)

INFO - group 1. group_name=group1, storage_server_port=23000, path_count=1, store_path0=/mnt/fastdfs_storage_data

[2014-03-26 03:47:17]

INFO - group 2. group_name=group2, storage_server_port=23000, path_count=1, store_path0=/mnt/fastdfs_storage_data

[2014-03-26 03:47:17]

INFO - group 3. group_name=group3, storage_server_port=23000, path_count=1, store_path0=/mnt/fastdfs_storage_data

在error.log中没有错误,既启动成功。可以打开浏览器,直接访问http://从机:8080,查看是否弹出nginx欢迎页面。

查看从机上传的文件:

http://10.120.20.191:8080/group1/M00/00/00/wKgAOVWsnq-AOMfVAADroWmJH48190_big.png

FastDFS在centos上的安装配置与使用的更多相关文章

  1. MongoDB 3.2 在CentOS 上的安装和配置

    MongoDB 3.2 在CentOS 上的安装和配置   2016-01-06 14:41:41 发布 您的评价:       0.0   收藏     0收藏 一.安装 编辑/etc/yum.re ...

  2. CentOS 7.0安装配置Vsftp服务器

    一.配置防火墙,开启FTP服务器需要的端口 CentOS 7.0默认使用的是firewall作为防火墙,这里改为iptables防火墙. 1.关闭firewall: systemctl stop fi ...

  3. CentOS 6.6安装配置LAMP服务器(Apache+PHP5+MySQL)

    准备篇: CentOS 6.6系统安装配置图解教程 http://www.osyunwei.com/archives/8398.html 1.配置防火墙,开启80端口.3306端口 vi /etc/s ...

  4. CentOS 6.4安装配置LAMP服务器(Apache+PHP5+MySQL)

    这篇文章主要介绍了CentOS 6.4安装配置LAMP服务器(Apache+PHP5+MySQL)的方法,需要的朋友可以参考下 文章写的不错,很详细:IDO转载自网络: 准备篇: 1.配置防火墙,开启 ...

  5. CentOS 7.0安装配置LAMP服务器(Apache+PHP+MariaDB)

    CentOS 7.0默认使用的是firewall作为防火墙,这里改为iptables防火墙. 1.关闭firewall: systemctl stop firewalld.service #停止fir ...

  6. Cacti中文版在Centos上的安装

    最近老有人问Cacti中文版在哪下载啊怎么安装啊,我在这里一遍给大家讲解了:Cacti中文版在Centos上的安装 1.基本安装 cacti是运作在apache+php+mysql+net-snmp工 ...

  7. CentOS 6.x安装配置

    简述 VMware可以创建多个虚拟机,每个虚拟机上都可以安装各种类型的操作系统.安装方法也有很多种.下面,主要以ISO镜像安装为例,介绍CentOS 6.x的安装过程及相关的参数设置. 简述 创建虚拟 ...

  8. CentOS 6.3安装配置LAMP服务器(Apache+PHP5+MySQL)

    准备篇: 1.配置防火墙,开启80端口.3306端口 vi /etc/sysconfig/iptables -A INPUT -m state --state NEW -m tcp -p tcp -- ...

  9. CentOS 7.0安装配置Vsftp服务器步骤详解

    安装Vsftp讲过最多的就是在centos6.x版本中了,这里小编看到有朋友写了一篇非常不错的CentOS 7.0安装配置Vsftp服务器教程,下面整理分享给各位. 一.配置防火墙,开启FTP服务器需 ...

随机推荐

  1. js统计字符串中各种字符情况

    问题描述:在一个字符串中,统计出大写字母.小写字母.数字和其他字符各数.这个算法以前在学习java的时候,老师说过,而且说了四种算法.在孔乙己的世界里,茴香豆的"茴"字有四种写法嘛 ...

  2. 如何在HTML不同的页面中,共用头部与尾部?

    一.asp语言和PHP语言 首先制作一个头部文件head.asp,或者一个底部文件foot.asp.如主页是index.asp,调用头部代码是在index.asp文件代码的开始位置(第一个标记后面,& ...

  3. Unity4.6新UI系统初探(uGUI)

    一.引言 Unity终于在即将到来的4.6版本内集成了所见即所得的UI解决方案(视频).事实上从近几个版本开始,Unity就在为这套系统做技术扩展,以保证最终能实现较理想的UI系统.本文试图通过初步的 ...

  4. Flash Builder 找不到所需的 Adobe Flash Player

    经测试该方法可用! http://bbs.9ria.com/thread-108472-1-1.html 最近重装了系统,flash开发工具也由flex换成了flash builder.调试时就出现了 ...

  5. TestLink学习三:发送邮件的两种配置方法

    第一种:修改config.inc.php中的[smtp],配置为默认本地发送,用hotmail用户做接收,调试成功!(本人未尝试这种) // ----------------------------- ...

  6. sublime text2 常用快捷键

    1. ctrl+方向键  按单词移动 2. ctrl+shift + 方向键  按单词选取 3. ctrl + F3 查找选定的或光标所在单词 4. F3 查找特定的单词(一般查找的流程是先ctrl+ ...

  7. 第一章 初识MVC4

    1.MVC模式 Mvc将应用程序分离为三个部分: Model:是一组类,用来描述被处理的数据,同时也定义这些数据如何被变更和操作的业务规则.与数据访问层非常类似. View:是一种动态生成HTML的模 ...

  8. 【转】【Asp.Net】ASP.NET中自定义控件无法响应事件

    在自定义服务器控件中增加事件处理程序,但代码运行时没有错误,按钮点击下去却没有反应.应该如何处理呢?(本例中,该自定义控件包括一个Button,和一个Label,我希望用户点击了这个Button后,改 ...

  9. JS原生父子页面操作

    var api = frameElement.api;  //当前 W = api.opener;//父页面 W.setPerSel(jsonStr); api.close(); //关闭窗口 js操 ...

  10. Web API 实现JSONP或者安装配置Cors跨域

    前言 照理来说本节也应该讲Web API原理,目前已经探讨完了比较底层的Web API消息处理管道以及Web Host寄宿管道,接下来应该要触及控制器.Action方法,以及过滤器.模型绑定等等,想想 ...