Centos下安装FastDFS

Centos下安装FastDFS

1.1需要资料:

  • FastDFS_v5.08.tar.gz
  • fastdfs-nginx-module_v1.16.tar.gz
  • libevent-2.0.22-stable.tar.gz
  • libfastcommon-master.zip
  • nginx-1.10.0.tar.gz

1.2 安装依赖

  • yum -y install gcc
  • yum install -y unzip zip
  • yum -y install libevent
  • yum -y install pcre pcre-devel zlib zlib-devel openssl openssl-devel
  • 安装libfastcommon-master
  tar -xvf libfastcommon-master.zip
  cd libfastcommon-master
  ./make.sh 
  ./makesh install
  
创建软连接
mkdir -p /usr/local/lib/
ln -s /usr/lib64/libfastcommon.so /usr/local/lib/libfastcommon.so
ln -s /usr/lib64/libfastcommon.so /usr/lib/libfastcommon.so
ln -s /usr/lib64/libfdfsclient.so /usr/local/lib/libfdfsclient.so
ln -s /usr/lib64/libfdfsclient.so /usr/lib/libfdfsclient.so

1.3安装fastDFS

tar -xvf FastDFS_v5.08.tar.gz
 cd FastDFS
./make.sh 
./make.sh install
查看:服务脚本所在目录
cd /etc/init.d/ && ls |grep fdfs
配置文件在:cd /etc/fdfs
执行脚本:cd /usr/bin/ && ls | grep fdfs

修改配置文件
 vim /etc/init.d/fdfs_storaged
进行全局替换命令: %s+/usr/local/bin+/usr/bin
 vim /etc/init.d/fdfs_trackerd
进行全局替换命令: %s+/usr/local/bin+/usr/bin

在/etc/fdfs下
cp tracker.conf.sample tracker.conf
vim tracker.conf
base_path=/fastdfs/tracker
mkdir -p /fastdfs/tracker
目录命令:cd /fastdfs/tracker/ && ll
启动tracker命令: /etc/init.d/fdfs_trackerd start
查看进程命令: ps -el | grep fdfs
停止tracker命令: /etc/init.d/fdfs_trackerd stop
service fdfs_trackerd start # 启动fdfs_trackerd服务,停止用stop
设置开机自启:
命令: vim /etc/rc.d/rc.local
加入配置: /etc/init.d/fdfs_trackerd start
或者 chkconfig fdfs_trackerd on

cp storage.conf.sample storage.conf
vim storage.conf
base_path=/leyou/fdfs/storage # storage的数据和日志存放目录
store_path0=/leyou/fdfs/storage # storage的上传文件存放路径
tracker_server=192.168.56.101:22122 # tracker的地址
mkdir -p /leyou/fdfs/storage
`sh /etc/init.d/fdfs_storaged` 启动
service fdfs_storaged start  # 启动fdfs_storaged服务,停止用stop
设置开机启动
chkconfig fdfs_storaged on
开机自启:
命令: vim /etc/rc.d/rc.local
加入配置: /etc/init.d/fdfs_storaged start

通过`ps -ef | grep fdfs` 查看进程

测试:

cd /etc/fdfs/
 cp client.conf.sample client.conf
命令: vim /etc/fdfs/client.conf
修改内容:
base_path=/fastdfs/tracker
tracker_server=192.168.119.137:22122
cd /usr/bin/
ls | grep fdfs
使用命令fdfs_upload_file进行上传操作
首先存储中/fastdfs/storage/data/00/00文件什么也没有
在tracker中 /usr/bin/fdfs_upload_file /etc/fdfs/client.conf /usr/local/software/FastDFS_v5.05.tar.gz  
在storage中可以查看上传的文件

与nginx整合:

tar -zxvf fastdfs-nginx-module_v1.16.tar.gz -C /usr/local

进入目录: cd fastdfs-nginx-module/src/

编辑配置文件config 修改为如下形式:
CORE_INCS="$CORE_INCS /usr/include/fastdfs /usr/include/fastcommon/"

先删除原先nginx安装的目录nginx-soft
 rm -rf nginx-soft
 
进入nginx解压的目录 加入模块命令:
./configure --add-module=/usr/local/fastdfs-nginx-module/src/

重新编译命令: make && make install

复制配置文件cp /usr/local/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/
修改配置文件 vim /etc/fdfs/mod_fastdfs.conf
修改内容:比如连接超时时间、跟踪器路径配置、 url的group配置、
 connect_timeout=10
 tracker_server=192.168.1.172:22122
 url_have_group_name = true
 store_path0=/fastdfs/storage
 
进入: /usr/local/fast/FastDFS/conf 复制文件到/etc/fdfs目录
cp http.conf mime.types /etc/fdfs/

创建软连接:ln -s /fastdfs/storage/data/ /fastdfs/storage/data/M00

进入/usr/local/nginx/conf修改配置文件---注意解压的nginx文件夹不要命名为nginx 因为后面安装时会自动创建nginx文件夹
vim nginx.conf
修改内容为:
listen 8888;
server_name localhost;
location ~/group([0-9])/M00 {
ngx_fastdfs_module;
}
注意: nginx里的端口要和第五步配置FastDFS存储中的storage.conf文件配置一致,
也就是(http.server_port=8888)
  • nginx # 启动
  • nginx -s stop # 停止
  • nginx -s reload # 重新加载配置

设置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 0

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

NGINX_CONF_FILE="/usr/local/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

  • 修改文件权限,并加入服务列表

    # 修改权限
    chmod 777 /etc/init.d/nginx 
    # 添加到服务列表
    chkconfig --add /etc/init.d/nginx 
    
  • 设置开机启动

    chkconfig nginx on
    

你可能感兴趣的:(IT技术分享,nginx,fastDFS)