文件异步多备常用方案

本文探讨了在业务中确保文件安全存储的场景,需要将文件A同时上传到两个云存储服务oss a和oss b。文章列举了四种异步上传策略,包括直接读取内存、创建临时文件、多句柄操作和使用硬链接,并分析了各自的优缺点。总结强调选择策略应根据具体业务场景权衡,提供思路供参考。
摘要由CSDN通过智能技术生成

业务需求上经常存在需要对同一个文件进行双上传,上传到不同云存储桶,以防出现某一个云厂商因各种意外导致自身服务出现不可用的情况,当然,还有其他措施可以避免,现在只针对通过程序业务代码而双写存储的这个场景。



业务场景

文件A上传到oss a,同时也需要将这个文件A异步上传到oss b,而文件A在主协程会被remove。

下面有份伪代码去描述这个场景

func ABC() {
   
	
	file, err := os.Open(path)
	if err != nil {
   
		return
	}
	defer func() {
   
		file.Close()
		os.Remove(path)
	}()

	...
	// 上传到oss a
	upload2OssA(file)

	
	...

	// TODO 异步上传到oss b

}

我们可以看到主routine打开了一个文件,并且上传到oss a,程序结束后会close文件且remove文件了,现在希望对这个文件异步上传到oss b



方式一

将文件内容读取出来上传

func ABC() {
   

	file, err := os.Open(path)
	if err != nil {
   
		return
	}
	defer func() {
   
		file.Close()
		os.Remove(path)
	}()

	...
	// 上传到oss a
	upload2OssA(file)


	...

	// TODO 异步上传到oss b
	method1(file
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
现如今,随着互联网的迅速发展,对于高并发,大流量的处理需求越来越多。在这样的情况下,传统的同步通信模式无法满足这种需求,因为同步通信方式会导致系统的实时性下降,响应速度变慢等问题。所以异步通信就成了重要的解决方案,而rabbitmq正是一种被广泛使用的异步通信工具之一。 rabbitmq是一个高度可靠,可扩展的消息代理,实现了AMQP协议。它可以完成消息的发送,接受和分发,适用于各种场景,比如:微服务架构,货物物流跟踪等。在使用rabbitmq的时候,常用的几个概念就是:producer,exchange,queue,consumer。 producer(生产者):使用rabbitmq client发送消息。 exchange(交换机):接收producer发送的消息,并将它分配给其它的queue进行存储。 queue(队列):存储exchange分配的消息。 consumer(消费者):从queue里面取出消息进行处理。 如何整合rabbitmq? 1.在pom.xml文件中加入rabbitmq的依赖。(可自行在maven仓库搜索) 2.在项目中编写producer和consumer,使用client进行消息发送和接受。 3.编写配置类,配置队列,交换机和bindings,这个非常重要,因为这决定了消息的路由规则。 4.使用spring提供的@RabbitListener注解,监听队列。@RabbitListener注解标注了一个方法,该方法会在监听到前面参数上配置的queue中有消息时自动执行。 5.在producer中使用rabbitTemplate对象发送消息。 整合rabbitmq异步通信可以完美地解决高并发,高流量,高吞吐量等问题。总结一下需要做的工作,就是编写producer和consumer,配置队列,交换机和bindings,使用@RabbitListener注解监听队列,使用rabbitTemplate对象发送消息。这些步骤都需要仔细考虑,只有正确的使用和配置才能达到最佳的使用效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值