1. 程式人生 > >Centos7下安裝FastDFS服務

Centos7下安裝FastDFS服務

 

1、安裝FastDFS服務的依賴

1.1、安裝GCC依賴

GCC用來對C語言程式碼進行編譯執行

[[email protected] soft]# yum install -y gcc

1.2、安裝unzip工具

unzip工具可以幫助我們對壓縮包進行解壓縮

[[email protected] soft]# yum install -y unzip zip

1.3、安裝libevent

[[email protected] soft]# yum install -y libevent

1.4、安裝Nginx所需依賴

[[email protected] soft]# yum -y install pcre pcre-devel zlib zlib-devel openssl openssl-devel

1.5、安裝libfastcommon-master

[[email protected] soft]# unzip libfastcommon-master.zip
[[email protected] soft]# mv libfastcommon-master /usr/local/
[[email protected] soft]# cd /usr/local/libfastcommon-master/
[
[email protected]
libfastcommon-master]# ./make.sh [[email protected] libfastcommon-master]# ./make.sh install

2、安裝FastDFS

2.1、編譯安裝

[[email protected] soft]# tar -zxvf FastDFS_v5.08.tar.gz -C /usr/local/
[[email protected] soft]# cd /usr/local/FastDFS/
#編譯安裝
[[email protected] FastDFS]# ./make.sh 
[
[email protected]
FastDFS]# ./make.sh install

檢查安裝情況

[[email protected] ~]# ll /etc/init.d/ | grep fdfs
-rwxr-xr-x  1 root root   918 Nov 12 15:41 fdfs_storaged
-rwxr-xr-x  1 root root   920 Nov 12 15:41 fdfs_trackerd
  • fdfs_trackerd 是tracker啟動指令碼
  • fdfs_storaged 是storage啟動指令碼

在 /etc/fdfs目錄,通過命令檢視到以下配置檔案模板:

[[email protected] ~]# ll /etc/fdfs/
total 20
-rw-r--r-- 1 root root 1461 Nov 12 15:41 client.conf.sample
-rw-r--r-- 1 root root 7927 Nov 12 15:41 storage.conf.sample
-rw-r--r-- 1 root root 7200 Nov 12 15:41 tracker.conf.sample
  • tarcker.conf.sample 是tracker的配置檔案模板;
  • storage.conf.sample 是storage的配置檔案模板;
  • client.conf.sample 是客戶端的配置檔案模板。

2.2、啟動tracker

     FastDFS的tracker和storage在剛剛的安裝過程中,都已經被安裝了,因此我們安裝這兩種角色的方式是一樣的。不同的是,兩種需要不同的配置檔案。我們要啟動tracker,就修改剛剛看到的tarcker.conf,並且啟動fdfs_trackerd指令碼即可。

(1)編輯tracker配置

配置的是tracker的資料和日誌存放目錄。

[[email protected] ~]# cd /etc/fdfs/
[[email protected] fdfs]# cp tracker.conf.sample  tracker.conf
#tracker的資料和日誌存放目錄
[[email protected] ~]# vim /etc/fdfs/tracker.conf
base_path=/data/fdfs/tracker

(2)建立目錄

[[email protected] ~]# mkdir -p /data/fdfs/tracker

(3)啟動tracker

    我們可以使用 sh /etc/init.d/fdfs_trackerd 啟動,不過安裝過程中,fdfs已經被設定為系統服務,我們可以採用熟悉的服務啟動方式:

[[email protected] ~]# ll /etc/init.d/fdfs_trackerd
-rwxr-xr-x 1 root root 920 Nov 12 15:41 /etc/init.d/fdfs_trackerd
 # 啟動fdfs_trackerd服務,停止用stop
[[email protected] ~]# service fdfs_trackerd start

們可以通過以下命令,設定tracker開機啟動:

[[email protected] ~]# chkconfig fdfs_trackerd on

2.2、啟動storage

(1)編輯storage配置

[[email protected] ~]# cd /etc/fdfs/
[[email protected] fdfs]# cp storage.conf.sample storage.conf
[[email protected] fdfs]# vim storage.conf
base_path=/data/fdfs/storage
store_path0=/data/fdfs/storage
tracker_server=192.168.2.14:22122

base_path=/data/fdfs/storage #storage資料和日誌的存放目錄
store_path0=/data/fdfs/storage#storage上傳檔案存放目錄
tracker_server=192.168.2.14:22122#tracker的地址

(2)建立storage存放目錄

[[email protected] fdfs]# mkdir -p /data/fdfs/storage

(3)啟動storage

我們可以使用 sh /etc/init.d/fdfs_storaged 啟動,同樣我們可以用服務啟動方式

