草庐IT

fdfs文件服务环境搭建详细教程

猫的树 2023-10-12 原文

前言

Linux环境搭建少不了FastDFS的安装,本文记录Linux环境下安装fdfs的步骤。

一、安装包和环境准备

1.所需安装包

image.png

将安装包上传至服务器

2.编译环境

环境安装好的跳过此步骤

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

3.创建目录

mkdir data
mkdir fastdfs
在data目录下创建client、file、storage、tracker目录

[图片上传失败...(image-c15bdd-1652446961897)]

4.解压安装包

tar -zxvf libfastcommon-1.0.7.tar.gz
tar -zxvf FastDFS_v5.05.tar.gz
tar -zxvf nginx-1.12.1.tar.gz
tar -zxvf fastdfs-nginx-module-master.tar.gz

二、安装步骤

1.安装libfastcommon

libfatscommon 是 FastDFS 分离出的一些公用函数包,解压之后进入libfastcommon目录,执行./make.sh./make.sh install

cd libfastcommon-1.0.36/
./make.sh
./make.sh install

2.安装Fastdfs

同上,进入解压目录执行执行./make.sh./make.sh install

cd fastdfs-5.05/
./make.sh
./make.sh install

编译成功之后进入 /etc/fdfs,会出现client.conf.sample客户端文件、storage.conf.sampletracker.conf.sample两个基础配置文件,将这三个文件复制

cp client.conf.sample client.conf
cp storage.conf.sample storage.conf
cp tracker.conf.sample tracker.conf

再将fastdfs-5.05下conf文件夹中的http.conf和mime.types拷贝到 /etc/fdfs/中供nginx访问使用

cp http.conf /etc/fdfs/
cp mime.types /etc/fdfs/

[图片上传失败...(image-45d78d-1652446961897)]

3.tracker配置

修改配置文件

执行命令vim /etc/fdfs/tracker.conf

tracker服务器端口(默认22122,一般不修改)

port=22122

存储日志和数据的根目录

base_path=/data/fastdfs/tracker

修改如下:
[图片上传失败...(image-280bff-1652446961897)]

启动tracker服务器

执行命令service fdfs_trackerd start
启动成功后,在/data/fastdfs/tracker中找到两个新文件
[图片上传失败...(image-8bcea-1652446961897)]

4.storage配置

大致流程和tracker配置一样

修改配置文件

执行命令vim /etc/fdfs/storage.conf,修改内容:

storage服务端口(默认23000,一般不修改)

port=23000

数据和日志文件存储根目录

base_path=/data/fastdfs/storage

文件存储目录

store_path0=/data/fastdfs/file

tracker服务器IP和端口(修改为自己服务器的ip)

tracker_server=192.168.18.125:22122

http访问文件的端口(默认8888,看情况修改,和nginx中保持一致)

http.server_port=8086

日志文件存储路径
[图片上传失败...(image-e550a9-1652446961897)]
文件存储路径
[图片上传失败...(image-23e2c1-1652446961897)]
填写服务器ip(云服务器填内网ip)
[图片上传失败...(image-6c8618-1652446961897)]

启动storage服务器

执行命令service fdfs_storaged start
启动成功后,在/data/fastdfs/storage中找到两个新文件
[图片上传失败...(image-49a113-1652446961897)]

检验是否整合成功

执行/usr/bin/fdfs_monitor /etc/fdfs/storage.conf,成功如下
[图片上传失败...(image-f6a0ef-1652446961897)]

5.client配置

修改配置文件

执行命令vim /etc/fdfs/client.conf,修改内容:

base_path=/data/fastdfs/client
tracker_server=192.168.29.129:22122 #tracker服务器IP和端口

如图所示
[图片上传失败...(image-aa4a20-1652446961897)]

测试上传

/data/fastdfs下编写一个测试文件
[图片上传失败...(image-3e14e4-1652446961897)]

执行命令/usr/bin/fdfs_upload_file /etc/fdfs/client.conf /data/fastdfs/test.txt
[图片上传失败...(image-395d27-1652446961897)]
成功返回文件路径,如图:
[图片上传失败...(image-80da85-1652446961897)]
如果出现错误,请检查(tracker.conf、storage.conf、client.conf)base_path、store_path0配置路径是否正确路径需要一致。

6.nginx配置

上述文件如果想要在web上查看,就需要配置nginx和fastdfs-nginx-module模块

安装fastdfs-nginx-module模块

进入fastdfs-nginx-module-master/src中,执行命令cp mod_fastdfs.conf /etc/fdfs/将mod_fastdfs.conf文件复制到/etc/fdfs/目录下

