Linux环境搭建FastDFS文件服务器(附带Nginx安装)

本文主要介绍在linux服务器如何搭建FastDFS文件服务器。大概分为9个步骤,由于内容较为繁琐。下面带你入坑!

首先简单介绍一下FastDFS是淘宝资深架构师余庆老师主导开源的一个分布式文件系统,用C语言编写。适应与中小企业,对文件不分块。

主要有Tracker(管理) 和Storage (储存)。
返回路径= 组名 /虚拟盘符{M00/00/02} /文件名
在这里插入图片描述

1、下载软件包

wget https://github.com/happyfish100/libfastcommon/archive/V1.0.7.tar.gzwget http://jaist.dl.sourceforge.net/project/fastdfs/FastDFS%20Nginx%20Module%20Source%20Code/fastdfs-nginx-module_v1.16.tar.gzwget https://github.com/happyfish100/fastdfs/archive/V5.05.tar.gzwget http://nginx.org/download/nginx-1.18.0.tar.gz

2、安装gcc

yum -y install gcc gcc-c++ autoconf pcre pcre-devel make automakeyum -y install wget httpd-tools vim

3、安装 libfastcommon

#进入libfastcommon压缩包目录解压,编译,安装
tar -zxvf libfastcommonV1.0.7.tar.gz#进入解压的libfastcommon-1.0.7目录,编译
./make.sh
./make.sh install#最后,将libfastcommon.so文件复制到usr/lib下 (请按照自己的实际文件路径修改)
cp /data/fastDFS/software/libfastcommon-1.0.7/src/libfastcommon.so /usr/lib

4、安装 FastDFS

