1、安装配置Nginx模块
① fastdfs-nginx-module 模块说明
FastDFS 通过 Tracker 服务器,将文件放在 Storage 服务器存储, 但是同组存储服务器之间需要进行文件复制, 有同步延迟的问题。
假设 Tracker 服务器将文件上传到了 192.168.51.128,上传成功后文件 ID已经返回给客户端。
此时 FastDFS 存储集群机制会将这个文件同步到同组存储 192.168.51.129,在文件还没有复制完成的情况下,客户端如果用这个文件 ID 在 192.168.51.129 上取文件,就会出现文件无法访问的错误。
而 fastdfs-nginx-module 可以重定向文件链接到源服务器取文件,避免客户端由于复制延迟导致的文件无法访问错误。
② 下载 fastdfs-nginx-module、解压
cd /usr/local
git clone https://github.com/happyfish100/fastdfs-nginx-module
cd fastdfs-nginx-module; git checkout V1.22
③ 配置Nginx
在nginx中添加模块
# 先停掉nginx服务
# /usr/local/nginx/sbin/nginx -s stop
进入解压包目录
# cd /usr/local/src/nginx-1.18.0/
./configure --add-module=/usr/local/fastdfs-nginx-module/src
make;make install
④ 查看Nginx的模块
root@iZ8vbeeelmyzkhxvdqblbyZ:/usr/local/src/nginx-1.18.0# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.18.0
built by gcc 9.3.0 (Ubuntu 9.3.0-10ubuntu2)
configure arguments: --add-module=/usr/local/fastdfs-nginx-module/src
如能像上面一样看到 --add-module后面出现的 插件地址,说明配置成功.
⑤ 复制 fastdfs-nginx-module 源码中的配置文件到/etc/fdfs 目录
cd /usr/local/fastdfs-nginx-module/src
cp mod_fastdfs.conf /etc/fdfs/
修改/etc/fdfs/mod_fastdfs.conf文件中的如下配置,其它默认.
# 连接超时时间
connect_timeout=10
# Tracker Server
tracker_server=ip:22122
# StorageServer 默认端口
storage_server_port=23000
# 如果文件ID的uri中包含/group**,则要设置为true
url_have_group_name = true
# Storage 配置的store_path0路径,必须和storage.conf中的一致
store_path0=/home/fastdfs/file
⑥ 复制 FastDFS 的部分配置文件到/etc/fdfs 目录
# cd /opt/fastdfs/conf/
# cp anti-steal.jpg http.conf mime.types /etc/fdfs/
⑦ 配置nginx,修改nginx.conf
vi /usr/local/nginx/conf/nginx.conf
修改配置,其它的默认
在80端口下添加fastdfs-nginx模块
location ~/group([0-9])/M00 {
ngx_fastdfs_module;
}
注意:
listen 80 端口值是要与 /etc/fdfs/storage.conf 中的 http.server_port=80 (前面改成80了)相对应。如果改成其它端口,则需要统一,同时在防火墙中打开该端口。
location 的配置,如果有多个group则配置location ~/group([0-9])/M00 ,没有则不用配group。
8. 启动nginx
cd /usr/local/nginx/sbin
root@iZ8vbeeelmyzkhxvdqblbyZ:/usr/local/nginx/sbin#
ngx_http_fastdfs_set pid=23532 #出现进程编号说明启动成功
9. 在地址栏访问。
能下载文件就算安装成功。注意和前面直接使用nginx路由访问不同的是,这里配置 fastdfs-nginx-module 模块,可以重定向文件链接到源服务器取文件。
http://39.99.175.175/group1/M00/00/00/rBq3g1_NzIGAAlxnAAAADK8IOy0132.txt
最终部署结构图:可以按照下面的结构搭建环境。