fastdfs
https://github.com/happyfish100/fastdfs/wiki
https://blog.csdn.net/qq_41946543/article/details/102811191
环境准备
使用的系统软件
centos7
libfatscommon FastDFS分离出的一些公用函数包
FastDFS FastDFS本体
fastdfs-nginx-module FastDFS和nginx的关联模块
nginx nginx-1.15.4
使用docker来跑centos7注意事项
命令需要加上 --privileged=True
,终端使用/usr/sbin/init
docker run --name cs_centos --privileged=True -dit -p 5555:8888 centos:7 /usr/sbin/init
进入centos7终端
docker exec -it cs_centos /bin/bash
编译环境
# yum install git gcc gcc-c++ make automake autoconf libtool pcre pcre-devel zlib zlib-devel openssl-devel wget vim -y
# 查看ip时候提示:bash: ip: command not found
# yum -y install initscripts
磁盘目录
说明 | 位置 |
---|---|
所有安装包 | /usr/local/src |
数据存储位置 | /home/dfs |
mkdir /home/dfs # 创建数据存储目录
cd /usr/local/src # 切换到安装目录准备下载安装包
安装libfatscommon
git clone https://github.com/happyfish100/libfastcommon.git --depth 1
cd libfastcommon/
./make.sh && ./make.sh install # 编译安装
安装FastDFS
cd ../ # 返回上一级目录
git clone https://github.com/happyfish100/fastdfs.git --depth 1
cd fastdfs/
./make.sh && ./make.sh install # 编译安装
# 配置文件准备
# -------------------------------踩坑------------------------------------
# 前三条cp,如果cp的时候显示无法获取某个文件或者目录,把cp后面的/usr去掉,从/etc开始写
cp /usr/etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
cp /usr/etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf
cp /usr/etc/fdfs/client.conf.sample /etc/fdfs/client.conf # 客户端文件,测试用
cp /usr/local/src/fastdfs/conf/http.conf /etc/fdfs/ # 供nginx访问使用
cp /usr/local/src/fastdfs/conf/mime.types /etc/fdfs/ # 供nginx访问使用
安装fastdfs-nginx-module
cd ../ # 返回上一级目录
git clone https://github.com/happyfish100/fastdfs-nginx-module.git --depth 1
cp /usr/local/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs
安装nginx
wget http://nginx.org/download/nginx-1.15.4.tar.gz # 下载nginx压缩包
tar -zxvf nginx-1.15.4.tar.gz # 解压
cd nginx-1.15.4/
# 添加fastdfs-nginx-module模块
./configure --add-module=/usr/local/src/fastdfs-nginx-module/src/
make && make install #编译安装
单机部署
tracker部署
vim /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 # 数据和日志文件存储根目录
store_path0=/home/dfs # 第一个存储目录
# --------------------------------------踩坑-----------------------------------
# 此处的ip为本机ip
tracker_server=192.168.52.1:22122 # tracker服务器IP和端口
http.server_port=8888 # http访问文件的端口(默认8888,看情况修改,和nginx中保持一致)
client测试
vim /etc/fdfs/client.conf
#需要修改的内容如下
base_path=/home/dfs
# --------------------------------------踩坑-----------------------------------
# 此处的ip为本机ip
tracker_server=192.168.52.1:22122 # tracker服务器IP和端口
# --------------------------------------踩坑-----------------------------------
# github文档上没有关闭防火墙以及启动服务,所以使用下面这条测试命令会报错
# 启动
# 不关闭防火墙的话无法使用
systemctl stop firewalld.service # 关闭防火墙
# 此处如果关闭防火墙报错,执行
systemctl mask firewalld
# 然后再执行关闭防火墙命令
# 启动tracker服务
/etc/init.d/fdfs_trackerd start
chkconfig fdfs_trackerd on # 重启后会自启动tracker服务
# 启动storage服务
/etc/init.d/fdfs_storaged start
chkconfig fdfs_storaged on #重启后会自启动storage服务
# 查看进程,有包含fdfs或者以fdfs打头的进程有这两个,说明进程启动成功了
ps -ef | grep fdfs
-----------------------------------------------------------------------------
root 3784 1 0 03:11 ? 00:00:00 /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf
root 3819 1 7 03:11 ? 00:00:00 /usr/bin/fdfs_storaged /etc/fdfs/storage.conf
root 3843 201 0 03:11 pts/1 00:00:00 grep --color=auto fdfs
-----------------------------------------------------------------------------
# 测试,返回ID表示成功 如:group1/M00/00/00/xx.tar.gz
[root@eca18027939f src]# fdfs_upload_file /etc/fdfs/client.conf /usr/local/src/nginx-1.15.4.tar.gz
group1/M00/00/00/rBQAAl3xlaiAQ0j7AA-itrfn0m4.tar.gz # 保存下来,测试使用
配置nginx访问
vim /etc/fdfs/mod_fastdfs.conf
# 需要修改的内容如下
tracker_server=192.168.52.1:22122 #tracker服务器IP和端口
url_have_group_name=true
store_path0=/home/dfs
# 配置nginx.config
vim /usr/local/nginx/conf/nginx.conf
# 添加如下配置
server {
listen 8888; # 该端口为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
/usr/local/nginx/sbin/nginx
# 测试下载,用外部浏览器访问刚才已传过的nginx安装包,引用返回的ID
192.168.0.159:5555 # 注:5555端口映射到了docker centos7容器的8888端口
http://192.168.0.159:5555/group1/M00/00/00/rBEAAl3wjgiAdfPsAA-itrfn0m4.tar.gz
# 弹出下载,单机部署全部跑通