0

0

部署与自动化运行Node.js网络爬虫:使用Windows任务计划程序

花韻仙語

花韻仙語

发布时间:2025-11-23 09:01:17

|

353人浏览过

|

来源于php中文网

原创

部署与自动化运行Node.js网络爬虫:使用Windows任务计划程序

本文将指导您如何部署一个基于node.js和puppeteer的网络爬虫,并利用windows任务计划程序实现其每日定时自动运行。我们将深入探讨服务器端脚本与静态网页的区别,提供详细的步骤配置任务计划,并讨论在自动化过程中需要注意的关键事项,如资源管理、错误处理及跨平台部署思路。

理解Node.js爬虫的运行环境

首先,我们需要明确您构建的网络爬虫(使用puppeteer和fs模块)是一个基于Node.js的服务器端(Server-side)应用程序,而非传统的客户端(Client-side)浏览器脚本。

  • 客户端脚本(如浏览器中的JavaScript):运行在用户的浏览器中,受浏览器安全策略(如同源策略CORS)的限制,无法直接访问本地文件系统或执行需要操作系统权限的操作。
  • 服务器端脚本(如Node.js):运行在服务器或本地计算机的Node.js运行时环境中,拥有更高级的权限,可以访问文件系统、发起网络请求、执行外部程序等。您的index.js文件正是属于此类。

您之前遇到的CORS错误,以及需要通过XAMPP才能运行的情况,很可能是因为您尝试以客户端脚本的方式去运行一个服务器端程序,或者在本地开发时,直接在浏览器中打开HTML文件导致浏览器限制了其对本地JSON文件的访问。Node.js爬虫的执行与您的静态HTML页面是相互独立的,爬虫负责数据抓取和存储,HTML页面则负责读取这些存储好的JSON数据并展示。

部署与定时执行Node.js爬虫

要在Windows系统上实现Node.js爬虫的定时自动运行,最直接且有效的方法是使用Windows任务计划程序(Task Scheduler)

准备工作

在配置任务计划之前,请确保您的系统已满足以下条件:

  1. Node.js环境安装:确保您的Windows系统上已安装Node.js运行时。您可以在命令行中输入 node -v 来验证。
  2. 项目依赖安装:在您的爬虫项目目录下(即index.js所在的目录),打开命令行并执行 npm install puppeteer,确保所有必要的Node.js模块已安装。
  3. 爬虫脚本路径确定:记录下您的index.js文件的完整绝对路径,例如 C:\Users\YourUser\ScraperProject\index.js。
  4. Node.js可执行文件路径确定:记录下node.exe的完整绝对路径,通常在Node.js的安装目录下,例如 C:\Program Files\nodejs\node.exe。

示例爬虫代码(简化)

您的index.js核心逻辑如下,它使用Puppeteer抓取网页数据并保存到JSON文件:

const puppeteer = require('puppeteer');
const fs = require('fs');

async function scrapeData(url, selector, outputPath) {
  let browser;
  try {
    browser = await puppeteer.launch({ headless: true }); // 生产环境建议 headless: true
    const page = await browser.newPage();
    await page.goto(url, { waitUntil: 'load', timeout: 0 });

    const data = await page.evaluate((sel) => {
      // 注意: page.evaluate 中的代码运行在浏览器上下文中,无法直接访问 Node.js 变量
      // 因此,selector 需要作为参数传入
      const element = document.querySelector(sel);
      return element ? element.innerText : null;
    }, selector); // 将 selector 传递给 page.evaluate

    if (data) {
      fs.writeFile(outputPath, JSON.stringify([data]), err => {
        if (err) throw new Error(`写入文件失败: ${err.message}`);
        console.log(`数据成功写入到 ${outputPath}`);
      });
    } else {
      console.log(`未找到 ${selector} 对应的数据在 ${url}`);
    }
  } catch (error) {
    console.error(`抓取 ${url} 时发生错误: ${error.message}`);
  } finally {
    if (browser) {
      await browser.close(); // 确保关闭浏览器实例
    }
  }
}

// 每日执行的抓取任务
(async () => {
  console.log('开始执行每日爬虫任务...');
  await scrapeData(
    'https://br.advfn.com/investimentos/futuros/di-depositos-interfinanceiros/cotacoes',
    '.even.first',
    'arreglo2.json'
  );
  await scrapeData(
    'https://br.tradingview.com/symbols/TVC-DXY/',
    '.js-quote-ticker.tv-site-table__row.tv-widget-watch-list__row:nth-child(2) .tv-widget-watch-list__cell--big', // 修正选择器以获取DXY值
    'arreglo.json'
  );
  await scrapeData(
    'https://br.advfn.com/bolsa-de-valores/fx/USDBRL/cotacao',
    '.qs-current-price',
    'cotacaoFechamento.json'
  );
  console.log('所有爬虫任务执行完毕。');
})();

注意点:

  • browser.close(): 在每个scrapeData函数中,我增加了finally块来确保在任务完成或出错时关闭Puppeteer启动的浏览器实例。这对于避免资源泄露和程序卡死至关重要。您的原始代码中没有显式关闭浏览器,这在长时间运行或多次执行时会导致问题。
  • 选择器优化: 针对DXY的抓取,我稍微调整了选择器,因为原始的选择器可能不够精确或在页面结构变化后失效。实际使用时请根据页面最新结构进行测试和调整。
  • 错误处理: 增加了try...catch块来捕获潜在的抓取或文件写入错误,并打印到控制台,这有助于调试。

