fastdfs

作者: 刘小刀tina | 来源:发表于2020-05-04 18:17 被阅读0次

1.编译环境

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

2.创建磁盘目录

a. 创建数据存储目录
mkdir /home/dfs
b.切换到安装目录准备下载安装包
cd /usr/local/src

3.安装libfatscommon

a.下载git安装包
git clone https://github.com/happyfish100/libfastcommon.git --depth 1
b.编译安装
cd libfastcommon/
./make.sh && ./make.sh install

4.安装FastDFS

a.返回上一级目录
cd ../
b.下载git安装包
git clone https://github.com/happyfish100/fastdfs.git --depth 1
c.进入目录
cd fastdfs/
d.编译安装
./make.sh && ./make.sh install
e.配置文件准备


5.安装fastdfs-nginx-module

a.返回上一级目录
cd ../

b.下载git安装包
git clone https://github.com/happyfish100/fastdfs-nginx-module.git --depth 1

c.复制配置文件
cp /usr/local/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs

6.安装nginx

a.下载nginx压缩包
wget http://nginx.org/download/nginx-1.15.4.tar.gz
b.解压
tar -zxvf nginx-1.15.4.tar.gz
c.进入nginx目录
cd nginx-1.15.4/
d.添加fastdfs-nginx-module模块到nginx
./configure --add-module=/usr/local/src/fastdfs-nginx-module/src/
e.编译安装
make && make install

7.修改配置

a.tracker配置
vim /etc/fdfs/tracker.conf

#需要修改的内容如下
port=22122  # tracker服务器端口(默认22122,一般不修改)
base_path=/home/dfs  # 存储日志和数据的根目录

b.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中保持一致)

c.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

d.配置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

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;
    }
}

8.启动命令

a.tracker

/etc/init.d/fdfs_trackerd start #启动tracker服务
/etc/init.d/fdfs_trackerd restart #重启动tracker服务
/etc/init.d/fdfs_trackerd stop #停止tracker服务
chkconfig fdfs_trackerd on #自启动tracker服务

b.storage

/etc/init.d/fdfs_storaged start #启动storage服务
/etc/init.d/fdfs_storaged restart #重动storage服务
/etc/init.d/fdfs_storaged stop #停止动storage服务
chkconfig fdfs_storaged on #自启动storage服务

c.nginx

/usr/local/nginx/sbin/nginx #启动nginx
/usr/local/nginx/sbin/nginx -s reload #重启nginx
/usr/local/nginx/sbin/nginx -s stop #停止nginx

检查集群状态

/usr/bin/fdfs_monitor /etc/fdfs/storage.conf
# 会显示会有几台服务器 有3台就会 显示 Storage 1-Storage 3的详细信息

9.建立Springboot项目访问测试

a.引入swagger和fdfs依赖

        <!-- FastDFS依赖 -->
        <dependency>
            <groupId>com.github.tobato</groupId>
            <artifactId>fastdfs-client</artifactId>
            <version>1.26.5</version>
        </dependency>
        <!-- swagger用于定义API文档 -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

        <!--美化swagger-->
        <dependency>
            <groupId>com.github.xiaoymin</groupId>
            <artifactId>swagger-bootstrap-ui</artifactId>
            <version>1.9.3</version>
        </dependency>

b.编写swagger和fdfs配置类

package com.xiaokai.demo.springboot.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

/**
 * SwaggerConfig
 * Description: <br/>
 * date: 2020/5/3 18:54<br/>
 *
 * @author lvxk<br />
 * @since JDK 1.8
 */
@Configuration
public class SwaggerConfig {

    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.xiaokai.demo.springboot.controller")) //此次每次使用须换成自己的web接口的全限定类名
                //.paths(AppUtility.isProd() ? PathSelectors.none() : PathSelectors.any())
                .paths(PathSelectors.any())
                .build();
    }
    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("FastDFS - 文件测试接口")
                .description("FastDFS - 文件测试接口")
                .termsOfServiceUrl("http://localhost:8071/swagger-ui.html")
                .contact(new Contact("xiaokai.lv", "http://localhost:8071/swagger-ui.html", "lvxiaokai@aliyun.com"))
                .version("1.0")
                .build();
    }
}

