当前位置: 首页 > news >正文

给装修公司做网站没建网站 备案

给装修公司做网站,没建网站 备案,wordpress经典博客主题,芜湖建设网站解题思路 采用分片上传,同时每个分片多线程上传可以加速上传速度,上传速度提升10倍左右 在阿里云OSS Go SDK中,bucket.UploadStream 函数并没有直接提供,而是通过 bucket.UploadFile 或者 bucket.PutObject 等函数来实现文件上传…

解题思路

采用分片上传,同时每个分片多线程上传可以加速上传速度,上传速度提升10倍左右

在阿里云OSS Go SDK中,bucket.UploadStream 函数并没有直接提供,而是通过 bucket.UploadFile 或者 bucket.PutObject 等函数来实现文件上传。对于大文件上传,可以使用分片上传的方式,并且结合多线程来加速上传过程。

要结合多线程上传每个分片,你可以使用Go语言的并发特性,例如使用 goroutines 和 channels。以下是一个简化的示例,展示了如何使用Go语言并发上传文件的各个分片:

package mainimport ("bytes""context""fmt""io""log""os""sync""github.com/aliyun/aliyun-oss-go-sdk/oss"
)func main() {// 创建OSS客户端。client, err := oss.New("<Endpoint>", "<AccessKeyId>", "<AccessKeySecret>")if err != nil {log.Fatalf("Error creating OSS client: %v", err)}// 获取存储空间。bucket, err := client.Bucket("<BucketName>")if err != nil {log.Fatalf("Error getting bucket: %v", err)}// 打开本地文件。localFilePath := "<YourLocalFilePath>"file, err := os.Open(localFilePath)if err != nil {log.Fatalf("Error opening local file: %v", err)}defer file.Close()// 获取文件大小。fileInfo, err := file.Stat()if err != nil {log.Fatalf("Error getting file info: %v", err)}fileSize := fileInfo.Size()// 设置分片大小。partSize := int64(10 * 1024 * 1024) // 10MBuploadID, err := bucket.InitiateMultipartUpload("<YourObjectKey>")if err != nil {log.Fatalf("Error initiating multipart upload: %v", err)}// 创建一个通道来收集上传结果。partsChan := make(chan oss.UploadPart, 10)var wg sync.WaitGroup// 计算分片数量。partCount := int((fileSize+partSize-1)/(partSize))// 上传每个分片。for i := int64(0); i < int64(partCount); i++ {wg.Add(1)partNumber := i + 1offset := i * partSizevar reader io.Readerif partNumber == int64(partCount) {reader = io.LimitReader(file, fileSize-offset)} else {reader = io.MultiReader(io.LimitReader(file, partSize), bytes.NewReader(nil))}// 使用goroutine并发上传分片。go func(partNumber int64, offset int64, reader io.Reader) {defer wg.Done()var buffer bytes.Bufferbuffer.ReadFrom(reader)partData := buffer.Bytes()var err errorif partData, err = io.ReadAll(reader); err != nil {log.Printf("Error reading part %d: %v", partNumber, err)return}if partNumber*partSize+int64(len(partData)) > fileSize {partData = partData[:fileSize-(partNumber-1)*partSize]}uploadResult, err := bucket.UploadPart(uploadID, partNumber, bytes.NewReader(partData), int64(len(partData)))if err != nil {log.Printf("Error uploading part %d: %v", partNumber, err)return}partsChan <- oss.UploadPart{ETag:       uploadResult.ETag,PartNumber: partNumber,}}(partNumber, offset, reader)}// 等待所有分片上传完成。wg.Wait()close(partsChan)// 收集所有分片的结果。var parts []oss.UploadPartfor part := range partsChan {parts = append(parts, part)}// 完成分片上传。if err := bucket.CompleteMultipartUpload(uploadID, parts); err != nil {log.Fatalf("Error completing multipart upload: %v", err)}log.Println("Upload complete!")
}

在这个示例中,我们首先初始化了一个分片上传会话,并设置了每个分片的大小为10MB。接着,通过循环读取文件内容并逐个上传分片,最终完成整个文件的上传。我们使用了 sync.WaitGroup 来等待所有分片上传完成,并使用了一个通道 partsChan 来收集上传结果。

请确保你已经替换了 <Endpoint>, <AccessKeyId>, <AccessKeySecret>, <BucketName>, 和 <YourLocalFilePath> 为你的实际OSS配置信息,并且提供了一个有效的本地文件路径和对象键名。

这种方法允许你利用Go语言的并发特性来加速大文件的上传过程。

http://www.yayakq.cn/news/317171/

相关文章:

  • 温州企业网站seo百度手机模板网站
  • 山东网站营销做直播网站需要学什么
  • 什么在线做动图的网站比较好网站开发代码h5
  • 写资料的网站有哪些内容济南做网站的公司
  • 郑州做网站找哪家好静态网站有哪些
  • 阜城县网站建设公司外链生成
  • 烟台网站建设哪家便宜建立网站线上营销
  • 广西金利建设有限公司网站嘉兴做营销型网站设计
  • 如何快速用手机做网站公司网站建设工作通知
  • 网站建设有几种工具科技有限公司的名称应该怎么取名
  • 网站建设空格怎么打长沙优化排名推广
  • asp网站ftp入侵七牛云免费服务器
  • 小程序源码搭建关键词排名优化公司地址
  • 怎样注册自己网站的域名免费的html网站
  • 汕头企业建站系统模板百度上做网站模板
  • ppt做的好的网站有哪些注册公司流程和费用
  • 淮阴网站建设网络舆情分析师证书
  • 建筑公司查询网站小红书推广计划
  • 铜陵网站建设哪家好爱南宁app下载乘车码
  • 响应式网站 翻译什么是网络营销的技术
  • 一个ip做网站中国风优秀个人网站欣赏
  • 电脑网站大全广州番禺伤人案
  • 怎么在百度上做自己的网站做网站盈利
  • 国外html5特效网站新手wordpress
  • 专门做画册的网站求个网站或者app
  • 网站开发分为几个方向阳春市建设局网站
  • 教你免费申请个人网站网络营销方法有哪些?
  • 珠江现代建设 杂志社网站乙方宝
  • 南阳网站优化费用网站内容建设的原则是什么
  • 红色系网站网络营销方式对比