目錄
問題內容
解決方法
首頁 後端開發 Golang 為什麼在記憶體中下載比從 aws s3 在檔案系統中下載慢?

為什麼在記憶體中下載比從 aws s3 在檔案系統中下載慢?

Feb 09, 2024 am 11:57 AM
overflow

为什么在内存中下载比从 aws s3 在文件系统中下载慢?

為什麼在記憶體中下載比從AWS S3在檔案系統中下載慢? 在下載檔案時,我們通常會選擇從AWS S3儲存桶下載到本機檔案系統。然而,有時候我們會發現,使用記憶體中的下載方式比直接從S3下載到檔案系統慢。這是因為在記憶體中下載涉及一些額外的步驟和資源消耗。首先,記憶體中的下載需要將檔案內容讀取到記憶體中,然後再寫入到檔案系統中。這個過程中涉及了額外的記憶體操作和IO操作,相較於直接從S3下載到檔案系統,會導致下載速度變慢。另外,記憶體中的下載還可能受到記憶體限制的影響,當下載的檔案較大時,可能會導致記憶體不足的問題,進而影響下載速度。因此,在選擇下載方式時,需要根據具體情況權衡利弊,選擇最適合的方式進行下載操作。

問題內容

我正在使用aws gosdk從某個儲存桶下載。以下是下載的兩種實作

  1. 下載到檔案
func (a *awsclient) downloadtofile(ctx context.context, objectkey string) (string, error) {
    params := &awss3.getobjectinput{
        bucket: aws.string(a.bucket),
        key:    aws.string(objectkey),
    }

    downloadpath := "some/valid/path"
    f, err := os.create(downloadpath)
    defer f.close()
    _, err = a.downloader.download(ctx, f, params)
    return downloadpath, err
}
登入後複製
  • 下載到記憶體
  • func (a *AwsClient) DownloadToMemory(ctx context.Context, objectKey string) (string, error) {
        params := &awsS3.GetObjectInput{
            Bucket: aws.String(a.bucket),
            Key:    aws.String(objectKey),
        }
    
        buffer := manager.NewWriteAtBuffer([]byte{})  
        _, err = a.downloader.Download(ctx, buffer, params)
        return buffer.Bytes(), err
    }
    登入後複製

    對於 100 mb 的文件,下載到記憶體中需要 30 秒,下載到檔案系統中只需要 8 秒。我的期望是內存下載應該要快得多。我的系統(apple m1、ventura、8gb ram)有足夠的可用 ram,所以這不是問題。有人可以幫助我理解這種行為嗎?

    解決方法

    將大的 S3 物件下載到動態緩衝區中效率非常低。該緩衝區被重新分配多次以處理 100M 資料和多個下載線程。記憶體重新分配需要大量 CPU 時間。

    嘗試在開始時分配 100M,而不是使用空字節片。

    如果物件大小未知,您可以使用 S3.HeadObject 即時取得物件長度。

    以上是為什麼在記憶體中下載比從 aws s3 在檔案系統中下載慢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    AI Hentai Generator

    AI Hentai Generator

    免費產生 AI 無盡。

    熱門文章

    R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
    2 週前 By 尊渡假赌尊渡假赌尊渡假赌
    倉庫:如何復興隊友
    4 週前 By 尊渡假赌尊渡假赌尊渡假赌
    Hello Kitty Island冒險:如何獲得巨型種子
    3 週前 By 尊渡假赌尊渡假赌尊渡假赌

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    比特幣誕生至今價格2009-2025 最完整的BTC歷史價格總表 比特幣誕生至今價格2009-2025 最完整的BTC歷史價格總表 Jan 15, 2025 pm 08:11 PM

    比特幣誕生至今價格2009-2025 最完整的BTC歷史價格總表

    Windows11右下角時間沒了怎麼辦_Windows11右下角時間沒了解決方法 Windows11右下角時間沒了怎麼辦_Windows11右下角時間沒了解決方法 May 06, 2024 pm 01:20 PM

    Windows11右下角時間沒了怎麼辦_Windows11右下角時間沒了解決方法

    Java 函數有哪些社群論壇或討論群組可以提問與討論? Java 函數有哪些社群論壇或討論群組可以提問與討論? Apr 28, 2024 pm 02:12 PM

    Java 函數有哪些社群論壇或討論群組可以提問與討論?

    怎麼用別人的程式碼 怎麼用別人的程式碼 May 05, 2024 pm 07:54 PM

    怎麼用別人的程式碼

    win11電腦時間一直不對怎麼辦? win11電腦時間不對怎麼調整方法 win11電腦時間一直不對怎麼辦? win11電腦時間不對怎麼調整方法 May 03, 2024 pm 09:20 PM

    win11電腦時間一直不對怎麼辦? win11電腦時間不對怎麼調整方法

    Java 函數開發中常見的異常類型及其修復措施 Java 函數開發中常見的異常類型及其修復措施 May 03, 2024 pm 02:09 PM

    Java 函數開發中常見的異常類型及其修復措施

    overflow在css中是什麼意思 overflow在css中是什麼意思 Apr 28, 2024 pm 03:15 PM

    overflow在css中是什麼意思

    抖音亂封帳號沒人管嗎?可以二次申訴嗎? 抖音亂封帳號沒人管嗎?可以二次申訴嗎? May 03, 2024 am 09:37 AM

    抖音亂封帳號沒人管嗎?可以二次申訴嗎?

    See all articles