FastDFS轻量级分布式文件系统部署

时间:2022-02-01 06:13:41

FastDFS介绍

FastDFS 是一个由 C 语言实现的开源轻量级分布式文件系统,作者余庆,支持 Linux、FreeBSD、AID 等 Unix 系统,解决了大数据存储和读写负载均衡等问题,适合存储 4KB~500MB 之间的小文件,如图片网站、短视频网站、文档、app 下载站等,UC、京东、支付宝、迅雷、酷狗等都有使用。

 

FastDFS上传下载的流程

FastDFS轻量级分布式文件系统部署

 

4.4 利用Java客户端调用FastDFS

服务器安装完毕后,咱们通过Java调用fastdfs

加载Maven依赖

fastdfs 没有在中心仓库中提供获取的依赖坐标。

只能自己通过源码方式编译,打好jar 包,安装到本地仓库。

官方仓库地址:

https://github.com/happyfish100/fastdfs-client-java

FastDFS轻量级分布式文件系统部署

直接用idea 直接把这个源码作为模块导入工程

FastDFS轻量级分布式文件系统部署

别的不用改,只把pom.xml中的版本改成1.27。

FastDFS轻量级分布式文件系统部署

然后右边 执行install 就好了

FastDFS轻量级分布式文件系统部署

安装好了 ,别的模块就可以直接使用这个坐标了。

1 <groupId>org.csource</groupId>
2 <artifactId>fastdfs-client-java</artifactId>
3 <version>1.27</version>

 

然后可以进行一下上传的测试

 1 @Test
 2 public void textFileUpload() throws IOException, MyException {
 3     String file = this.getClass().getResource("/tracker.conf").getFile();
 4     ClientGlobal.init(file);
 5     TrackerClient trackerClient=new TrackerClient();
 6     TrackerServer trackerServer=trackerClient.getConnection();
 7     StorageClient storageClient=new StorageClient(trackerServer,null);
 8     String orginalFilename="e://victor.jpg";
 9     String[] upload_file = storageClient.upload_file(orginalFilename, "jpg", null);
10     for (int i = 0; i < upload_file.length; i++) {
11         String s = upload_file[i];
12         System.out.println("s = " + s);
13     }
14 
15 }

加入tracker.conf文件

FastDFS轻量级分布式文件系统部署

1 tracker_server=192.168.67.162:22122
2 
3 # 连接超时时间,针对socket套接字函数connect,默认为30秒
4 connect_timeout=30000
5 
6 # 网络通讯超时时间,默认是60秒
7 network_timeout=60000

打印结果

FastDFS轻量级分布式文件系统部署

这个打印结果实际上就是我们访问的路径,加上FastDFS服务器地址我们可以拼接成一个字符串

http://127.0.0.1/group1/M00/00/00/wKhDo1qjU2qAWKQmAAATla901AQ534.jpg

直接放到浏览器去访问就可以访问到了