解压FastDFS_v5.05.tar.gz,
tar -zxvf FastDFS_v5.05.tar.gz编译FastDFS
./make.sh
安装FastDFS
./make.sh install安装成功后将目录conf内的文件拷贝到/etc/fdfs目录下(请按照实际文件路径修改):
cp /data/fastDFS/software/FastDFS/conf/* /etc/fdfs/

5、安装 tracker

进入/etc/fdfs目录,修改tracker.conf文件。如果不存在,就拷贝tracker.conf.sample文件为tracker.conf,然后再修改:
base_path=/home/yuqing/fastdfs 修改成 base_path=/home/logs/fastdfs (注解:日志文件)http.server_port=8080 修改成 http.server_port=80 (注解:端口,80是方便默认)store_group=group1 (注解:组名)
其中,/home/logs/fastdfs目录如果不存在,就创建一个。之后,就启动tracker,
fdfs_trackerd /etc/fdfs/tracker.conf start查看是启动成功(出现如下提示,表示启动成功):restart重启
netstat -unltp | grep tracker

在这里插入图片描述

6、安装storage

由于storage和tracker运行的都是fastDFS程序,每一台服务器都部署一台fasfDFS,一台服务器是tracker,一台是storage

修改storage.conf文件。如果不存在,就拷贝storage.conf.sample文件为storage.conf,然后再修改:
base_path=/home/yuqing/fastdfs 修改成 base_path=/home/logs/storage (日志路径)
store_path0=/home/yuqing/fastdfs 修改成 store_path0=/home/data/storage  (实际储存文件路径,可以配置多个)
tracker_server=192.168.209.121:22122 修改成 tracker_server=192.168.2.231:22122 (ip为服务器ip地址,如果不确认,用ifconfig查询,连接tracker服务器地址)
group_name=group1 (必须和tracker的组名相同)
http.server_port=80 (这个端口也要改)
其中,如果/home/logs/storage和/home/data/storage不存在,就创建该目录然后,就启动storage
fdfs_storaged /etc/fdfs/storage.conf start查看是否成功(出现如下提示,表示启动成功)
netstat -unltp | grep storage

在这里插入图片描述
最后,查看tracker和storage是不是在通信:

fdfs_monitor /etc/fdfs/storage.conf

如下提示,出现ACTIVE,表示二者均正常启动,至此就可以进行上传文件测试了。
在这里插入图片描述

7、测试图片上传

Tracker和storage都已经安装完成,使用命令测试文件上传:
FastDFS提供一个文件上传命令:usr/bin/fdfs_test 测试文件上传。测试上传需要连接tracker服务器,连接storage服务器。因此需要指定一个配置文件:client.conf配置文件,通过Client.conf连接tracker服务器。

修改/etc/fdfs下client.conf 
base_path=/home/logs/client (日志目录)
tracker_server=192.168.2.231:22122  (tracker端口,ip为服务器ip,ifconfig能查到)测试命令
/usr/bin/fdfs_test /etc/fdfs/client.conf upload anti-steal.jpg

如下图返回地址则成功
在这里插入图片描述

8、安装Nginx

#gcc安装 
yum install gcc-c++#PCRE pcre-devel 安装
yum install -y pcre pcre-devel# zlib 安装
yum install -y zlib zlib-devel#OpenSSL 安装
yum install -y openssl openssl-devel解压、编译、安装。
tar -zxvf nginx-1.18.0.tar.gz
cd nginx-1.18.0
./configure
make
make install

9、安装 fastdfs-nginx-module

  1. 首先解压fastdfs-nginx-module_v1.16.tar.gz
  2. 修改/fastdfs-nginx-module/src/config文件
  3. 去掉所有的local(三个)
    在这里插入图片描述
拷贝usr/lib64目录下库文件libfdfsclient.so
cp /usr/lib64/libfdfsclient.so /usr/lib在nginx安装目录下执行如下命令:把module添加nginx中。通过设置安装参数方式添加模块。
cd nginx-1.18.0
./configure --add-module=../fastdfs-nginx-module/src
注意:我这里nginx-1.18.0和fastdfs-nginx-module在同一级目录,所以这样写重新安装编译
make && make install查看Nginx的模块
/usr/local/nginx/sbin/nginx -V复制 fastdfs-nginx-module 源码中的配置文件到/etc/fdfs 目录, 并修改
cd fastdfs-nginx-module/src
cp mod_fastdfs.conf /etc/fdfs/进入/etc/fdfs/修改mod_fastdfs.conf如下配置,其他默认
# 连接超时时间
connect_timeout=10# Tracker Server
tracker_server=192.168.2.231:22122(ip地址为本地地址,用ifconfig查询)# StorageServer 默认端口
storage_server_port=23000# 如果文件ID的uri中包含/group**,则要设置为true
url_have_group_name = true# Storage 配置的store_path0路径,必须和storage.conf中的一致
store_path0=/home/data/storage
# the base path to store log files
base_path=/home/logs/storage配置Nginx ,进入/usr/local/nginx/conf目录下修改nginx.conf
注意:无论你在哪解压安装的。必须进这个目录/usr/local/nginx/conf下修改nginx.conf
vim nginx.conf修改配置,其它的默认
在80端口下添加fastdfs-nginx模块location ~/group([0-9])/M00 {ngx_fastdfs_module;
}
注意:下面#user  nobody;改成 #user  root;

注意:
  listen 80 端口值是要与 /etc/fdfs/storage.conf 中的 http.server_port=80 (前面改成80了)相对应。如果改成其它端口,则需要统一,同时在防火墙中打开该端口
  location 的配置,如果有多个group则配置location ~/group([0-9])/M00 ,没有则不用配group。
在文件存储目录下创建软连接,将其链接到实际存放数据的目录,注意这个文件存储的位置后面多个data目录是系统自动生成的
ln -s /home/data/storage/data /home/data/storage/data/M00

启动nginx

#启动nginx
cd /usr/local/nginx/sbin/
./nginx 直接启动
/usr/local/nginx/sbin/nginx设置开机自启
vim /etc/rc.d/rc.local 
加入:/usr/local/nginx/sbin/nginx使/etc/rc.d/rc.local变成可执行文件
chmod +x /etc/rc.d/rc.local

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/414089.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

快速排序【hoare版本】【挖坑法】【双指针法】(数据结构)

快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法,其基本思想为:任取待排序元素序列中 的某元素作为基准值,按照该排序码将待排序集合分割成两子序列,左子序列中所有元素均小于基准值,右子序列中所有元素均…

android 和 opencv 开发环境搭建

本文详细说明给android项目添加opencv库的详细步骤,并通过实现图片灰度化来查看配置是否成功。 下载OPENCV ANDROID SDK 到官网下载 打开 https://opencv.org/releases/ 选择android,下载完成后解压出下面的文件: 安装android sdk 和 ndk …

Dubbo使用详解

简介 Dubbo是一个高性能、轻量级的开源Java RPC框架,由阿里巴巴公司开发并开源。它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。Dubbo使得应用可通过高性能的 RPC 实现服务的输出和输…

Redis相关命令详解及其原理

Redis概念 Redis,英文全称是remote dictionary service,也就是远程字典服务。这是kv存储数据库。Redis,包括所有的数据库,都是请求-回应模式,通俗来说就是数据库不会主动地要给前台推送数据,只有前台发送了…

Java研学-Maven基础

一 概述 Maven是一个跨平台的项目管理工具,主要用于基于 Java 平台的项目(Maven 底层为Java)构建、依赖包管理和项目信息管理,只需要运行一条简单的命令,就能高效的完成构建动作   Maven 能提供一种项目的依赖配置&a…

docker里Java服务执行ping命令模拟流式输出

文章目录 业务场景处理解决实现ping功能并实时返回输出实现长ping和中断请求docker容器找不到ping命令处理 业务场景 我们某市的客户,一直使用CS版本的信控平台,直接安装客户Windows server服务器上,主要对信号机设备进行在线管理、方案配时…

09 STM32 - PWM

9.1 PWM简介 脉冲宽度调制(Pulse Width Modulation,简称PWM),是利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术。简单一点,就是对脉冲宽度的控制。 9.2 PWM波原理 如下图所示,使用定时器定时,从0开始&#x…

VSCode使用Makefile Tools插件开发C/C++程序

提起Makefile,可能有人会觉得它已经过时了,毕竟现在有比它更好的工具,比如CMake,XMake,Meson等等,但是在Linux下很多C/C源码都是直接或者间接使用Makefile文件来编译项目的,可以说Makefile是基石…

SQL 最大连续合格次数 最大连胜记录次数 最大连败记录次数

有这样一个问题,工厂中要统计某个供应商送货检验的情况,依照其连续合格次数,决定是否免检,不使用游标或者循环,如何写这个sql。 此情景也可以用于统计连胜记录等 先要学习一下 窗函数LAG,指的是按分组和排…

统计学-R语言-6.1

文章目录 前言参数估计的原理总体、样本和统计量点估计区间估计评价估计量的标准有效性 总体均值的区间估计一个总体均值的估计(大样本)一个总体均值的估计(小样本估计) 练习 前言 本篇文章将开始介绍参数估计的相关知识。 参数估…

[笔记]深度学习入门 基于Python的理论与实现(四)

4. 神经网络的学习 这里说的‘学习’就是指从训练数据中自动获取最优权重参数的过程。为了进行学习,将导入损失函数这一指标。而学习的目的就是以该损失函数为基准,找出能使它的值达到最小的权重参数。为此,我们介绍利用了函数斜率的梯度法。…

O(1)插入、删除和随机元素[中等]

优质博文:IT-BLOG-CN 一、题目 实现RandomizedSet类: 【1】RandomizedSet()初始化RandomizedSet对象。 【2】bool insert(int val)当元素val不存在时,向集合中插入该项,并返回true;否则,返回false。 【3】…