fastdfs安装教程

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 16:33   1286   0

本人测试环境:CentOS7.3

建议一下安装包获取最新版本,否则容易出现各种不兼容报错(https://github.com/happyfish100 在此网站下载相对应的软件版本)

  1. libfastcommon-1.0.43.tar
  2. fastdfs-6.06.tar.gz
  3. fastdfs-nginx-module-1.22.tar
  4. nginx-1.8.1.tar

新建路径(fastdfs 数据存储位置) mkdir /home/dfs

tar -zxvf libfastcommon-1.0.43.tar.gz

tar -zxvf fastdfs-6.06.tar.gz

tar -zxvf fastdfs-nginx-module-1.22.tar

tar -zxvf nginx-1.8.1.tar

编译环境安装:

yum install git gcc gcc-c++ make automake autoconf libtool pcre pcre-devel zlib zlib-devel openssl-devel wget vim -y

安装libfastcommon

cd libfastcommon-1.0.43/

./make.sh && ./make.sh install #编译安装


安装FastDFS
cd ../ #返回上一级目录
mv fastdfs-6.06 fastdfs #修改目录名

cd fastdfs/
./make.sh && ./make.sh install #编译安装
#配置文件准备
cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf
cp /etc/fdfs/client.conf.sample /etc/fdfs/client.conf #客户端文件,测试用
cp /usr/local/fastdfs/conf/http.conf /etc/fdfs/ #供nginx访问使用
cp /usr/local/fastdfs/conf/mime.types /etc/fdfs/ #供nginx访问使用

安装fastdfs-nginx-module
cd ../ #返回上一级目录
cp /usr/local/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs

安装nginx
cd nginx-1.15.4/
#添加fastdfs-nginx-module模块
./configure --add-module=/usr/local/src/fastdfs-nginx-module/src/

(添加多个模块可以这样写,--prefix指定生成nginx的目录路径

./configure --prefix=/usr/local/nginx --add-module=/usr/local/fastdfs-nginx-module-1.22/src --with-http_stub_status_module)
make && make install #编译安装

单机部署
tracker配置
#服务器ip为 192.168.223.131
vi /etc/fdfs/tracker.conf
#需要修改的内容如下
port=22122 # tracker服务器端口(默认22122,一般不修改)
base_path=/home/dfs # 存储日志和数据的根目录

storage配置
vim /etc/fdfs/storage.conf
#需要修改的内容如下
port=23000 # storage服务端口(默认23000,一般不修改)
base_path=/home/dfs/storage # 数据和日志文件存储根目录
store_path0=/home/dfs # 第一个存储目录
tracker_server=192.168.223.131:22122 # tracker服务器IP和端口
http.server_port=80 # http访问文件的端口(默认8888,看情况修改,和nginx中保持一致)

client测试
vim /etc/fdfs/client.conf
#需要修改的内容如下
base_path=/home/dfs
tracker_server=192.168.223.131:22122 #tracker服务器IP和端口

启动trackerd

/etc/init.d/fdfs_trackerd start (/etc/init.d/fdfs_trackerd stop #停止)

启动storaged

/etc/init.d/fdfs_storaged start

/etc/init.d/fdfs_storaged start (/etc/init.d/fdfs_storaged stop #停止)


#保存后测试,返回ID表示成功 如:group1/M00/00/00/wKjfg18V32uAeOVfAAy3weBKVkQ.tar.gz
fdfs_upload_file /etc/fdfs/client.conf /usr/local/src/nginx-1.15.4.tar.gz

进入/home/dfs/data/00/00目录,发现文件已上传成功

配置nginx访问
vim /etc/fdfs/mod_fastdfs.conf
#需要修改的内容如下
tracker_server=192.168.223.131:22122 #tracker服务器IP和端口
url_have_group_name=true
store_path0=/home/dfs
#配置nginx.config
vim /usr/local/nginx/conf/nginx.conf
#添加如下配置
server {
listen 80; ## 该端口为storage.conf中的http.server_port相同
server_name localhost;
location ~/group[0-9]/ {
ngx_fastdfs_module;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}

#测试下载,用外部浏览器访问刚才已传过的nginx安装包,引用返回的ID
http://192.168.223.131/group1/M00/00/00/wKjfg18V32uAeOVfAAy3weBKVkQ.tar.gz

常见问题:

/etc/init.d/fdfs_storaged start (ip:192.168.223.132)
输入命令后 storaged 没有启动,且也没有产生相应的 storaged.log文件,说明 启动storaged出现问题可以使用 /etc/init.d/fdfs_storaged restart 启动,则会产生storaged.log文件,然后打开日志文件查看报错。
如果日志里面出现:
ERROR - file: storage_ip_changed_dealer.c, line: 163, connect to tracker server 192.168.223.130:22122 fail, errno: 111, error info: Connection refused
说明192.168.223.130服务器上面的tracker server没有启动或者启动有问题,需进行排查启动即可,或者在192.168.223.132机器上打开storaged.conf文件,注释掉#tracker_server = 192.168.223.130:22122,然后重启storaged服务 即可。


扩容group会遇到offline, 查看tracker日志发现:
ERROR - file: tracker_service.c, line: 3550, cmd=84, client ip: 106.15.137.142, package size 32 is not correct, expect length: 16
两台storage的store_path_count 和路径必须一致,所以两台一起修改配置文件重启后,就OK了。
如果还是不行就需要以下操作:
有时候通过fdfs_monitor 发现store_path的配置不生效,这时,必须要删除tracker目录下的两个文件:storage_groups_new.dat,storage_servers_new.dat再重启服务。

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP