FastDFS使用C语言编写的一款开源文件系统。为互联网量身定制,充分考虑了冗余备份,负载均衡,横向扩展等机制,并注重高可用、高性能等指标,使用FastDFS很容易搭建一套高性能的文件服务器集群提供文件上传、文件下载等服务。
FastDFS架构包括Tracker Server和Storage Server。客户端向Tracker Server请求,通过Tracker Server 调度最终由Storage Server完成文件上传和下载。
Tracker 管理集群
Storage 保存文件,分成多个组,组内同步。
跟dubbo架构有些类似。
客户端上传文件后存储在服务器并将文件ID返回给客户端,此ID用于以后访问服务器上的图片信息。包括:组名、虚拟磁盘路径、数据两级目录、文件名。
如:group1/M00/00/00/wKgloVkVcTaAf4rLAAKW8AEzyvk980.PNG
实现文件服务器
1、安装FastDFS。
2、测试FastDFS是否可用:
确认Tracker是否启动;确认Storage是否启动;确认Nginx是否可用
3、图片服务器的使用:FastDFS客户端需要官网下载。
当时用java客户端进行上传图片时,需要将FastDFS客户端的依赖加入。
有私服,将FastDFS客户端添加到Maven私服的第三方库,直接加入坐标使用;
没有私服,需要将FastDFS客户端,手动加入到本地Maven仓库。
4、编码步骤记录:
public static void main(String[] args) throws Exception {
// 1、加载配置文件,配置文件内部只有一行:tracker_server=192.168.37.161:22122,指明FastDFS的Tracker
ClientGlobal.init(System.getProperty("user.dir") + "/src/main/resources/tracker.conf");
// 2、创建一个TrackerClient对象,new即可
TrackerClient trackerClient = new TrackerClient();
// 3、使用TrackerClient对象创建连接,获取一个TrackerServer对象
TrackerServer trackerServer = trackerClient.getConnection();
// 4、创建一个StorageServer的引用,值为null
StorageServer storageServer = null;
// 5、创建一个StorageClient对象,需要两个参数TrackerServer对象和StorageServer的引用
StorageClient storageClient = new StorageClient(trackerServer, storageServer);
// 6、使用StorageClient对象上传图片
// storageClient.upload_file(file_buff, file_ext_name, meta_list)
String[] result = storageClient.upload_file("C:/Users/Administrator/Desktop/图/6.PNG", "PNG", null);
// 7、处理返回结果,长度为2,。第一个为:组名 ;第二个为:组内的路径
for (String str : result) {
System.err.println(str);
}
}
运行结果:
group1
M00/00/00/wKgloVkVfoyAYMZeAAVtnlfTdEU270.PNG