Linux搭建分布式文件服务器-FastDFS并配置Nginx和fastdfs-nginx-module

Linux搭建分布式文件服务器-FastDFS

  • Linux搭建分布式文件服务器-FastDFS
    • 1.什么是FastDFS
    • 2.文件上传流程
    • 3.文件下载流程
    • 4. 简易FastDFS架构
    • 5.FastDFS安装
      • 5.1 安装fastdfs依赖包
      • 5.2 安装fastdfs
      • 5.3 配置跟踪服务器tracker
      • 5.4 配置存储服务器storage
      • 5.5 启动tracker 和 storage
      • 5.6 测试是否安装成功
      • 5.7 安装nginx及fastdfs-nginx-module

Linux搭建分布式文件服务器-FastDFS

需准备材料:

  1. libfastcommon-master
  2. fastdfs-nginx-module-master
  3. fastdfs-master
  4. nginx
    下载资源包:https://download.csdn.net/download/Jeman_Yao/12948918
    大多数公司开发时可能涉及到大量的文件读写,为了提高效率和安全性,大多数开发会选择单独的文件服务器作为文件存储,如云端的七牛云存储等,也有些会自己搭建私有的文件服务器,例如Hadoop分布式文件系统以及本次使用的 FastDFS文件服务器 ,欢迎指导。

1.什么是FastDFS

FastDFS 是用 c 语言编写的一款开源的分布式文件系统。FastDFS 为互联网量身定制, 充分考虑了冗余备份、负载均衡、线性扩容等机制,并注重高可用、高性能等指标,使用 FastDFS 很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务:

  1. FastDFS 架构包括 Tracker serverStorage server 。客户端请求 Tracker server 进行文 件上传、下载,通过 Tracker server 调度最终由 Storage server 完成文件上传和下载;

  2. Tracker server 作用是 负载均衡和调度 ,通过 Tracker server 在文件上传时可以根据一些策略找到 Storage server 提供文件上传服务。可以将 tracker 称为追踪服务器或调度服务器;

  3. Storage server 作用是文件存储,客户端上传的文件最终存储在 Storage 服务器上, Storageserver 没有实现自己的文件系统而是利用操作系统 的文件系统来管理文件。可以将 storage 称为 存储服务器 Linux搭建分布式文件服务器-FastDFS并配置Nginx和fastdfs-nginx-module_第1张图片

  4. Tracker:管理集群,tracker 也可以实现集群。每个 tracker 节点地位平等。收集 Storage 集群的状态。

  5. Storage:实际保存文件 Storage 分为多个组,每个组之间保存的文件是不同的。每 个组内部可以有多个成员,组成员内部保存的内容是一样的,组成员的地位是一致的,没有 主从的概念。;

2.文件上传流程

Linux搭建分布式文件服务器-FastDFS并配置Nginx和fastdfs-nginx-module_第2张图片

客户端上传文件后存储服务器将文件 ID 返回给客户端,此文件 ID 用于以后访问该文 件的索引信息。文件索引信息包括:组名,虚拟磁盘路径,数据两级目录,文件名。
组名,虚拟磁盘路径,数据两级目录,文件名

  1. 组名:文件上传后所在的 storage 组名称,在文件上传成功后有 storage 服务器返回, 需要客户端自行保存;
  2. 虚拟磁盘路径:storage 配置的虚拟路径,与磁盘选项 store_path*对应。如果配置了 store_path0 则是 M00,如果配置了 store_path1 则是 M01,以此类推;
  3. 数据两级目录:storage 服务器在每个虚拟磁盘路径下创建的两级目录,用于存储数据 文件;
  4. 文件名:与文件上传时不同。是由存储服务器根据特定信息生成,文件名包含:源存储 服务器 IP 地址、文件创建时间戳、文件大小、随机数和文件拓展名等信息

3.文件下载流程

Linux搭建分布式文件服务器-FastDFS并配置Nginx和fastdfs-nginx-module_第3张图片

4. 简易FastDFS架构

Linux搭建分布式文件服务器-FastDFS并配置Nginx和fastdfs-nginx-module_第4张图片
.

5.FastDFS安装

5.1 安装fastdfs依赖包

  1. 解压缩libfastcommon-master.zip;
  2. 进入到libfastcommon-master的目录中;
  3. 执行 ./make.sh;
  4. 执行 sudo ./make.sh install

5.2 安装fastdfs

  1. 解压缩fastdfs-master.zip
  2. 进入到 fastdfs-master目录中
  3. 执行 ./make.sh
  4. 执行 sudo ./make.sh install

