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