FastDFS是一個開源的輕量級分佈式文件系統,它對文件進行管理,功能包括:文件存儲、文件同步、文件訪問(文件上傳、文件下載)等,解決了大容量存儲和負載均衡的問題。特別適合以文件爲載體的在線服務。(百科)html
本文詳細介紹了FastDFS在centos系統上的詳細安裝過程,在從機上使用了nginx實現了http的訪問請求,咱們開始吧。。(轉載請標明,謝謝)linux
fdfs工具包下載地址http://pan.baidu.com/s/1eQHCSJwnginx
使用winscp將工具包複製到服務器中c++
1、節點和關閉服務(關閉防火牆)apache
sudo service iptables stop centos
sudo chkconfig iptables off瀏覽器
sudo vi /etc/selinux/config 修改 selinux=disable服務器
2、開始安裝 fastdfs,主機Tracker、從機storage安裝方法同樣app
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