新闻中心

Node.js Puppeteer爬虫的部署与自动化运行指南

2025-11-27
浏览次数:
返回列表

Node.js Puppeteer爬虫的部署与自动化运行指南

本教程详细指导如何部署基于node.js和puppeteer的网络爬虫,并实现其自动化定时执行。文章区分了前端静态网站与后端node.js脚本的部署策略,重点介绍了在windows环境下使用任务计划程序(task scheduler)进行定时任务配置的方法,同时提及了cors问题产生的原因及解决方案,并提供了其他部署选项,确保爬虫数据能定期更新并服务于前端应用。

理解Node.js爬虫与前端应用的差异

在开始部署之前,首先需要明确您所构建的系统包含两个主要部分:

  1. Node.js网络爬虫(index.js):这是一个运行在Node.js运行时环境中的服务器端脚本。它使用Puppeteer库来模拟浏览器行为,访问特定网页抓取数据,并将数据保存为JSON文件。这类脚本不能直接在浏览器中运行,因为它依赖于Node.js特有的模块(如fs用于文件系统操作)和外部库(如puppeteer)。
  2. 前端静态网站(HTML/CSS/JS):这是一个传统的静态网页应用,它在用户的浏览器中运行。您的HTML页面中的J*aScript会读取由爬虫生成的JSON文件,进行数据处理和展示。

由于这两部分运行环境不同,它们的部署策略也需要分开考虑。

Node.js爬虫脚本分析

您提供的index.js代码片段展示了使用Puppeteer抓取三个不同网站数据的过程,并将结果分别保存到arreglo2.json、arreglo.json和cotacaoFechamento.json文件中。

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

// 抓取第一个数据源
(async () => {
  const browser = await puppeteer.launch();
  const page = await browser.newPage();
  await page.goto('https://br.advfn.com/investimentos/futuros/di-depositos-interfinanceiros/cotacoes', {
    waitUntil: 'load',
    timeout: 0
  });
  const textNode = await page.evaluate(() => {
    const nodeText = document.querySelector(".even.first").innerText;
    return [nodeText];
  });
  fs.writeFile('arreglo2.json', JSON.stringify(textNode), err => {
    if (err) throw new Error('algo deu errado');
    console.log('deu certo');
  });
  await browser.close(); // 确保关闭浏览器实例
})();

// 抓取第二个数据源
(async () => {
  const browser = await puppeteer.launch();
  const page = await browser.newPage();
  await page.goto('https://br.tradingview.com/symbols/TVC-DXY/', {
    waitUntil: 'load',
    timeout: 0
  });
  const textNode = await page.evaluate(() => {
    const nodeText = document.querySelector(".js-quote-ticker.tv-site-table__row.tv-widget-watch-list__row:nth-child(2)").children[1].children[1].children[0].innerHTML;
    return [nodeText];
  });
  fs.writeFile('arreglo.json', JSON.stringify(textNode), err => {
    if (err) throw new Error('algo deu errado');
    console.log('deu certo');
  });
  await browser.close(); // 确保关闭浏览器实例
})();

// 抓取第三个数据源
(async () => {
  const browser = await puppeteer.launch();
  const page = await browser.newPage();
  await page.goto('https://br.advfn.com/bolsa-de-valores/fx/USDBRL/cotacao', {
    waitUntil: 'load',
    timeout: 0
  });
  const textNode = await page.evaluate(() => {
    const nodeText = document.querySelector(".qs-current-price").innerText;
    return [nodeText];
  });
  fs.writeFile('cotacaoFechamento.json', JSON.stringify(textNode), err => {
    if (err) throw new Error('algo deu errado');
    console.log('deu certo');
  });
  await browser.close(); // 确保关闭浏览器实例
})();

注意事项:

  • 浏览器实例管理: 在每个异步函数结束时,务必调用 await browser.close(); 来关闭Puppeteer启动的浏览器实例,以避免资源泄露。上述代码已在示例中补充。
  • 错误处理: 确保文件写入等操作有健壮的错误处理机制。
  • 路径: fs.writeFile 默认会将文件写入到执行脚本的当前工作目录。在部署时,需要确保脚本有写入该目录的权限。

自动化定时执行Node.js爬虫

为了实现每天早上8点自动运行index.js,我们需要利用操作系统的定时任务功能。

1. Windows系统:使用任务计划程序(Task Scheduler)

Windows任务计划程序是一个强大的工具,可以用来安排程序或脚本在特定时间自动运行。

