提高 axios 获取下载速度

IT技术 reactjs axios azure-blob-storage
2021-05-01 18:27:53

我正在使用axios从 Azure 存储 Blob 下载文件 (~100MB)。

axios({
  method: 'get',
  url: uri,
  onDownloadProgress: (progressEvent) => {
    console.log("Loaded: " + ((progressEvent.loaded / progressEvent.total) * 100) + "%"); 
  },
  responseType: 'arraybuffer'
}).then({})

我的问题是实际下载文件需要很长时间(约 10 分钟)。我以前使用的是 fetch(),它甚至比这还慢(约 15-20 分钟)。大家有什么关于如何加快下载速度的建议吗?我的互联网速度不是问题,因为直接下载文件或使用 Azure 存储资源管理器(1.12.0,AzCopy 10.3.3)只需不到 2 分钟。

我还尝试使用 azure-storage 的 blobServiceClient,但获得了与 axios 和 fetch 相似的速度(大约 15kbps)。

如果有帮助,这是在 React 应用程序中。

1个回答

我已经测试了下载速度。我希望我的结果对你有用。

  1. 我上传StorageExplorer.exe作为下载测试的源文件。文件大小为 92.5M。

在此处输入图片说明

  1. 通过下载文件Azure Storage Explore,它会花费1 minute and 07 seconds.

在此处输入图片说明

  1. 通过 chrome 浏览器在门户中下载文件,需要58 seconds.

在此处输入图片说明

  1. 通过我的测试代码下载文件。

① 从portal复制网址Storage Explore

在此处输入图片说明

网址如:https://p*****ge.blob.core.windows.net/testcontainer/StorageExplorer.exe

经过我的代码测试,会1 minute and 52 seconds耗时,而且很不稳定,有时测试下载时间会比较长。

② 从AzCopy Command.

url格式如下: https://pan********ge.blob.core.windows.net/testcontainer/StorageExplorer.exe?se=2020-09-18T07%3A55%3A28Z&sp=rl&sv=2018-03-28&sr=c&sig=5kJyTBwHHRS******mlj3%2FWj9CmvQriXCMi4%3D

用相同的代码测试后,需要1 minute and 02 seconds.

我的测试结论:

不要使用看起来像https://p*****ge.blob.core.windows.net/testcontainer/StorageExplorer.exe.

您可以使用类似于从 AzCopy 命令获取的 url。

下面是我的测试代码。

  1. npm 我进步了
  2. npm 和 axios
'use strict'

const Fs = require('fs')  
const Path = require('path')  
const Axios = require('axios')  
const ProgressBar = require('progress')

async function download () {  
  const url =    'https://pan*****e.blob.core.windows.net/testcontainer/StorageExplorer.exe'

  console.log('Connecting …')
  const { data, headers } = await Axios({
    url,
    method: 'GET',
    responseType: 'stream'
  })
  const totalLength = headers['content-length']

  console.log('Starting download')
  const progressBar = new ProgressBar('-> downloading [:bar] :percent :etas',     {
      width: 40,
      complete: '=',
      incomplete: ' ',
      renderThrottle: 1,
      total: parseInt(totalLength)
    })

  const writer = Fs.createWriteStream(
    Path.resolve(__dirname, 'software', 'StorageExplorer.exe')
  )
  data.on('data', (chunk) => progressBar.tick(chunk.length))
  data.pipe(writer)
}

download()

在此处输入图片说明