5.3 配置跟踪服务器tracker

  1. sudo cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
  2. 在/usr/local目录中创建目录 fastdfs/tracker
    mkdir –p /usr/local/fastdfs/tracker
  3. 编辑/etc/fdfs/tracker.conf配置文件 sudo vim /etc/fdfs/tracker.conf
    修改 base_path=/usr/local/fastdfs/tracker

5.4 配置存储服务器storage

  1. sudo cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf
  2. 在/usr/localfastdfs/ 目录中创建目录 storage
    mkdir –p /usr/localfastdfs/storage
  3. 编辑/etc/fdfs/storage.conf配置文件 sudo vim /etc/fdfs/storage.conf
    修改内容:
    base_path=/usr/local/fastdfs/storage
    store_path0=/usr/local/fastdfs/storage
    tracker_server=ip地址:22122

5.5 启动tracker 和 storage

sudo service fdfs_trackerd start
sudo service fdfs_storaged start
如果提示Failed to start fdfs_trackerd.service: Unit fdfs_trackerd.service not found.错误、则可以通过/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf start和/usr/bin/fdfs_storaged /etc/fdfs/storage.conf start命令启动tracker和storage服务、启动完成之后通过ps aux | grep fdfs命令查看tracker和storage进程。

5.6 测试是否安装成功

  1. sudo cp /etc/fdfs/client.conf.sample /etc/fdfs/client.conf
  2. 编辑/etc/fdfs/client.conf配置文件 sudo vim /etc/fdfs/client.conf
    修改内容:
    base_path=/usr/local/fastdfs/tracker
    tracker_server=ip地址:22122
  3. 上传文件测试:
    fdfs_upload_file /etc/fdfs/client.conf 要上传的图片文件
    如果返回类似group1/M00/00/00/rBIK6VcaP0aARXXvAAHrUgHEviQ394.jpg的文件id则说明文件上传成功

如果出现一下错误,检查:1.安全组是否开放了23000和22122端口;2.尝试关闭防火墙;3.配置5.4.3及5.6.2步骤时IP改为内网IP

ERROR - file: connection_pool.c, line: 130, connect to 122.52.29.222:22122 fail, errno: 110, error info: Connection timed out
   上传文件:/usr/bin/fdfs_upload_file  <config_file> <local_filename>
   下载文件:/usr/bin/fdfs_download_file <config_file> <file_id> [local_filename]
   删除文件:/usr/bin/fdfs_delete_file <config_file> <file_id>

5.7 安装nginx及fastdfs-nginx-module

  1. 解压缩 nginx-1.8.1.tar.gz
  2. 解压缩 fastdfs-nginx-module-master.zip
  3. 进入nginx-1.8.1目录中
  4. 执行
    sudo ./configure --prefix=/usr/local/nginx/ --add-module=fastdfs-nginx-module-master解压后的目录的绝对路径/src
    路径展示
    // 此处报错可尝试安装以下程序,centos采用yum -y debian采用apt-get
    yum -y install pcre-devel
    yum -y install zlib-devel
    yum -y install openssl openssl-devel
    
    sudo make
    sudo make install
    // 此处如果报错未找到make可尝试安装以下程序,centos采用yum -y debian采用apt-get
    yum -y install gcc make
    apt-get install gcc make
    
  5. sudo cp fastdfs-nginx-module-master解压后的目录中src下的mod_fastdfs.conf /etc/fdfs/mod_fastdfs.conf
  6. sudo vim /etc/fdfs/mod_fastdfs.conf
    修改内容:
    connect_timeout=10
    tracker_server=ip地址:22122
    url_have_group_name=true
    store_path0=/usr/local/fastdfs/storage
  7. sudo cp 解压缩的fastdfs-master目录中的http.conf /etc/fdfs/http.conf
  8. sudo cp 解压缩的fastdfs-master目录中的mime.types /etc/fdfs/mime.types
  9. sudo vim /usr/local/nginx/conf/nginx.conf
    在http部分中添加配置信息如下:
    server {
    listen 8888;
    server_name localhost;
    location ~/group[0-9]/ {
    ngx_fastdfs_module;
    }
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
    root html;
    }
    }
  10. 启动nginx
    sudo /usr/local/nginx/sbin/nginx
  11. 测试
    在浏览器中输入
    http://(服务器ip):8888/group1/M00/00/00/rBIK6VcaP0aARXXvAAHrUgHEviQ394.jpg(此处改成测试上传时返回的文件id)
    正常打开文件则安装成功

你可能感兴趣的:(分布式,linux)