软件安装-Linux安装FastDFS

本文介绍如何在CentOS 7环境中安装和配置FastDFS,包括必备软件的安装、FastDFS各组件的配置步骤,以及与Nginx的整合过程,最后验证系统是否正确部署。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Linux安装FastDFS

一. 准备工作
1.安装环境CentOS-7。
2.运行几条命令

运行命令命令含义详情
yum install -y gcc gcc-c++安装gcc(编译时需要)FastDFS是C语言开发,安装FastDFS需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc;
yum -y install libevent安装libevent(运行时需求)若安装了桌面图形界面,就不需要安装;FastDFS依赖libevent库;

3. 下载资源文件
1). libfastcommonV1.0.7.tar.gz
libfastcommon是FastDFS官方提供的,libfastcommon包含了FastDFS运行所需要的一些基础库。
下载地址:https://pan.baidu.com/s/1o36R7IC_4WgroWTC-aNboA 提取码: h991
2). FastDFS_v5.05.tar.gz
下载地址:https://pan.baidu.com/s/1SFKhxJ6PuwVRS-WuuGhYEA 提取码: yuvy
3). fastdfs-nginx-module_v1.16.tar(1).gz
下载地址:https://pan.baidu.com/s/1TFfztvA6dFoQTTGK3PWzRg 提取码: 1tkm
下载好了之后,将这几个安装包上传到Linux系统中,准备工作就差不多了!下面我们开始安装

二.开始安装

1. 安装libfastcommon
 libfastcommon是FastDFS官方提供的,libfastcommon包含了FastDFS运行所需要的一些基础库。
(1)将 libfastcommonV1.0.7.tar.gz解压至/usr/local/下:

tar -zxvf libfastcommonV1.0.7.tar.gz -C /usr/local/

(2)切换目录到:/usr/local/libfastcommon-1.0.7/ 下,接着进行编译和安装;

cd /usr/local/libfastcommon-1.0.7/
./make.sh           #编译
./make.sh install   #安装

安装后的截图:
在这里插入图片描述
(3)libfastcommon安装好后会在/usr/lib64 目录下生成 libfastcommon.so 库文件;
  
  注意:由于FastDFS程序引用usr/lib目录所以需要将/usr/lib64下的库文件拷贝至/usr/lib下。

cp libfastcommon.so /usr/lib

2、安装tracker
(1)将FastDFS_v5.05.tar.gz 解压至/usr/local/下

tar -zxvf FastDFS_v5.05.tar.gz -C /usr/local

(2)切换目录到: /usr/local/FastDFS/ 下,编译和安装;

cd /usr/local/FastDFS/
./make.sh && ./make.sh install  #编译之后接着进行安装

安装后的截图:
在这里插入图片描述
(3)安装成功将安装目录下的conf下的文件拷贝到/etc/fdfs/下;

