FastDFS安裝部署指南

一、系統環境搭建

此處已Ubuntu環境搭建爲示例。

1.1 安裝Ubuntu:

vmware安裝Ubuntu16.04英文版,網絡連接採用NAT模式,需檢測互相能夠ping通。

鏡像下載地址:

http://releases.ubuntu.com/16.04/ubuntu-16.04-desktop-amd64.iso 

1.2 安裝gcc:(編譯代碼)

sudo apt-get install build-essential
gcc --version   

1.3 安裝ssh:(遠程使用)

sudo apt-get install openssh-server
xshell 登入

1.4 安裝lrzsz:(互傳文件)

sudo apt-get install -y lrzsz
rz 彈窗       //上傳本地文件
sz file      //下載指定文件

二、FastDFS部署

上傳源碼到“/opt/src”目錄進行部署安裝。

2.1 安裝FastDFS:

程序會被安裝到“/usr/bin”目錄,配置文件位於“/etc/fdfs”目錄。

  • 安裝libfastcommon

    unzip libfastcommon-1.0.36.zip 或 tar xzf libfastcommon-1.0.36.tar.gz
    cd libfastcommon-1.0.36
    make
    make install
    
  • 再安裝fastdfs

    unzip fastdfs-5.11.zip 或 tar xzf fastdfs-5.11.tar.gz
    cd fastdfs-5.11
    make
    make install
    

2.2 配置FastDFS:

假定以下內容:

選項 參數
tracker地址 192.168.40.128:22122
storage地址 192.168.40.128:23000
數據存儲路徑 /opt/fastdfs
編組名稱 group1

到“/etc/fdfs”目錄拷貝.conf.sample文件爲.conf,修改以下配置:

  • tracker.conf

    base_path=/opt/fastdfs
    store_group=group1
    
  • storage.conf

    base_path=/opt/fastdfs
    group_name=group1
    tracker_server=192.168.40.128:22122
    store_path0=/opt/fastdfs
    http.server_port=8888
    
  • storage_ids.conf

    # <id>  <group_name>  <ip_or_hostname>
    100001   group1  192.168.40.128
    
  • client.conf

    base_path=/opt/fastdfs
    tracker_server=192.168.40.128:22122
    

2.3 啓動FastDFS:

  • 先啓動tracker

    /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart
    
  • 再啓動storage

    /usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart
    

2.4 測試FastDFS:

  • 上傳文件

    sudo fdfs_upload_file /etc/fdfs/client.conf /opt/src/fastdfs-5.11.png
    group1/M00/00/00/wKgogFohRKaAbfmfAAUkKwe5sE4.png
    
  • 下載文件

    sudo fdfs_download_file /etc/fdfs/client.conf group1/M00/00/00/wKgogFohRKaAbfmfAAUkKwe5sE4.png /opt/src/fastdfs.png
    

三、Nginx部署

fastdfs-nginx-module 可以重定向文件連接到源服務器取文件。需與storage同服務器部署。

3.1 解壓fastdfs-nginx-module:

cd /opt/src
unzip fastdfs-nginx-module-master.zip

3.2 安裝Nginx:

tar xzf nginx-1.13.7.tar.gz
cd nginx-1.13.7
./configure --add-module=/opt/src/fastdfs-nginx-module-master/src
make
make install

3.3 配置修改:

  • 複製fastdfs-nginx-module配置文件到”/etc/fdfs”目錄

    cp /opt/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/
    
  • 修改mod_fastdfs.conf

    connect_timeout=10
    base_path=/tmp
    tracker_server=192.168.40.128:22122
    storage_server_port=23000
    group_name=group1
    url_have_group_name = true
    store_path0=/opt/fastdfs
    
  • 複製fastdfs的部分文件到”/etc/fdfs”目錄

    cd /opt/src/fastdfs-5.11/conf
    cp http.conf mime.types /etc/fdfs/
    
  • 配置nginx.conf,位於”/usr/local/nginx/conf”中

    user nobody;
    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 192.168.40.128;
            location ~/group([0-9])/M00 {
                root /opt/fastdfs;
                ngx_fastdfs_module;
            }
    
            error_page 500 502 503 504 /50x.html;
    
            location = /50x.html {
                root html;
            }
        }
    }
    

    1) 8888 端口值與”/etc/fdfs/storage.conf”中的”http.server_port=8888”對應。

    2) storage 對應有多個 group 的情況下,訪問路徑帶 group 名,如/group1/M00/00/00/xxx, 對應的 Nginx 配置爲:

    location ~/group([0-9])/M00 {
        ngx_fastdfs_module;
    }
    

    3) 如查下載時如發現老報 404,將”nginx.conf”第一行”user nobody”修改爲”user root”後重新啓動。

3.4 啓動Nginx:

3.5 Nginx反向代理:

若存在多個storage服務器,想通過瀏覽器統一訪問一個圖片路徑,則需要單獨部署一個普通的nginx反向代理。

  • 配置nginx.conf

    upstream fastdfs_group1{
        server 192.168.40.128:8888;
    }
    upstream fastdfs_group2{
        server 192.168.40.129:8888;
    }
    server {
        listen       80;
        server_name  192.168.40.125;
        location /group1 {
            proxy_redirect off;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://fastdfs_group1;
        }
        location /group2 {
            proxy_redirect off;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://fastdfs_group2;
        }
    }
    
  • 瀏覽器訪問圖片: 
    http://192.168.40.125:80/group1/M00/00/00/wKgogFohRKaAbfmfAAUkKwe5sE4.png


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章