• SAP 电商云 Spartacus 服务器端渲染的单步调试详细步骤


    本文介绍如何在本地调试 SAP Spartacus Node.js 应用。

    按照这个链接 安装 Spartacus.

    在 package.json 的 scripts 区域,生成了一个名叫 build:ssr 的指令,默认按照 --prod 参数来构建。

    如果使用这个 script,我们不得不调试 minified and uglified code, 不太直观。

    也就是说,去掉 --prod:production

    使用如下命令行:

    ng build && ng run mystore:server

    采用这个方式构建出的 main.js, 代码是可读的:

    (3) 添加一个 --inspect-brk 选项:

    node --inspect-brk dist/mystore/server/main.js

    启动:

    npm run serve:ssr

    (4) Chrome 地址栏输入 chrome://inspect, 点击 inspect hyperlink:

    断点会自动触发,停在 main.js 的第一行:

    现在就可以开始调试了:

    引起 Node.js 应用高 CPU 占用率的一些可能性:

    • 循环和迭代。 如果不限制可迭代集合的大小,任何 .map、.reduce、.forEach 和其他迭代方法调用都可能导致问题。for 和 while 循环也存在同样的潜在问题。 如果业务层面上必须处理大型集合,请使用流或将集合,拆分为块并异步处理它们。 它将在不同的 EventLoop 迭代之间分配负载,减少阻塞效应。

    • 递归函数。 这里的原理相同,你需要考虑递归深度,特别是当函数是同步的时候。

    • 巨大的有效载荷。Node.js 是为处理大量异步操作而创建的,例如向数据库发出请求或外部 API 调用。 在来自外部来源的有效载荷很小之前,它可以完美运行。 不要忘记 Node.js 需要先读取一个有效载荷并将其存储在内存中,然后将 JSON 解析为一个对象(增加了更多内存),对该对象执行一些操作。 来自 Node.js 服务的巨大负载也可能是一个问题,因为 Node.js 首先将对象字符串化为 JSON,然后将它们发送到客户端。 所有这些操作都可能导致高 CPU,确保有效负载大小不是很大,使用分页,并且不要预填充不必要的数据。 对于 GraphQL 服务,使用复杂性来限制响应负载。

    2023年2月25日星期六更新

    Spartacus 3.0 SSR 模式的启用

    本地文件夹的路径:

    yarn ssrdebug:以调试模式启动 SSR 服务器:

  • 相关阅读:
    【无标题】
    Maven 使用
    【Labivew】G语言
    17.Oauth2-微服务认证
    代码随想录笔记_动态规划_139单词拆分
    ffmpeg使用命令实现音视频分离
    Notion 程序猿必备笔记软件
    Bigemap在审计行业中的应用案例
    时序数据库的关键技术点总结
    Java并发编程——线程间通信
  • 原文地址:https://blog.csdn.net/i042416/article/details/126630847