配置步骤:

  1. 打开任务计划程序: 在Windows搜索栏中输入“任务计划程序”并打开。

  2. 创建基本任务: 在右侧“操作”面板中选择“创建基本任务...”。

  3. 任务名称和描述:

    • 名称: 为任务指定一个有意义的名称,例如“每日爬虫数据更新”。
    • 描述: 简要说明任务目的。
  4. 触发器:

    • 选择“每天”。
    • 设置开始日期和时间为第二天早上8:00 AM。
    • 确保“重复任务”设置为每天。
  5. 操作:

    • 选择“启动程序”。
    • 程序或脚本: 填写您的Node.js可执行文件的完整路径。通常是 C:\Program Files\nodejs\node.exe (如果Node.js安装在默认位置)。
    • 添加参数(可选): 填写您的index.js脚本文件名,例如 index.js。
    • 起始于(可选): 填写您的index.js脚本所在的目录的完整路径,例如 C:\Users\YourUser\YourProjectFolder。这是非常关键的一步,因为fs.writeFile会在这个目录下创建JSON文件,并且Node.js会在这个目录下查找index.js。

    示例配置:

    • 程序或脚本: C:\Program Files\nodejs\node.exe
    • 添加参数(可选): index.js
    • 起始于(可选): C:\path\to\your\project\ (请替换为您的实际项目路径)
  6. 完成: 检查配置摘要,然后点击“完成”。

    语鲸 语鲸

    AI智能阅读辅助工具

    语鲸 314 查看详情 语鲸

现在,您的Node.js爬虫将在每天早上8点自动运行。

2. Linux/macOS系统:使用Cron Jobs

如果您在Linux或macOS服务器上部署,可以使用cron来调度任务。

  1. 打开Crontab编辑器: 在终端中输入 crontab -e。

  2. 添加任务行: 在文件末尾添加一行,指定执行时间和命令。

    0 8 * * * /usr/local/bin/node /path/to/your/project/index.js >> /path/to/your/project/cron.log 2>&1
    • 0 8 * * *: 表示每天的8点0分执行。
    • /usr/local/bin/node: Node.js可执行文件的完整路径(根据您的安装路径可能不同,可以通过 which node 命令查看)。
    • /path/to/your/project/index.js: 您的index.js脚本的完整路径。
    • >> /path/to/your/project/cron.log 2>&1: 将所有输出(包括错误)重定向到日志文件,便于调试。

部署前端静态网站

您的前端静态网站(HTML、CSS、处理JSON的J*aScript)可以像部署普通静态网站一样进行。

  1. 文件放置: 将所有静态文件(包括index.html、style.css、前端J*aScript文件以及由爬虫生成的arreglo.json、arreglo2.json、cotacaoFechamento.json等)放在同一个目录下。
  2. 选择托管服务:
    • 本地服务器: 如果您希望在本地访问,可以使用XAMPP、Nginx、Apache或简单的Node.js静态文件服务器。确保JSON文件与HTML文件在同一个可访问的目录下。
    • 云托管: 对于线上部署,可以使用GitHub Pages、Netlify、Vercel、Amazon S3等静态网站托管服务。

重要提示: 确保前端J*aScript能够通过相对路径正确访问到爬虫生成的JSON文件。这意味着爬虫生成的JSON文件需要与前端HTML文件部署在同一个Web服务器的可访问路径下。

理解CORS问题

