FastDFS-图片服务器的使用

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












  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值