配置Windows任务计划程序

按照以下步骤创建定时任务:

  1. 打开任务计划程序

    • 按下 Win + R 键,输入 taskschd.msc,然后按回车。
    • 或者在开始菜单搜索“任务计划程序”并打开。
  2. 创建基本任务

    • 在任务计划程序库的右侧“操作”面板中,点击“创建基本任务...”。
    • 名称:输入一个描述性的名称,例如“每日美元指数爬虫”。
    • 描述:简要说明任务的目的,例如“每天上午8点运行Node.js爬虫,抓取美元指数和汇率数据。”
    • 点击“下一步”。
  3. 配置触发器

    萝卜简历
    萝卜简历

    免费在线AI简历制作工具,帮助求职者轻松完成简历制作。

    下载
    • 何时希望任务开始?:选择“每天”。
    • 点击“下一步”。
    • 每天
      • 开始:选择您希望任务首次运行的日期。
      • 重复周期:选择“1 天”。
      • 时间:设置您希望任务每天运行的时间,例如 8:00:00 AM。
    • 点击“下一步”。
  4. 配置操作

    • 希望任务执行什么操作?:选择“启动程序”。
    • 点击“下一步”。
    • 启动程序
      • 程序或脚本:输入Node.js可执行文件的完整路径,例如 C:\Program Files\nodejs\node.exe。
      • 添加参数(可选):输入您的爬虫脚本的完整路径,例如 C:\Users\YourUser\ScraperProject\index.js。
      • 起始于(可选):输入您的爬虫项目目录的路径,例如 C:\Users\YourUser\ScraperProject。这一步非常重要,它确保Node.js在正确的项目目录下执行,以便正确解析package.json中的依赖和相对路径。
    • 点击“下一步”。
  5. 完成

    • 检查您配置的所有信息。
    • 勾选“当单击‘完成’时,打开此任务的‘属性’对话框”选项,以便进行更高级的设置。
    • 点击“完成”。

任务高级设置(可选但推荐)

在任务的属性对话框中,您可以进行一些高级配置:

  • 常规选项卡
    • 运行任务时使用用户账户:确保选择一个具有足够权限的用户账户(通常是您当前登录的账户),以便Node.js能够访问文件系统和执行网络操作。
    • 无论用户是否登录都要运行:勾选此项,即使您没有登录系统,任务也会按计划执行。
    • 使用最高权限运行:勾选此项,确保任务具有执行所需操作的权限。
  • 设置选项卡
    • 如果任务失败,重新启动:勾选并配置重试次数和间隔,以增加任务的健壮性。
    • 如果任务运行时间超过以下时间,请停止任务:根据您的爬虫预计运行时间设置一个合理的上限,防止任务无限期运行。

注意事项与最佳实践

  1. 错误处理与日志记录

    • 在您的Node.js爬虫脚本中,务必添加健壮的try...catch块来捕获可能发生的错误(如网络请求失败、页面元素未找到、文件写入失败等)。
    • 将错误信息和运行状态记录到日志文件中(例如使用winston或log4js等日志库),而不是仅仅console.log。这样即使任务在后台运行,您也能追踪其状态和问题。
  2. 资源管理

    • Puppeteer会启动一个无头浏览器实例,这会消耗系统资源。确保在每次抓取任务完成后调用 browser.close() 来关闭浏览器实例,释放内存。
    • 如果您的爬虫需要处理大量数据或长时间运行,考虑优化代码以减少资源消耗。
  3. 输出文件路径

    • 在任务计划程序中运行的脚本,其工作目录可能是任务计划程序的默认目录,而不是您的项目目录。因此,在脚本中写入JSON文件时,建议使用绝对路径或基于__dirname构建路径,以确保文件被写入到预期的位置。
    • 例如:fs.writeFile(path.join(__dirname, 'arreglo2.json'), ...),需要 const path = require('path');。
  4. 环境差异

    • 在开发环境中手动运行和在任务计划程序中自动运行可能会有细微的环境差异。确保所有必要的环境变量都已设置,并且程序具有执行所需操作的权限。
  5. 跨平台考虑

    • 如果您未来需要将爬虫部署到Linux服务器,可以使用cron作业来替代Windows任务计划程序。
    • 对于更复杂的、需要弹性伸缩或无服务器部署的场景,可以考虑使用云服务(如AWS Lambda, Google Cloud Functions, Azure Functions)结合其定时触发器功能。

总结

通过将Node.js爬虫识别为服务器端应用,并利用Windows任务计划程序进行定时调度,您可以轻松实现其自动化运行。关键在于正确配置任务计划,确保Node.js可执行文件和脚本路径的准确性,并为爬虫脚本添加完善的错误处理、资源管理和日志记录机制。理解这些概念和实践,将使您能够更有效地部署和维护自动化数据抓取任务。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

553

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

374

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

731

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

477

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

990

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

656

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

551

2023.09.20

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.1万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号