一、系統環境搭建
此處已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:
-
啓動Nginx
/usr/local/nginx/sbin/nginx
-
重啓Nginx:
/usr/local/nginx/sbin/nginx -s reload
-
瀏覽器訪問圖片:
http://192.168.40.128:8888/group1/M00/00/00/wKgogFohRKaAbfmfAAUkKwe5sE4.png
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