java中使用分布式文件系统FastDFS

安装过程 ,比较麻烦,略

  1. 简介

    FastDFS 是用 c 语言编写的一款开源的分布式文件系统。FastDFS 为互联网量身定制, 充分考虑了冗余备份、负载均衡、线性扩容等机制,并注重高可用、高性能等指标,使用 FastDFS 很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务。
    FastDFS 架构包括 Trackerserver 和 Storageserver。客户端请求 Trackerserver 进行文 件上传、下载,通过 Trackerserver 调度最终由 Storageserver 完成文件上传和下载。
    Trackerserver 作用是负载均衡和调度,通过 Trackerserver 在文件上传时可以根据一些 策略找到 Storage server 提供文件上传服务。可以将 tracker 称为追踪服务器或调度服务 器。
    Storage server 作用是文件存储,客户端上传的文件最终存储在 Storage 服务器上, Storageserver 没有实现自己的文件系统而是利用操作系统 的文件系统来管理文件。可以将 storage 称为存储服务器。

    服务端两个角色:
    Tracker:管理集群, tracker 也可以实现集群。每个 tracker 节点地位平等。收集 Storage 集群的状态。
    Storage:实际保存文件 Storage 分为多个组,每个组之间保存的文件是不同的。每 个组内部可以有多个成员,组成员内部保存的内容是一样的,组成员的地位是一致的,没有主从的概念。

  2. 使用

//初始化配置文件
ClientGlobal.init("./src/main/resources/fastdfs.conf");
//创建调度客户端对象
TrackerClient trackerClient = new TrackerClient();
//获取服务端连接
TrackerServer trackerServer = trackerClient.getConnection();

StorageServer storageServer = null;
//使用调度服务对象根据某些策略获取上传的机器,封装到上传服务对象,由此创建上传对象
StorageClient storageClient = new StorageClient(trackerServer, storageServer);
//使用文件上传对象完成文件上传操作
//上传本地文件,也可以接收前台传来的文件通过数组上传
String[] pngs = storageClient.upload_appender_file("E:/2.png", "png", null);
for (String p : pngs) {
    System.out.println(p);
}
/*
 * group1/M00/00/00/wKiRkV3ZLxGEW4jRAAAAAOcGJ8Y854.png
 *
 * */

你可能感兴趣的:(Java)