powershell - 从 powershell 下载文件时,Invoke-WebRequest 进度变得无响应/暂停
问题描述
我是批处理脚本的新手,正在尝试自动化构建依赖项的下载和执行。我正在实现一个 .bat 文件并从终端执行它。Invoke-webrequest 用于下载依赖项。
我在尝试下载大文件时遇到问题。如果系统空闲,下载将在后台停止。我在 .bat 文件中编写了命令并从 Powershell 触发了它。我目前正在使用 Invoke-webrequest,因为我也可以在 oneliner 中发送凭据。
@REM %DebugUri%- url to downloadfile
@REM %debugfeature% - output file path.
@REM USERID , PASSID provided in previous steps.
powershell -Command "Invoke-WebRequest -Uri %DebugUri% -OutFile ./%debugfeature% -UseBasicParsing -Credential (New-Object PSCredential('%USERID%', (ConvertTo-SecureString -AsPlainText -Force -String '%PASSID%')))"
它可以很好地下载小文件(~50MB)。但是当我尝试下载大文件(~1GB)并让系统闲置一段时间时。下载进度暂停,PowerShell 终端无响应。下载也停止(根据任务管理器没有网络活动)。
如果 PowerShell 屏幕在前台并且系统在整个过程中保持活动状态,则下载工作正常(不确定是否相关)
我需要添加任何属性以保持下载进度处于活动状态吗?或我可以使用 .bat 脚本下载文件的任何其他过程。如果您需要任何进一步的信息,请告诉我。谢谢~
解决方案
前几天我也遇到了类似的问题。有趣的是,检查/更新下载进度的方式会大大减慢实际下载本身的速度。您应该并且可能必须禁用下载进度才能获得不错的下载速度。你可以这样做:
$ProgressPreference = 'SilentlyContinue'
# your code here
$ProgressPreference = 'Continue'
或者,您也可以使用底层 WebClient 类来发出请求,这就是我所做的:
Invoke-Expression (New-Object System.Net.WebClient).DownloadString('https://mydownloadpath.com')
推荐阅读
- python - 如何在不更改 Pandas 0.20.1 中的列顺序的情况下连接 pandas Dataframes?
- sql-server - Copy varchar column data to date column
- spring-boot - Spring Boot 从 1.5.x 迁移到 2.1.x 后无法运行 Eureka Client Application
- qt - 为什么 QML 速度太慢,无法绘制包含约 4000 个简单元素的场景?
- arrays - 在 Excel 中将 Texbox 字符串传递给 countif
- r - 如何让 c 返回一个表达式?
- python - Auto_arima 参数选择
- spring - 自动装配 HibernateTemplate 时不创建 Bean
- python-3.x - ValueError:无法将大小为 13 的序列复制到维度为 200 的数组轴
- django - auto_now_add 在 Django 单元测试中创建 NotNullViolation