cp /usr/local/FastDFS/conf/* /etc/fdfs/

在这里插入图片描述
3、配置和启动tracker
(1)切换目录到: /etc/fdfs/ 目录下;
(2)拷贝一份新的tracker配置文件

cp tracker.conf.sample tracker.conf

(3)修改tracker.conf ; vim tracker.conf

base_path=/home/yuqing/fastdfs 改为: base_path=/home/fastdfs
http.server_port 改为: 80
base_path=/home/fastdfshttp.server_port=80 #配置http端口

(4)创建 /home/fastdfs 目录

mkdir /home/fastdfs

(5)启动tracker,运行如下命令:

/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

在这里插入图片描述
注意:在/home/fastdfs/ 目录下生成两个目录, 一个是数据,一个是日志;

4、配置和启动storage
由于上面已经安装过FastDFS,这里只需要配置storage就好了;
(1)切换目录到: /etc/fdfs/ 目录下;
(2)拷贝一份新的storage配置文件

cp storage.conf.sample storage.conf

(3)修改storage.conf ; vim storage.conf

group_name=group1 #配置组名
base_path=/home/yuqing/fastdfs 改为: base_path=/home/fastdfs
#store存放文件的位置(store_path)
store_path0=/home/yuqing/fastdfs 改为: store_path0=/home/fdfs_storage
#如果有多个挂载磁盘则定义多个store_path,如下
#store_path1=…
#store_path2=…
#配置tracker服务器:IP
tracker_server=192.168.172.20:22122
#如果有多个则配置多个tracker
#tracker_server=192.168.101.4:22122
#配置http端口
http.server_port=88

(4)创建 /home/fdfs_storage 目录

mkdir /home/fdfs_storage

(5)启动storage, 运行命令如下:

/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart

启动完成后进入 /home/fdfs_storage/data 目录下,显示目录如下:
在这里插入图片描述
注意:有可能不在fdfs_storage/data目录下,可以去fdfs/data目录下去看看

5、使用FastDFS自带工具测试

(1)切换目录到 /etc/fdfs/ 目录下;
(2)拷贝一份新的client配置文件

cp client.conf.sample client.conf

(3)修改client.conf ; vim client.conf,修改基本路径和tracker_server如下:
在这里插入图片描述
注意:若tracker有多个,可以配置多个,如下:
  #tracker_server=…
  #tracker_server=…
(4)拷贝一张图片IMG_0028.JPG 到Centos服务器上的 /usr1 目录下;
在系统根路径新建一个usr1目录

mkdir /usr1

在这里插入图片描述
(5)进行测试,运行如下:(运行测试程序,读取/etc/fdfs/client.conf 文件,上传/usr1目录下的IMG_0028.JPG文件)

/usr/bin/fdfs_test /etc/fdfs/client.conf upload /usr1/IMG_0028.JPG

结果如下,表示搭建成功;
在这里插入图片描述
以上图中的文件地址:http://10.2.32.53/group1/M00/00/00/CgIgNVyXc1yAKPodAAMd5WwB-dQ579_big.JPG
对应storage服务器的/home/fdfs_storage/data/00/00/wKisFFpBG9eAHaQvAAAWKd1hQR4158_big.jpg文件;
由于现在还没有和nginx整合无法使用http下载。

6、FastDFS 和nginx整合

6.1 在tracker上安装 nginx
在每个tracker上安装nginx,的主要目的是做负载均衡及实现高可用。如果只有一台tracker可以不配置nginx。
一个tracker对应多个storage,通过nginx对storage负载均衡;

6.2 在storage 上安装nginx
(1)上传 fastdfs-nginx-module_v1.16.tar.gz 到Centos服务器上;
(2)解压 fastdfs-nginx-module_v1.16.tar.gz 到 /usr/local目录下;
tar -zxvf fastdfs-nginx-module_v1.16.tar.gz -C /usr/local
(3)切换目录到: /usr/local/fastdfs-nginx-module/src/ 目录下
cd /usr/local/fastdfs-nginx-module/src/
(4)修改config文件,将文件中的所有 /usr/local/ 路径改为 /usr/

在这里插入图片描述
修改完成后:

在这里插入图片描述

(5)将fastdfs-nginx-module/src下的mod_fastdfs.conf拷贝至/etc/fdfs/下

cp mod_fastdfs.conf /etc/fdfs/

(6)并修改 /etc/fdfs/mod_fastdfs.conf 的内容;vi /etc/fdfs/mod_fastdfs.conf

base_path=/tmp 修改为 base_path=/home/fastdfs
base_path=/home/fastdfs
tracker_server=192.168.172.20:22122
#tracker_server=192.168.172.20:22122 #(多个tracker配置多行)
url_have_group_name=true #url中包含group名称
store_path0=/home/fdfs_storage #指定文件存储路径(上面配置的store路径)

(7)将libfdfsclient.so拷贝至/usr/lib下

cp /usr/lib64/libfdfsclient.so /usr/lib/

(8)创建nginx/client目录

mkdir -p /var/temp/nginx/client

8.3 Nginx的安装
(1)上传 nginx-1.8.0.tar.gz 到Centos服务器上;
(2)解压 nginx-1.8.0.tar.gz 到 /usr/local目录下;
tar -zxvf nginx-1.8.0.tar.gz -C /usr/local/
(3)安装nginx的依赖库
yum install pcreyum install pcre-develyum install zlibyum install zlib-develyum install opensslyum install openssl-devel
(4)进入nginx解压的目录下:cd /usr/local/nginx-1.8.0/
(5)加入模块命令配置
在这里插入图片描述

注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录;
(6)编译并安装

make && make install

安装成功后查看生成的目录,如下所示:
在这里插入图片描述

(7)拷贝配置文件到 /etc/fdfs 下;

cd /usr/local/FastDFS/confcp http.conf mime.types /etc/fdfs/

(8)修改nginx配置文件
在这里插入图片描述

mkdir /usr/local/nginx/logs # 创建logs目录
cd /usr/local/nginx/conf/
vim nginx.conf

做如下的修改:
在这里插入图片描述
在这里插入图片描述

说明:
  (a.) server_name指定本机ip;
  (b.) location /group1/M00/:group1为nginx 服务FastDFS的分组名称,M00是FastDFS自动生成编号,对应store_path0=/home/fdfs_storage,如果FastDFS定义store_path1,这里就是M01

(9)nginx的启动
cd /usr/local/nginx/sbin/
./nginx
查询nginx进程
  
(10) fastdfs 和 nginx 服务的开机自启动: http://www.cnblogs.com/yufeng218/p/8215381.html

7、在浏览器中访问上传到fastDFS的图片

因为Centos系统有防火墙,需要先关闭掉,才可以在浏览器中访问;
(1)CentOS 7.0默认使用的是firewall作为防火墙;若没有启用iptables 作为防火墙,则使用以下方式关闭防火墙:
systemctl stop firewalld.service #停止firewall
systemctl disable firewalld.service #禁止firewall开机启动
firewall-cmd --state #查看默认防火墙状态(关闭后显示notrunning,开启后显示running)
  
(2)若已经启用iptables作为防火墙,则使用以下方式关闭:
service iptables stop #临时关闭防火墙
chkconfig iptables off #永久关闭防火墙
防火墙的相关链接:http://www.jb51.net/article/101576.htm
         http://www.linuxidc.com/Linux/2015-05/117473.htm
(3)在谷歌浏览器中访问刚才上传的图片:
刚才上传的图片地址为:http://10.2.32.53/group1/M00/00/00/CgIgNVyXc1yAKPodAAMd5WwB-dQ579_big.JPG

<think>好的,用户现在想知道如何检查Linux系统上是否安装fastdfs-nginx-module。首先,我需要回顾之前用户遇到的错误是关于ngx_fastdfs_module未找到的,所以现在他们可能是在安装或配置过程中遇到了问题,想要确认模块是否已经正确安装。 用户的问题集中在如何查找该模块是否安装,所以需要从多个角度入手。首先,考虑Nginx的编译参数,因为第三方模块通常需要在编译时添加。用户可能已经按照之前的指导重新编译了Nginx,但需要确认是否成功。因此,检查Nginx的编译参数是关键的第一步,使用nginx -V命令查看输出中是否包含该模块的路径。 接下来,用户可能需要确认模块的源码是否存在,因为即使编译时添加了模块,如果源码路径不正确或者没有下载,也会导致问题。这时候需要检查默认的源码目录,比如/usr/local/src或者用户指定的位置,看看是否有对应的模块目录。 另外,动态模块的情况也不能忽视,尤其是较新版本的Nginx可能支持动态加载模块。这时候需要检查模块是否被编译成.so文件,并确认是否在配置文件中正确加载。用户可能不知道动态模块的存放路径,需要提示常见的路径如modules目录,或者通过nginx -V查找--modules-path参数。 此外,配置文件中的加载指令也是重要的一环,用户可能在配置文件中遗漏了load_module指令,导致模块没有被正确加载。需要指导用户检查nginx.conf中的相关配置。 用户还可能遇到其他问题,比如模块虽然存在但版本不兼容,或者依赖库缺失,这时候需要提示他们检查依赖项,如libfastcommon,以及模块与Nginx版本的兼容性。可能还需要建议查看编译日志,确认是否有错误信息。 最后,需要以清晰的步骤呈现,确保用户能够逐步排查问题。同时,要考虑到用户可能对Linux命令不太熟悉,需要给出具体的命令示例和路径,帮助他们直接执行检查。总结来说,需要从编译参数、源码存在性、动态模块、配置文件、依赖检查等多个方面全面覆盖,确保用户能够准确判断模块是否安装成功。</think>--- ### **检查 Linux 系统是否安装 fastdfs-nginx-module 的完整方法** --- #### **1. 通过 Nginx 编译参数验证** 该模块是第三方模块,**必须显式编译到Nginx中**才能生效。执行以下命令查看编译参数: ```bash nginx -V 2>&1 | grep fastdfs ``` - **有安装**:输出会显示类似 `--add-module=/path/to/fastdfs-nginx-module` - **未安装**:无任何输出 --- #### **2. 检查模块源码是否存在** 模块需要**先下载源码**才能编译,检查常见存放路径: ```bash # 默认可能存放的路径 ls /usr/local/src/ | grep fastdfs-nginx-module # 官方推荐路径 ls /usr/local/ | grep fastdfs-nginx-module # 自定义安装可能路径 ls /opt/ | grep fastdfs-nginx-module # 商业软件常见路径 # 精确搜索全盘(需要root权限) sudo find / -name "fastdfs-nginx-module" -type d 2>/dev/null ``` - **找到目录**:说明已下载源码(但可能未编译) - **未找到**:需要重新下载源码 --- #### **3. 检查动态模块文件(.so)** 如果Nginx版本≥1.9.11,可能以**动态模块**形式加载: ```bash # 检查默认模块目录 ls /usr/local/nginx/modules/ | grep fastdfs # 通过Nginx输出确认模块路径 nginx -V 2>&1 | grep modules-path # 在模块路径中查找 find $(nginx -V 2>&1 | grep modules-path | awk -F= '{print $2}') -name "ngx_http_fastdfs_module.so" ``` - **找到.so文件**:表示已编译为动态模块 - **未找到**:需重新编译 --- #### **4. 验证配置文件加载** 如果使用动态模块,需在 `nginx.conf` 顶部添加加载指令: ```nginx # 检查配置文件是否包含此指令 load_module modules/ngx_http_fastdfs_module.so; ``` --- #### **5. 补充排查方法** ```bash # 检查模块依赖库是否存在 ldconfig -p | grep libfastcommon # 依赖的基础库 # 查看编译日志(如果有) cat /usr/local/nginx/nginx_install.log | grep fastdfs # 尝试触发模块功能 curl -I http://localhost/group1/M00/00/00/test.txt # 观察Nginx日志中是否出现fastdfs相关记录 ``` --- ### **流程图解** $$ \begin{array}{ccc} \text{检查编译参数} & \rightarrow & \text{有输出=已编译} \\ \downarrow & \searrow & \\ \text{无输出} & & \text{验证模块文件} \\ \downarrow & & \downarrow \\ \text{搜索源码路径} & \leftarrow & \text{存在.so=动态模块} \\ & \searrow & \\ & & \text{检查配置文件} \\ \end{array} $$ --- ### **常见问题说明** 1. **源码存在 ≠ 模块已安装** 即使找到源码目录,也必须通过 `--add-module` 编译才能生效 2. **动态模块需要显式加载** 新编译的.so文件必须配合 `load_module` 指令使用 3. **版本匹配要求** fastdfs-nginx-module 需要与以下组件版本兼容: - Nginx 版本 - FastDFS 版本 - libfastcommon 版本 建议通过组合上述方法交叉验证,可准确判断模块状态。如果仍不确定,可提供 `nginx -V` 完整输出和 `find` 命令结果进一步分析。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值