Springboot整合fastdfs-分布式文件存储

一、快速开始

1、添加依赖
xml 复制代码
 <dependency>
    <groupId>com.luhuiguo</groupId>
    <artifactId>fastdfs-spring-boot-starter</artifactId>
    <version>0.2.0</version>
</dependency>
<dependency>
    <groupId>org.csource</groupId>
    <artifactId>fastdfs-client-java</artifactId>
    <version>1.27-SNAPSHOT</version>
</dependency>
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-configuration-processor</artifactId>
	<optional>true</optional>
</dependency>
2、添加配置项
yaml 复制代码
# fdfs配置
fdfs:
  connect-timeout: 2000 # 连接服务器超时时间
  so-timeout: 3000    
  tracker-list: ${ip}:${port}
  http:
    path: http://${ip}:${port}/ #http链接前缀   
3、新建 fdfs_client.conf(可忽略)
properties 复制代码
connect_timeout = 60
network_timeout = 60
charset = UTF-8
http.tracker_http_port = 8080
http.anti_steal_token = no
http.secret_key = 123456
tracker_server = 192.168.53.85:22122
2、FastDFS客户端工具
java 复制代码
@Slf4j
public class FastDFSClient {
	//分片客户端
    private static TrackerClient trackerClient;
    //分片服务端
	private static TrackerServer trackerServer;
    //存储桶客户端
	private static StorageClient storageClient;
    //存储桶服务端
	private static StorageServer storageServer;
	
	static {
		try {
            //引入配置
			String filePath = new ClassPathResource("fdfs_client.conf").getFile().getAbsolutePath();;
			ClientGlobal.init(filePath);
			trackerClient = new TrackerClient();
			trackerServer = trackerClient.getConnection();
			storageServer = trackerClient.getStoreStorage(trackerServer);
		} catch (Exception e) {
			logger.error("FastDFS Client Init Fail!",e);
		}
	}
    
    //文件上传
    @SneakyThrows
	public static String[] upload(FastDFSFile file) {
		NameValuePair[] meta_list = new NameValuePair[1];
		meta_list[0] = new NameValuePair("author", file.getAuthor());
		long startTime = System.currentTimeMillis();
		String[] uploadResults = null;
		storageClient = new StorageClient(trackerServer, storageServer);
        uploadResults = storageClient.upload_file(file.getContent(), file.getExt(), meta_list);
        if(null == uploadResults) return null;
		String groupName = uploadResults[0];
		String remoteFileName = uploadResults[1];
		return uploadResults;
	}
    
    //获取File
    @SneakyThrows
	public static FileInfo getFile(String groupName, String remoteFileName) {
		storageClient = new StorageClient(trackerServer, storageServer);
        return storageClient.get_file_info(groupName, remoteFileName);
	}
    
    //下载文件
    @SneakyThrows
	public static InputStream downFile(String groupName, String remoteFileName) {
		storageClient = new StorageClient(trackerServer, storageServer);
        byte[] fileByte = storageClient.download_file(groupName, remoteFileName);
        InputStream ins = new ByteArrayInputStream(fileByte);
        return ins;
	}
    
    //删除文件
    @SneakyThrows
	public static void deleteFile(String groupName, String remoteFileName) {
		storageClient = new StorageClient(trackerServer, storageServer);
		int i = storageClient.delete_file(groupName, remoteFileName);
		logger.info("delete file successfully!!!" + i);
	}
    
    //获取存储器
    @SneakyThrows
	public static StorageServer[] getStoreStorages(String groupName){
		return trackerClient.getStoreStorages(trackerServer, groupName);
	}
    
    //获取FetchStorages
    @SneakyThrows
	public static ServerInfo[] getFetchStorages(String groupName,String remoteFileName) {
		return trackerClient.getFetchStorages(trackerServer, groupName, remoteFileName);
	}
    
    // 获取存储器的URL
    @SneakyThrows
	public static String getTrackerUrl() {
		return "http://"+trackerServer.getInetSocketAddress().getHostString()+":"
            +ClientGlobal.getG_tracker_http_port()+"/";
	}
    @Data
    public static class FastDFSFile {
        //文件名
        private String name;
        //文件内容
        private byte[] content;
        //文件拓展名
        private String ext;
        //文件的md5
        private String md5;
        //文件做着
        private String author;
    }
}
相关推荐
陪我一起学编程21 分钟前
Rust 不可变借用:从规则约束到内存安全的深度思考
后端·rust·编程语言
今日说"法"4 小时前
Rust探秘:所有权转移在函数调用中的表现
开发语言·后端·rust
刘一说6 小时前
深入理解 Spring Boot 嵌入式 Web 容器:从原理到性能调优
前端·spring boot·firefox
你的人类朋友6 小时前
设计模式的原则有哪些?
前端·后端·设计模式
程序员小凯6 小时前
Spring Boot文件处理与存储详解
java·spring boot·后端
菜鸡儿齐7 小时前
kafka简介
分布式·kafka
周杰伦_Jay7 小时前
【实战|旅游知识问答RAG系统全链路解析】从配置到落地(附真实日志数据)
大数据·人工智能·分布式·机器学习·架构·旅游·1024程序员节
2501_938774298 小时前
Leaflet 弹出窗实现:Spring Boot 传递省级旅游口号信息的前端展示逻辑
前端·spring boot·旅游
ruleslol9 小时前
SpringBoot13-文件上传02-阿里云OSS
spring boot
武子康9 小时前
大数据-139 ClickHouse MergeTree 最佳实践:Replacing 去重、Summing 求和、分区设计与物化视图替代方案
大数据·后端·nosql