nodejs 使用request 下载文件报错 Error: read ECONNRESET 的修复方式

在使用NodeJS进行图片爬取时遇到错误,通过更换为Axios库并调整图片写入方式成功解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在编写图像识别模型的时候, 需要爬取一些样本图片,于是用NodeJS编写了一个简单的爬虫。但是在下载图片过程中, 经常会报如下错误:
在这里插入图片描述
报错部分代码:

 //通过流的方式,把图片写到本地/image目录下,并用新闻的标题和图片的标题作为图片的名称
 
await request(gif).pipe(fs.createWriteStream('./appleCode/' + img_filename)).on;  

一开始我以为是服务器对IP进行了频率验证,后来查看 request 发现官方已经弃用了。于是盲猜是 pipe 流同时运行的进程超出了限制。

条条大路,通罗马,于是改用 Axios 来下载文件

npm install axios

然后参考官方示例编写一个下载操作函数

/**
 * @param {string} imgUrl 图片地址
 * @param {string} filepath 文件保存的本地目录
 * @param {string} flieName 保存的文件名
 */
async function downloadFile(imgUrl, filepath, flieName) {
    if (!fs.existsSync(filepath)) {
        fs.mkdirSync(filepath);
    }
    const mypath = path.resolve(filepath, flieName);
    const writer = fs.createWriteStream(mypath); // 创建写入对象
    const response = await Axios({
        url: imgUrl,
        method: "GET",
        responseType: "stream",
    }); // 请求图片地址获取二进制数据流
    response.data.pipe(writer); // 写入图片数据到文件中
    return new Promise((resolve, reject) => {
        writer.on("finish", resolve);
        writer.on("error", reject);
    });
}

啪的一下,很快啊,问题就解决了

当你在Node.js中使用`mysql2`创建数据库连接池并遇到 `Uncaught Error: read ECONNRESET` 错误时,这通常意味着连接到MySQL服务器的过程中出现了问题,可能是网络中断或者是MySQL服务器本身的问题。以下是几种可能的解决方案: 1. **检查网络连接**: 确保你的应用程序能够正常访问MySQL服务器,可以试着直接运行`mysql2.connect()`看看是否能成功连接。 2. **重启MySQL服务**: 如果MySQL服务突然停止或意外关闭,可能会导致连接错误。尝试重启MySQL服务并再次尝试连接。 3. **调整连接池配置**: 使用 `createPool` 创建连接池时,确认 `pool.connectionTimeout` 和 `pool.queueTimeout` 是否设置得合理。如果设置过长,可能会导致超时错误。 4. **代码异常处理**: 在调用`createPool`时添加try-catch块,捕获异常并在catch中做适当处理,如记录日志或重试连接。 5. **检查防火墙设置**: 确认没有防火墙规则阻止 Node.js 应用程序访问 MySQL 服务。 ```javascript const { Pool } = require('mysql2/promise'); let pool; async function initPool() { try { // 更改这里的配置以适应实际情况 pool = await Pool({ host: 'your_host', user: 'your_user', password: 'your_password', database: 'your_database', connectionLimit: 10, queueLimit: 0, // 如果设置了,根据实际情况调整 waitForConnections: true, connectionTimeout: 60000, // 连接超时时间 queueTimeout: 60000, // 队列超时时间 }); } catch (error) { console.error("Error creating pool:", error); // 可能需要在这里添加重试逻辑或者其他错误处理 } } // 初始化连接池 initPool(); // 使用 pool async function query(sql) { try { const [rows] = await pool.query(sql); // ...处理查询结果 } catch (error) { console.error("Error executing query:", error); // 捕获并处理异常 } } ```
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

唐大帅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值