当前位置:网站首页>SAP 电商云 Spartacus SSR Optimization Engine 几处 timeout 的执行顺序
SAP 电商云 Spartacus SSR Optimization Engine 几处 timeout 的执行顺序
2022-07-31 12:34:00 【华为云】
SSR optimization engine option 代码:
const ngExpressEngine = NgExpressEngineDecorator.get(engine, { timeout: 9000, concurrency: 1, forcedSsrTimeout:90000, maxRenderTime:1000, cache: true, cacheSize: 10, renderingStrategyResolver: (req) => RenderingStrategy.DEFAULT});(1) 首先是 MaxRenderTimeout 超时到达:
显示 log:
然后是:


最后:
注意,这里的 log 不会打印到控制台上:
这两个 timeout 值,谁的数值大,则谁对应的 timeout callback 就会后执行。
以 CmsSetPageSuccessIndex 为例:

运行时该 Action 类包含三大字段:
(1) meta
(2) payload
(3) type
meta
meta 包含的 loader 字段和 meta 本身都是一个 object.
meta.entityId 和 entityType 是该 action payload 的标识位。

loader 表明该 entity 加载状况。
payload
包含的业务数据:

type
字符串类型。
从 上图 Prototype 能看出,CmsSetPageSuccessIndex 的原型链类为 EntitySuccessAction.
这一点也能从其实现代码看出:
export class CmsSetPageSuccessIndex extends StateUtils.EntitySuccessAction { readonly type = CMS_SET_PAGE_SUCCESS_INDEX; constructor(pageContext: PageContext, payload: Page) { super(pageContext.type, pageContext.id, payload); }}查看 EntitySuccessAction 的实现:

属性1,meta 属性,定义在该类里。
属性2,payload,通过构造函数参数定义。
属性3,type,定义在上图81行,然后被 CmsSetPageSuccessIndex 重载。
EntitySuccessAction 构造函数接收三个参数:entityType,id 和 payload.
通过 entityType 和 id,生产出 meta 字段。
entitySuccessMeta 可以看成一个构造器或者工厂函数:
根据 entityType 和 id,生产出 EntityLoaderMeta, 后者是 EntityMeta 和 LoaderMeta 的联合。
export interface EntityMeta { entityType: string; entityId: string | string[]; entityRemove?: boolean;}export interface LoaderMeta { entityType: string; loader: { load?: boolean; error?: any; success?: boolean; };}采用三个点的语法,是因为这两个 interface,都有同名字段:entityType
LoaderMeta 的运行时数据,通过构造器 loadMeta 制造:
export function loadMeta(entityType: string): LoaderMeta { return { entityType: entityType, loader: { load: true, }, };}EntityMeta 字段的值,通过 entityMeta 构造:
export function entityMeta(type: string, id: string | string[]): EntityMeta { return { entityType: type, entityId: id, };}运行时通过 PageEffect 从 Commerce Cloud 后台读取 CMS 数据成功后,新建 ActionClass,将负载通过构造函数参数传入。

边栏推荐
猜你喜欢
随机推荐
PyQt5快速开发与实战 10.1 获取城市天气预报
365天挑战LeetCode1000题——Day 044 最大层内元素和 层次遍历
串的基本概念与操作
深圳某游戏研发公司每个工位都装监控,网友:堪比“坐牢”!
【Shader】Shader官方示例[通俗易懂]
ASM外部冗余是否可以替换磁盘
[core]-ARMV7-A, ARMV8-A, ARMV9-A Architecture Introduction "Recommended Collection"
SAP 电商云 Spartacus UI 和 Accelerator UI 里的 ASM 模块
PyQt5快速开发与实战 9.7 UI层的自动化测试
LRU缓存[线性表 -> 链表 -> hash定位 -> 双向链表]
这款悄然崛起的国产API接口管理工具,你一定要晓得
Ali on three sides: MQ message loss, repetition, backlog problem, how to solve?
PyQt5 rapid development and actual combat 10.2 compound interest calculation && 10.3 refresh blog clicks
0x80070570文件或目录损坏且无法删除(0x80070091怎么删除)
JVS轻应用的组成与配置
[Shader] Shader official example [easy to understand]
认知—运动康复医疗机器人应用设计
普林斯顿微积分读本03第二章--编程实现函数图像绘制、三角学回顾
三相PWM整流器预测直接功率控制
架构实战营|模块8








