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可执行文件和脚本路径的准确性,并为爬虫脚本添加完善的错误处理、资源管理和日志记录机制。理解这些概念和实践,将使您能够更有效地部署和维护自动化数据抓取任务。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

510

2023.11.27

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

564

2023.09.20

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

215

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

193

2025.11.08

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共48课时 | 10.7万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

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

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