fdfs配置

package com.xiaokai.demo.springboot.config;

import com.github.tobato.fastdfs.FdfsClientConfig;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.EnableMBeanExport;
import org.springframework.context.annotation.Import;
import org.springframework.jmx.support.RegistrationPolicy;

/**
 * DfsConfig
 * Description: <br/>
 * date: 2020/5/3 18:51<br/>
 *
 * @author lvxk<br />
 * @since JDK 1.8
 */
@Configuration
@Import(FdfsClientConfig.class)
// Jmx重复注册bean的问题
@EnableMBeanExport(registration = RegistrationPolicy.IGNORE_EXISTING)
public class DfsConfig {
}

建立测试Controller

package com.xiaokai.demo.springboot.controller;

import com.xiaokai.demo.springboot.util.FileDfsUtil;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.http.ResponseEntity;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

import javax.annotation.Resource;

/**
 * 一些声明信息
 * Description: <br/>
 * date: 2020/5/3 18:56<br/>
 *
 * @author lvxk<br />
 * @since JDK 1.8
 */
@RestController
@Api(tags = "FastDFS文件测试")
public class FileController {

    @Resource
    private FileDfsUtil fileDfsUtil ;
    /**
     * 文件上传
     */
    @ApiOperation(value="上传文件", notes="测试FastDFS文件上传")
    @RequestMapping(value = "/uploadFile",headers="content-type=multipart/form-data", method = RequestMethod.POST)
    public ResponseEntity<String> uploadFile (@RequestParam("file") MultipartFile file){
        String result ;
        try{
            String path = fileDfsUtil.upload(file) ;
            if (!StringUtils.isEmpty(path)){
                result = path ;
            } else {
                result = "上传失败" ;
            }
        } catch (Exception e){
            e.printStackTrace() ;
            result = "服务异常" ;
        }
        return ResponseEntity.ok(result);
    }
    /**
     * 文件删除
     */
    @RequestMapping(value = "/deleteByPath", method = RequestMethod.GET)
    public ResponseEntity<String> deleteByPath (){
        String filePathName = "group1/M00/00/00/wKhIgl0n4AKABxQEABhlMYw_3Lo825.png" ;
        fileDfsUtil.deleteFile(filePathName);
        return ResponseEntity.ok("SUCCESS") ;
    }
}

c.打开swagger页面测试上传接口选择图片并上传,成功会返回url


image.png

d.浏览器输入服务器ip:8888/url地址即可


image.png

相关文章

  • FastDFS 和 Nginx 整合

    1、安装 FastDFS Centos 7 安装 FastDFS 2、配置 fastdfs-nginx-modul...

  • 分布式FastDFS集群部署

    FastDFS FastDFS的作者余庆在其 GitHub 上是这样描述的:“FastDFS is an open...

  • 使用docker安装fastDFS

    使用Docker安装FastDFS 获取镜像可以利用已有的FastDFS Docker镜像来运行FastDFS。 ...

  • FastDFS

    1.FastDFS介绍 1.1FastDFS构成 FastDFS由存储服务器(Storage Server)、 跟...

  • FastDFS安装

    FastDFS安装报告 [TOC] 实验要求 安装 FastDFS这个开源的轻量级的分布式文件系统FastDFS ...

  • FastDFS集群部署

    之前介绍过关于FastDFS单机部署,详见博文:FastDFS单节点部署 下面来看下FastDFS集群部署,实现高...

  • 在CentOS上搭建FastDFS+nginx

    一、软件下载 fastdfs libfastcommon fastdfs-nginx-module nginx 二...

  • FastDFS 集群

    Centos 7 安装 FastDFS CentOS 7 安装 Nginx FastDFS 和 Nginx 整合 ...

  • Django开发教程(四)

    十四、分布式图片存储服务器FastDFS 14.1 什么是FastDFS FastDFS 是用 c 语言编写的一款...

  • fastDFS 介绍

    3.2.1什么是FastDFS FastDFS 是用 c 语言编写的一款开源的分布式文件系统。FastDFS 为互...

网友评论

      本文标题:fastdfs

      本文链接:https://www.haomeiwen.com/subject/mimyghtx.html