FastDFS+Nginx安装与配置

半兽人 发表于: 2016-02-22   最后更新时间: 2016-02-22  
  •   0 订阅,1643 游览

FastDFS+Nginx安装与配置

单独安装FastDFS已经ok,接下来在nginx配置FastDFS.
没有看过上一篇文章的,可以点击查看:FastDFS 分布式文件系统的安装与使用(单节点)

1、fastdfs-nginx-module 作用说明
      FastDFS 通过 Tracker 服务器,将文件放在 Storage 服务器存储,但是同组存储服务器之间需要进入 文件复制,有同步延迟的问题。假设 Tracker 服务器将文件上传到了 192.168.4.125,上传成功后文件 ID 已经返回给客户端。此时 FastDFS 存储集群机制会将这个文件同步到同组存储 192.168.4.126,在文件还 没有复制完成的情况下,客户端如果用这个文件 ID 在 192.168.4.126 上取文件,就会出现文件无法访问的 错误。而 fastdfs-nginx-module 可以重定向文件连接到源服务器取文件,避免客户端由于复制延迟导致的 文件无法访问错误。(解压后的 fastdfs-nginx-module 在 nginx 安装时使用)


2、上传 fastdfs-nginx-module_v1.16.tar.gz 到 /usr/local/src


3、解压

# cd /usr/local/src/
# tar -zxvf fastdfs-nginx-module_v1.16.tar.gz


4、修改 fastdfs-nginx-module 的 config 配置文件

# cd fastdfs-nginx-module/src
# vi config

CORE_INCS="$CORE_INCS /usr/local/include/fastdfs /usr/local/include/fastcommon/" 

修改为:

CORE_INCS="$CORE_INCS /usr/include/fastdfs /usr/include/fastcommon/"

(注意:这个路径修改是很重要的,不然在 nginx 编译的时候会报错的)


5、上传当前的稳定版本 Nginx(nginx-1.6.2.tar.gz)到/usr/local/src 目录


6、安装编译 Nginx 所需的依赖包
# yum install gcc gcc-c++ make automake autoconf libtool pcre* zlib openssl openssl-devel
7、编译安装 Nginx (添加 fastdfs-nginx-module 模块) 
# cd /usr/local/src/
# tar -zxvf nginx-1.6.2.tar.gz
# cd nginx-1.6.2
# ./configure --add-module=/usr/local/src/fastdfs-nginx-module/src
# make && make install
8、复制 fastdfs-nginx-module 源码中的配置文件到/etc/fdfs 目录,并修改
# cp /usr/local/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/ 
# vi /etc/fdfs/mod_fastdfs.conf

修改以下配置:
     connect_timeout=10
     base_path=/tmp
     tracker_server=192.168.4.121:22122
     storage_server_port=23000
     group_name=group1
     url_have_group_name = true
     store_path0=/home/yuqing/fastdfs


9、复制 FastDFS 的部分配置文件到/etc/fdfs 目录 

# cd /usr/local/src/FastDFS/conf
# cp http.conf mime.types /etc/fdfs/


10、在/fastdfs/storage 文件存储目录下创建软连接,将其链接到实际存放数据的目录 

# ln -s /fastdfs/storage/data/ /fastdfs/storage/data/M00
11、配置 Nginx


简洁版 nginx 配置样例: 

user root; worker_processes 1; events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       8888;
        server_name  localhost;
        location ~/group([0-9])/M00 {
            #alias /fastdfs/storage/data;
            ngx_fastdfs_module;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
root html; }
} }
A、8888 端口值是要与/etc/fdfs/storage.conf 中的 http.server_port=8888 相对应, 因为 http.server_port 默认为 8888,如果想改成 80,则要对应修改过来。
B、Storage 对应有多个 group 的情况下,访问路径带 group 名,如/group1/M00/00/00/xxx, 对应的 Nginx 配置为:
     location ~/group([0-9])/M00 {
         ngx_fastdfs_module;
}
C、如查下载时如发现老报 404,将 nginx.conf 第一行 user nobody 修改为 user root 后重新启动。


12、防火墙中打开 Nginx 的 8888 端口

# vi /etc/sysconfig/iptables
添加:
-A INPUT -m state --state NEW -m tcp -p tcp --dport 8888 -j ACCEPT # service iptables restart


13、启动 Nginx

# /usr/local/nginx/sbin/nginx
ngx_http_fastdfs_set pid=xxx
(重启 Nginx 的命令为:/usr/local/nginx/sbin/nginx -s reload)



14、通过浏览器访问测试时上传的文件
     http://192.168.4.125:8888/group1/M00/00/00/wKgEfVUYNYeAb7XFAAVFOL7FJU4.tar.gz


注意:千万不要使用kill -9命令强杀FastDFS进程,否则可能会导致binlog数据丢失。










发表于: 11月前   最后更新时间: 11月前   游览量:1643
上一条: FastDFS安装与使用(单节点)
下一条: 已经是最后了!
评论…

  • 评论…
    • in this conversation
      提问