执行命令vim /etc/fdfs/mod_fastdfs.conf修改 mod_fastdfs.conf 文件
[图片上传失败...(image-38e7af-1652446961897)]

fastdfs-nginx-module-master/src/config文件

ngx_module_incs="/usr/include/fastdfs /usr/include/fastcommon/"
CORE_INCS="$CORE_INCS /usr/include/fastdfs /usr/include/fastcommon/"

安装nginx

进入到nginx文件夹中,执行命令./configure --add-module=/data/soft/fastdfs-nginx-module-master/src (module后面是fastdfs-nginx-module-master的解压路径)

然后安装nginx,执行命令make && make install,安装成功编辑nginx.conf
[图片上传失败...(image-ad1b90-1652446961897)]
修改监听端口为8086 (和前面配置的端口一致),添加如下内容:

location ~/group([0-9])/M00 {
    ngx_fastdfs_module;
}

重启nginx之后,开放指定端口

firewall-cmd --zone=public --add-port=22122/tcp --permanent
firewall-cmd --zone=public --add-port=23000/tcp --permanent
firewall-cmd --zone=public --add-port=8086/tcp --permanent

如果需要其他代理访问,需要监听配置这台服务器的8086端口。

7.注意事项

如果nginx无法访问

  1. 请先检查防火墙是否关闭,或者端口是否开放
  2. mod_fastdfs.conf文件tracker_server是否一致

如果 unknown directive “ngx_fastdfs_module” in /usr/local/nginx/conf/nginx.conf:151,可能是nginx一直是启动的,必须要重启nginx才可以,nginx -s reload无效。

相关命令

  • 防火墙相关
  • [ 关闭] systemctl stop firewalld
  • [ 开启] systemctl start firewalld
  • [ 重启防火墙] firewall-cmd --reload
  • [ 开放指定端口] firewall-cmd --zone=public --add-port=1935/tcp --permanent
  • [ 查看端口号] netstat -ntlp
  • [ 查看端口使用情况] netstat -ntulp |grep 端口号
  • tracker服务
  • [启动] fdfs_trackerd /etc/fdfs/tracker.conf
  • [重启] fdfs_trackerd /etc/fdfs/tracker.conf restart
  • [关闭] fdfs_trackerd /etc/fdfs/tracker.conf stop
  • storage服务
  • [启动] fdfs_storaged /etc/fdfs/storage.conf
  • [重启] fdfs_storaged /etc/fdfs/storage.conf restart
  • [关闭] fdfs_storaged /etc/fdfs/storage.conf stop
  • nginx
  • [启动 ] /usr/local/nginx/sbin/nginx
  • [刷新配置文件]/usr/local/nginx/sbin/nginx -s reload
  • [重启]/usr/local/nginx/sbin/nginx -s reopen
  • [停止]/usr/local/nginx/sbin/nginx -s stop

8.分布式部署

tracker配置

vim /etc/fdfs/tracker.conf
port=22122 # tracker服务器端口(默认22122,一般不修改)
base_path=/home/lvjian # 存储日志和数据的根目录

storage配置

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

client测试

需要启动tracker、storage命令在下面启动项里
vim /etc/fdfs/client.conf
base_path=/home/lvjian
tracker_server=192.168.29.129:22122 #tracker服务器IP和端口
tracker_server=192.168.29.130:22122 #tracker服务器IP和端口
tracker_server=192.168.29.131:22122 #tracker服务器IP和端口
fdfs_upload_file /etc/fdfs/client.conf /usr/local/src/nginx-1.15.4.tar.gz #测试上传

配置nginx访问

vim /etc/fdfs/mod_fastdfs.conf
tracker_server=192.168.29.129:22122 #tracker服务器IP和端口
tracker_server=192.168.29.130:22122 #tracker服务器IP和端口
tracker_server=192.168.29.131:22122 #tracker服务器IP和端口
url_have_group_name=true
store_path0=/home/lvjian

nginx和之前配置一样

创作不易,关注、点赞就是对作者最大的鼓励,欢迎在下方评论留言
欢迎关注微信公众号:键指JAVA,定期分享Java知识,一起学习,共同成长。

有关fdfs文件服务环境搭建详细教程的更多相关文章

  1. ruby - 使用 RubyZip 生成 ZIP 文件时设置压缩级别 - 2

    我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看ruby​​zip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d

  2. ruby - 其他文件中的 Rake 任务 - 2

    我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时

  3. ruby-on-rails - 在 Rails 中将文件大小字符串转换为等效千字节 - 2

    我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,

  4. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  5. ruby-on-rails - Rails 3 中的多个路由文件 - 2

    Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题

  6. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  7. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  8. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  9. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  10. Ruby 写入和读取对象到文件 - 2

    好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信

随机推荐