[[email protected] ~]# ll /etc/init.d/fdfs_storaged
-rwxr-xr-x 1 root root 918 Nov 12 15:41 /etc/init.d/fdfs_storaged
#啟動fdfs_storaged服務,停止用stop
[[email protected] ~]# service fdfs_storaged start
#開機自啟
[[email protected] ~]# chkconfig fdfs_storaged on

檢視程序

[[email protected] ~]# ps -ef | grep fdfs
root     26105     1  0 15:54 ?        00:00:00 /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf
root     26185     1  4 16:02 ?        00:00:03 /usr/bin/fdfs_storaged /etc/fdfs/storage.conf
root     26218 25412  0 16:03 pts/0    00:00:00 grep --color=auto fdfs

3、安裝Nginx及FastDFS模組

3.1、安裝FastDFS的Nginx模組

解壓縮及配置config檔案

[[email protected] soft]# tar -zxf fastdfs-nginx-module_v1.16.tar.gz -C /usr/local/
# 進入配置目錄
[[email protected] soft]# cd /usr/local/fastdfs-nginx-module/src/
[[email protected] src]# vim config
# 執行下面命令(將配置中的/usr/local改為/usr):
:%s+/usr/local/+/usr/+g

 配置mod_fastdfs.conf

[[email protected] ~]# cp /usr/local/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/

[[email protected] ~]# vim /etc/fdfs/mod_fastdfs.conf
connect_timeout=10
tracker_server=192.168.2.14:22122
url_have_group_name = true
store_path0=/data/fdfs/storage

connect_timeout=10                          # 客戶端訪問檔案連線超時時長(單位:秒)
tracker_server=192.168.2.14:22122      # tracker服務IP和埠
url_have_group_name=true                    # 訪問連結字首加上組名 
store_path0=/data/fdfs/storage  # 檔案儲存路徑

複製 FastDFS的部分配置檔案到/etc/fdfs目錄

[[email protected] ~]# cd /usr/local/FastDFS/conf/
[[email protected] conf]# cp http.conf mime.types /etc/fdfs/

3.2、安裝Nginx

(1)解壓縮及配置

[[email protected] ~]# mkdir /data/nginx
[[email protected] soft]# tar -zxvf nginx-1.14.1.tar.gz -C /usr/local/
[[email protected] soft]# cd /usr/local/nginx-1.14.1/
[[email protected] nginx-1.14.1]# ./configure --prefix=/data/nginx --sbin-path=/usr/bin/nginx --add-module=/usr/local/fastdfs-nginx-module/src/

注意其中--add-module指定的是fastdfs-nginx-module壓縮目錄。

(2)編譯安裝

[[email protected] nginx-1.14.1]# make && make install

(3)配置nginx整合fastdfs-module模組

我們需要修改nginx配置檔案,在/data/nginx/config/nginx.conf檔案中

[[email protected] ~]# vim /data/nginx/conf/nginx.conf

 server {
        listen       80;
        server_name  image.wzy.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;
        }
}

(4)設定nginx開機啟動
 

[[email protected] ~]# 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 0

nginx="/usr/bin/nginx"
prog=$(basename $nginx)

NGINX_CONF_FILE="/data/nginx/conf/nginx.conf"

[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx

lockfile=/var/lock/subsys/nginx

make_dirs() {
   # make required directories
   user=`$nginx -V 2>&1 | grep "configure arguments:.*--user=" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
   if [ -n "$user" ]; then
      if [ -z "`grep $user /etc/passwd`" ]; then
         useradd -M -s /bin/nologin $user
      fi
      options=`$nginx -V 2>&1 | grep 'configure arguments:'`
      for opt in $options; do
          if [ `echo $opt | grep '.*-temp-path'` ]; then
              value=`echo $opt | cut -d "=" -f 2`
              if [ ! -d "$value" ]; then
                  # echo "creating" $value
                  mkdir -p $value && chown -R $user $value
              fi
          fi
       done
    fi
}

start() {
    [ -x $nginx ] || exit 5
    [ -f $NGINX_CONF_FILE ] || exit 6
    make_dirs
    echo -n $"Starting $prog: "
    daemon $nginx -c $NGINX_CONF_FILE
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}

stop() {
    echo -n $"Stopping $prog: "
    killproc $prog -QUIT
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}

restart() {
    configtest || return $?
    stop
    sleep 1
    start
}

reload() {
    configtest || return $?
    echo -n $"Reloading $prog: "
    killproc $nginx -HUP
    RETVAL=$?
    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" in
    start)
        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

nginx # 啟動
nginx -s stop # 停止
nginx -s reload # 重新載入配置
 

# 修改許可權
[[email protected] ~]# chmod 777 /etc/init.d/nginx
# 新增到服務列表
[[email protected] ~]# chkconfig --add /etc/init.d/nginx 
[[email protected] ~]# chkconfig nginx on