您提到在本地直接打开file://协议的HTML文件时遇到CORS(跨域资源共享)错误。这是因为:

  • 浏览器安全策略: 现代浏览器出于安全考虑,会限制通过file://协议加载的页面访问本地文件系统中的其他资源,尤其是通过XMLHttpRequest或fetch等API。这被视为跨域请求,即使它们都在您的本地硬盘上。
  • Web服务器的作用: 当您通过XAMPP等Web服务器访问时(例如http://localhost/your_project/index.html),浏览器认为所有资源都来自同一个“源”(http://localhost),因此不会触发CORS限制。

解决方案:

由于您的Node.js爬虫是服务器端脚本,它直接通过fs.writeFile操作本地文件系统,不涉及浏览器中的HTTP请求,因此不会遇到CORS问题。前端应用通过Web服务器访问这些JSON文件时,如果HTML和JSON文件都来自同一个源,也不会有CORS问题。

总结与高级部署选项

通过以上步骤,您可以在Windows系统上实现Node.js爬虫的自动化运行,并通过Web服务器提供数据给前端静态网站。

高级部署选项:

  • 云函数(Serverless Functions): AWS Lambda、Google Cloud Functions、Azure Functions等服务允许您部署Node.js函数,并配置定时触发器(例如每天早上8点),无需管理服务器。这是更现代且通常更具成本效益的解决方案。
  • 虚拟私有服务器(VPS): 租用一台VPS(如AWS EC2、DigitalOcean Droplet),您可以在上面安装Node.js,并将爬虫部署上去。然后使用Linux的cron或Windows的Task Scheduler来定时执行。
  • 容器化(Docker): 将您的Node.js爬虫打包成Docker容器,可以在任何支持Docker的环境中运行,并配合容器编排工具(如Kubernetes)进行调度。

选择哪种部署方式取决于您的需求、预算以及对服务器管理的熟悉程度。对于个人项目,Windows任务计划程序或Linux Cron是最直接且免费的解决方案。

以上就是Node.js Puppeteer爬虫的部署与自动化运行指南的详细内容,更多请关注其它相关文章!


# linux  # nodejs  # css  # 这是  # 文件系统  # 早上  # 可以使用  # 并将  # 可选  # 您的  # git  # node.js  # 前端  # js  # html  # java  # javascript  # json  # 温江区营销推广公司  # 竞价和seo推广  # 建站seo软件  # 巴南seo优化排名效果  # 黄山seo排名价格  # 静安关键词排名电话多少  # 谷歌seo利基站  # 关键词营销推广报价  # 关键词排名用什么方式  # seo东东  # 关闭浏览器  # 自动运行  # 目录下 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 押井守高度称赞《辐射4》:玩了八年都停不下来!  文心一言怎样用插件调度API数据_文心一言用插件调度API数据【API调用】  Flexbox布局实践:实现粘性导航栏与底部固定页脚  如何在J*a中实现统一对象行为接口_项目大型化时的接口规范化  《刺客信条:影》PS5 Pro和Switch 2画面对比  win11 Snap Layouts怎么用 Win11窗口布局与分屏多任务高效指南【必学】  QQ邮箱在线登录平台 QQ邮箱个人邮箱网页版入口  使用 Pandas 高效处理 .dat 文件:数据清洗与数值计算实战  qq音乐在线播放入口_qq音乐电脑版登录链接  漫蛙漫画登录站点 漫蛙2正版漫画快速访问  京东单号查询入口_京东快递订单追踪入口  如何使 Jest 模拟函数默认抛出错误以提高测试效率  小米Civi 4录制视频过暗_小米Civi 4亮度优化  Yandex浏览器官方网页版入口 Yandex浏览器最新版官网  蛙漫漫画免费阅读入口_蛙漫官方正版无广告纯净版  如何在CSS中使用visited与link控制链接颜色_visited link伪类配合  如何在 Excel Online 和 Google 表格中更改日期格式  iCloud登录入口网页版 苹果iCloud官网登录  LINQ to XML为何解析失败? 深入理解C# XDocument的异常处理  Word2013如何插入视频和音频媒体_Word2013媒体插入的多媒体支持  在哪找SublimeJ远程工具_SFTP插件配置教程  2025AO3夸克浏览器通道_AO3手机HTTPS安全入口分享  微信网页版扫码登录入口 微信网页版二维码登录入口  抖音隐秘迷城小游戏入口_ 抖音冒险解谜小游戏秒玩  微信群消息显示延迟如何解决 微信群消息刷新优化方法  KFC套餐升级怎么获取优惠代码_KFC套餐升级活动与优惠代码获取方法  J*aScript类型检查_j*ascript代码规范  谷歌浏览器最新官方入口链接 谷歌浏览器网页版官网导航  AWS EC2实例间SQL Server连接超时:安全组配置与故障排除指南  百度网盘网页版入口 百度网盘网页版官方登录网址  解决Flask中Quill编辑器内容提交失败及TypeError的指南  sublime如何优雅地处理行尾空格_sublime自动清理多余空白字符配置  深入理解J*a链表中的IPosition接口与使用  动漫花园资源网使用步骤_动漫花园资源网下载流程  UC浏览器如何安装插件 UC浏览器添加扩展程序详细教程【进阶】  CSS实现侧边栏导航项全宽圆角悬停背景效果  怎么在html里运行vbs脚本_html中运行vbs脚本方法【教程】  b站如何看历史记录_b站观看历史找回方法  如何使用Node.js csv 包按条件移除含空字段的CSV记录  包子漫画官方网站在线链接-包子漫画在线阅读平台主页地址  俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问  XML中包含HTML标签导致解析错误? 正确嵌入非XML数据的两种方法  如何在网页中实现特定地点的随机图片展示  哔哩哔哩忘记密码了怎么找回_哔哩哔哩密码找回方法  漫蛙manwa2最新登录网址_漫蛙manwa2手机网页版入口  css绝对定位元素脱离父容器怎么办_确保父元素position非static  Excel文件在线转换快速入口 Excel在线格式转换网站  深入理解rpy2中的类型转换:优化Python对象到R矩阵的映射  小红书怎么解除第三方平台绑定_小红书多平台登录解绑方法介绍  python3时间如何用calendar输出? 

搜索