Fastdfs 分布式文件管理系统

Fastdfs 分布式文件管理系统

概念:图片
缺点: 所有的问题文件全部存放在一台计算机中,如果这台计算机坏掉,那么会导致整个服务不可用,文件不能上传和下载 ,如果这台计算机磁盘损坏那么会丢失所有的文件,而且这台计算机的磁盘空间非常的有限,很容易达到磁盘的上限,导致无法上传文件

分布式文件系统

图片

优点:解决了传统方式的单点故障问题,如果某一个节点出现故障还有其它的节点可以用来读取和写入文件,可以提供数据的备份避免因为其它磁盘损坏导致的文件丢失,还可以提供库容的机制,无限的增加文件存放的空间上限。

Fastdfs 简介

FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储、文件同步、文件访问(文件上传、文件下载)等,解决了大容量存储和负载均衡的问题。特别适合以文件为载体的在线服务,如相册网站、视频网站等等,简单、灵活、高效、采用c语言开发,由阿里巴巴开发并开通。

Fastdfs 文件系统有两大部分组成: 一个是客户端 ,一个是服务端

客户端通常指的是我们的程序,也就是我们的java 代码,Java代码去连接Fastdfs、操作Fastdfs ,Fastdfs 提供了专有的API访问。

服务端有两个部分组成: 一个是跟踪器(tracker) 一个是存储节点(storage)

跟踪器(tracker)主要做调度的工作: 相当于是一个纽扣,比如文件的上传功能

1、client询问tracker上传到的storage,注意,它不需要附加参数

2、tracker返回一台可用的storage

3、client直接和storage通讯完成文件上传

存储节点(storage) 用于存储文件,包括文件和文件属性都保存到存储服务器磁盘上,完成文件管理的所有功能;文件存储,文件同步,文件访问等。

Fastdfs环境的搭建
yum install git gcc gcc-c++ make automake autoconf libtool pcre pcre-devel zlib zlib-devel openssl-devel ubuntu 的差什么就装什么

说明位置
所有安装包/usr/local/src
数据存储位置/home/dfs/
#这里我为了方便把日志什么的都放到了dfs
mkdir /home/dfs #创建数据存储目录
cd /usr/local/src #切换到安装目录准备下载安装包

安装libfastcommon

git clone https://github.com/happyfish100/libfastcommon.git --depth 1
cd libfastcommon/
./make.sh && ./make.sh install #编译安装

参考:https://github.com/happyfish100/fastdfs/wiki#%E5%8D%95%E6%9C%BA%E9%83%A8%E7%BD%B2

安装FastDFS

cd ../ #返回上一级目录
git clone https://github.com/happyfish100/fastdfs.git --depth 1
cd fastdfs/
./make.sh && ./make.sh install #编译安装
#配置文件准备
cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf
cp /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配置

#服务器ip为 192.168.52.1
#我建议用ftp下载下来这些文件 本地修改
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  # 第一个存储目录
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
tracker_server=192.168.52.1:22122    #tracker服务器IP和端口
#保存后测试,返回ID表示成功 如:group1/M00/00/00/xx.tar.gz
fdfs_upload_file /etc/fdfs/client.conf /usr/local/src/nginx-1.15.4.tar.gz

测试上传失败:

1.测试失败的话 我们需要重启tracker和storage

2.依次在终端输入:
pkill -9 fdfs
/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf

配置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安装包,引用返回的ID
http://172.18.3.94:8888/group1/M00/00/00/rBIDXl_0IIuAYDbiAAmOgczu2y4488.jpg
#弹出下载单机部署全部跑通

测试下载 :

要想在浏览器上下载,我们需要配置nginx访问, 需要安装fastdfs-nginx-module,和安装nginx 配置好以后即可访问。

http://172.18.3.94:8888/group1/M00/00/00/rBIDXl_0IIuAYDbiAAmOgczu2y4488.jpg

fdfs_download_file /etc/fdfs/client.conf group1/M00/00/00/rBIDXl_tjFaAMazxAAmOgczu2y4728.jpg

nginx 扩展模块的执行流程

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rRy6jYUb-1615345390941)(/home/pf/.config/Typora/typora-user-images/image-20210105194508872.png)]

