FastDFS的安装
Linux下使用FastDFS
所有操作均在CentOS 6.x環境下進行。
將所需文件,上傳到/usr/local/learn目錄下:
單節點FastDFS
整個安裝過程非常復雜,很容易出錯,建議進行多次備份。
我們這里不打算安裝多臺虛擬機,因此會把tracker和storage都安裝在一起。
?
安裝gcc
GCC用來對C語言代碼進行編譯運行,使用yum命令安裝:
yum -y install gcc后面會用到解壓命令(unzip),所以這里可以用yum把unzip 也裝一下
yum install -y unzip zip安裝libevent
yum -y install libevent安裝libfastcommon-master
解壓剛剛上傳的libfastcommon-master.zip unzip libfastcommon-master.zip進入解壓完成的目錄 cd libfastcommon-master編譯并且安裝: ./make.sh ./make.sh install安裝fastdfs
tar -zxvf FastDFS_v5.08.tar.gzcd FastDFS./make.sh ./make.sh install如果安裝成功,會看到/etc/init.d/下看到提供的腳本文件:
ll /etc/init.d/ | grep fdfs-
fdfs_trackerd 是tracker啟動腳本
-
fdfs_storaged 是storage啟動腳本
能夠在 /etc/fdfs/ 目錄下看到默認的配置文件模板:
ll /etc/fdfs/-
tarcker.conf.sample 是tracker的配置文件模板
-
storage.conf.sample 是storage的配置文件模板
-
client.conf.sample 是客戶端的配置文件模板
配置并啟動tracker服務
FastDFS的tracker和storage在剛剛的安裝過程中,都已經被安裝了,因此我們安裝這兩種角色的方式是一樣的。不同的是,兩種需要不同的配置文件。
我們要啟動tracker,就修改剛剛看到的tarcker.conf,并且啟動fdfs_trackerd腳本即可。
1)首先將模板文件復制
cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf2)修改復制后的配置文件:
vim /etc/fdfs/tracker.conf# 修改的內容如下:
base_path=/learn/tracker # 存儲日志和數據的根目錄3)新建目錄:
mkdir -p /learn/tracker注意:關閉防火墻:
chkconfig iptables off4)啟動和停止
啟動tracker服務器: /etc/init.d/fdfs_trackerd start
停止tracker服務器: /etc/init.d/fdfs_trackerd stop
不過安裝過程中,fdfs已經被設置為系統服務,我們可以采用熟悉的服務啟動方式:
service fdfs_trackerd start # 啟動fdfs_trackerd服務,停止用stop檢查FastDFS Tracker Server是否啟動成功:
ps -ef | grep fdfs_trackerd設置tracker服務開機啟動:
chkconfig fdfs_trackerd on配置并啟動storage服務
1)首先將模板文件復制
cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf2)修改復制后的配置文件:
vim /etc/fdfs/storage.conf# 修改的內容如下:
base_path=/learn/storage # 數據和日志文件存儲根目錄 store_path0=/learn/storage # 第一個存儲目錄 tracker_server=192.168.56.101:22122 # tracker服務器IP和端口3)新建目錄:
mkdir -p /learn/storage注意關閉防火墻: chkconfig iptables off
?
4)啟動和停止
啟動storage服務器:/etc/init.d/fdfs_storaged start
停止storage服務器:/etc/init.d/fdfs_storaged stop
推薦使用:
service fdfs_storaged start # 啟動fdfs_storaged服務,停止用stop設置storage服務開機啟動:
chkconfig fdfs_storaged onps -ef | grep fdfs
使用nginx訪問FastDFS
為什么需要用Nginx訪問?
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
解壓
tar -zxvf fastdfs-nginx-module_v1.16.tar.gz修改config
1)進入src目錄
cd fastdfs-nginx-module/src/2)編輯config
vim config使用以下底行命令:
:%s+/usr/local/+/usr/+g將所有的/usr/local替換為 /usr,這個才是正確的目錄:
配置nginx與FastDFS關聯配置文件
復制 fastdfs-nginx-module 源碼中的配置文件到/etc/fdfs 目錄, 并修改
cp /usr/local/learn/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/vi /etc/fdfs/mod_fastdfs.conf修改以下配置:
connect_timeout=10 # 客戶端訪問文件連接超時時長(單位:秒)tracker_server=192.168.56.101:22122 # tracker服務IP和端口url_have_group_name=true # 訪問鏈接前綴加上組名store_path0=/learn/storage # 文件存儲路徑復制 FastDFS 的部分配置文件到/etc/fdfs 目錄
cd /usr/local/learn/FastDFS/conf/ cp http.conf mime.types /etc/fdfs/安裝Nginx的插件
如果沒有安裝過nginx
-
安裝nginx的依賴庫
解壓安裝包
tar -zxvf nginx-1.10.0.tar.gz配置nginx安裝包,并指定fastdfs-nginx-model
cd nginx-1.10.0./configure --prefix=/opt/nginx --sbin-path=/usr/bin/nginx --add-module=/usr/local/learn/fastdfs-nginx-module/src注意:在執行./configure配置nginx參數的時候,需要將fastdfs-nginx-moudle源碼作為模塊編譯進去。
?
-
編譯并安裝
如果已經安裝過nginx
1) 進入nginx目錄:
cd /usr/local/learn/nginx-1.10.0/2) 配置FastDFS 模塊
./configure --prefix=/opt/nginx --sbin-path=/usr/bin/nginx --add-module=/usr/local/learn/fastdfs-nginx-module/src注意:這次配置時,要添加fastdfs-nginx-moudle模塊
?
3) 編譯,注意,這次不要安裝(install)
make4) 替換nginx二進制文件:
備份:
mv /usr/bin/nginx /usr/bin/nginx-bak用新編譯的nginx啟動文件替代原來的:
cp objs/nginx /usr/bin/啟動nginx
配置nginx整合fastdfs-module模塊
我們需要修改nginx配置文件,在/opt/nginx/config/nginx.conf文件中:
vim /opt/nginx/conf/nginx.conf將文件中,原來的server 80{ ...} 部分代碼替換為如下代碼:
server {listen 80;server_name image.learn.com;# 監聽域名中帶有group的,交給FastDFS模塊處理location ~/group([0-9])/ {ngx_fastdfs_module;}location / {root html;index index.html index.htm;}error_page 500 502 503 504 /50x.html;location = /50x.html {root html;}}啟動nginx:
nginx # 啟動nginxnginx -s stop # 停止nginxnginx -s reload # 重新載入配置文件# 可通過ps -ef | grep nginx查看nginx是否已啟動成功
設置nginx開機啟動
創建一個開機啟動的腳本:
vim /etc/init.d/nginx添加以下內容:
#!/bin/sh # # nginx - this script starts and stops the nginx daemon # # chkconfig: - 85 15 # description: NGINX is an HTTP(S) server, HTTP(S) reverse \ # proxy and IMAP/POP3 proxy server # processname: nginx # config: /etc/nginx/nginx.conf # config: /etc/sysconfig/nginx # pidfile: /var/run/nginx.pid# Source function library. . /etc/rc.d/init.d/functions# Source networking configuration. . /etc/sysconfig/network# Check that networking is up. [ "$NETWORKING" = "no" ] && exit 0nginx="/usr/bin/nginx" prog=$(basename $nginx)NGINX_CONF_FILE="/opt/nginx/conf/nginx.conf"[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginxlockfile=/var/lock/subsys/nginxmake_dirs() {# make required directoriesuser=`$nginx -V 2>&1 | grep "configure arguments:.*--user=" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`if [ -n "$user" ]; thenif [ -z "`grep $user /etc/passwd`" ]; thenuseradd -M -s /bin/nologin $userfioptions=`$nginx -V 2>&1 | grep 'configure arguments:'`for opt in $options; doif [ `echo $opt | grep '.*-temp-path'` ]; thenvalue=`echo $opt | cut -d "=" -f 2`if [ ! -d "$value" ]; then# echo "creating" $valuemkdir -p $value && chown -R $user $valuefifidonefi }start() {[ -x $nginx ] || exit 5[ -f $NGINX_CONF_FILE ] || exit 6make_dirsecho -n $"Starting $prog: "daemon $nginx -c $NGINX_CONF_FILEretval=$?echo[ $retval -eq 0 ] && touch $lockfilereturn $retval }stop() {echo -n $"Stopping $prog: "killproc $prog -QUITretval=$?echo[ $retval -eq 0 ] && rm -f $lockfilereturn $retval }restart() {configtest || return $?stopsleep 1start }reload() {configtest || return $?echo -n $"Reloading $prog: "killproc $nginx -HUPRETVAL=$?echo }force_reload() {restart }configtest() {$nginx -t -c $NGINX_CONF_FILE }rh_status() {status $prog }rh_status_q() {rh_status >/dev/null 2>&1 }case "$1" instart)rh_status_q && exit 0$1;;stop)rh_status_q || exit 0$1;;restart|configtest)$1;;reload)rh_status_q || exit 7$1;;force-reload)force_reload;;status)rh_status;;condrestart|try-restart)rh_status_q || exit 0;;*)echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"exit 2 esac修改文件權限,并加入服務列表
# 修改權限 chmod 777 /etc/init.d/nginx # 添加到服務列表 chkconfig --add /etc/init.d/nginx設置開機啟動
chkconfig nginx on?
總結
以上是生活随笔為你收集整理的FastDFS的安装的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 绕过网关访问图片上传并解决跨域问题
- 下一篇: 使用fastDFS客户端改造文件上传