集成fastdfs

1.导入依赖

<dependency>
	<groupId>FastDfs</groupId>
	<artifactId>classes</artifactId>
	<version>1.27</version>
</dependency>

如果下载不了 我们就去官网把zip下载下来,解压。 打成jar的形式

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-y8zS91Ln-1615345390964)(/home/pf/.config/Typora/typora-user-images/image-20201223213031423.png)].

参考:https://blog.csdn.net/dongdingzhuo/article/details/78731704#commentBox

导入jar包

<dependency>
    <groupId>org.apache</groupId>
    <artifactId>fastdfs-client</artifactId>
    <scope>system</scope>
    <version>1.0</version>
    <systemPath>${project.basedir}/src/main/resources/jar/fastdfs-client-java-1.29-SNAPSHOT.jar</systemPath>
</dependency>
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.8.1</version>
    <configuration>
        <source>1.8</source>
        <target>1.8</target>
        <encoding>UTF-8</encoding>
        <compilerArguments>
            <extdirs>${project.basedir}/src/main/resources/jar</extdirs>
        </compilerArguments>
    </configuration>
</plugin>
 <resources>
        <resource>
            <directory>${basedir}/src/main/resources</directory>
            <filtering>true</filtering>
            <includes>
                <include>**/*.txt</include>
            </includes>
        </resource>
        <resource>
            <directory>${basedir}/src/main/resources</directory>
            <targetPath>config/</targetPath>
            <includes>
                <include>**/*.xml</include>
            </includes>
        </resource>
        <resource>
            <directory>${basedir}/src/main/resources</directory>
            <filtering>true</filtering>
            <includes>
                <include>**/*.properties</include>
            </includes>
        </resource>
        <resource>
            <directory>${basedir}/src/main/resources</directory>
            <excludes>
                <exclude>**/*.properties</exclude>
            </excludes>
        </resource>
        <resource>
            <directory>${basedir}/src/main/resources</directory>
            <targetPath>BOOT-INF/lib/</targetPath>
            <includes>
                <include>**/*.jar</include>
            </includes>
        </resource>
    </resources>

</build>

配置nginx

修改nginx.conf配置

建议打开:user root;

worker_processes配置成CPU核心数的2倍;

配置日志文件存放目录:

​ access_log /home/zf/nginx/factoryTest/access.log;

​ error_log /home/zf/nginx/factoryTest/error.log;

http模块加入文件上传大小:client_max_body_size 100M;

如部署前端项目:gzip on可开启;

如需加入自定义配置文件:http模块配置include conf.d/*.conf;

2. 加入开机启动项

-添加开机启动服务

sudo vim /lib/systemd/system/nginx.service

-加入以下内容

[Unit]

Description=nginx service

After=network.target

[Service]

Type=forking

ExecStart=/usr/local/nginx/sbin/nginx

ExecReload=/usr/local/nginx/sbin/nginx -s reload

ExecStop=/usr/local/nginx/sbin/nginx -s quit

PrivateTmp=true

[Install]

WantedBy=multi-user.target

-设置开机启动

systemctl daemon-reload

systemctl enable nginx.service

3. 相关命令

-启动:systemctl start nginx

-停止:systemctl stop nginx

-查看服务状态:systemctl status nginx

-重启:systemctl restart nginx

报错: nginx 启动失败 我们应该在usr/local/nginx下配置 而不是在usr/local/src/naginx 下配置 src 一般放的是源码

FastDFS中fdfs_trackerd和fdfs_storaged的启动、重启、终止命令

启动:
sudo service fdfs_trackerd start
sudo service fdfs_storaged start
12
重启:
sudo /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart
sudo /usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart
12
终止:
sudo /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf stop
sudo /usr/bin/fdfs_storaged /etc/fdfs/storage.conf stop
12

注意点:
我们要是使用终止命令或者使用 kill -9 fdfs进程id 来终结fdfs_storaged服务的,然后用上面的启动命令是启动不了的,因为log日志问题,会出现下面的错误
在这里插入图片描述
一般在我们跟换ip地址的时候,重启fdfs服务,就使用重启命令就行。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值