
本文探讨了在Mirth Connect中区分通道是因部署启动而进行首次轮询,还是按计划自动轮询的问题,以便实现基于轮询类型的目的地条件执行。通过在通道部署脚本中设置一个全局通道变量作为标志,并在源过滤器/转换器中检查并更新该标志,可以有效识别通道的首次部署轮询与后续计划轮询,从而实现精细化的流程控制。
在Mirth Connect中,有时需要根据通道的轮询方式(例如,是因部署而进行的“启动时轮询”,还是按预定计划进行的自动轮询)来决定是否执行特定的目的地。例如,一个通道可能需要在部署后手动触发一次备份,但在夜间自动轮询时则不执行恢复操作。然而,Mirth Connect并没有直接提供一个内置变量来明确指示当前的轮询是手动触发还是自动触发。本文将介绍一种利用全局通道变量(Global Channel Map Variable)来间接实现这一区分的方法。
Mirth Connect通道通常有两种主要的轮询触发机制:
核心挑战在于如何在通道的源过滤器或转换器中识别当前正在执行的轮询属于哪种类型,以便根据此信息有条件地启用或禁用某些目的地。
Mirth Connect提供了一个globalChannelMap对象,允许在通道的各个脚本之间共享数据。我们可以利用这一点,在通道部署时设置一个标志,并在每次轮询时检查并更新这个标志。
步骤 1:在通道部署脚本中初始化部署标志
当通道被部署时,Mirth Connect会执行其“部署脚本”(Deploy Script)。我们可以在这里设置一个全局通道变量,例如NEW_DEPLOY,来指示通道刚刚被部署。
导航到部署脚本: 在Mirth Connect Administrator中,选择你的通道,然后点击“Scripts”选项卡,找到“Deploy Script”。
添加初始化代码: 在部署脚本中添加以下JavaScript代码:
// 设置一个标志,指示通道刚刚被部署
globalChannelMap.put('NEW_DEPLOY', true);
return;这段代码将NEW_DEPLOY变量设置为true,表示通道刚刚完成部署。
步骤 2:在源过滤器/转换器中检查并更新标志
在通道的源连接器(Source Connector)的过滤器或转换器中,我们可以访问这个全局通道变量。在每次轮询时,检查NEW_DEPLOY的值,并根据其状态执行不同的逻辑。
导航到源过滤器/转换器: 在Mirth Connect Administrator中,选择你的通道,然后点击“Source”选项卡,选择一个“Filter”或“Transformer”步骤。
添加检查和更新代码: 在该脚本中添加以下JavaScript代码:
if ($gc('NEW_DEPLOY') == true) {
// 如果 NEW_DEPLOY 为 true,则表示这是部署后的首次轮询("Poll Once on Start")
logger.info("NEW_DEPLOY WAS " + $gc('NEW_DEPLOY') + ", 这是部署后的首次轮询");
// 执行与首次部署轮询相关的逻辑,例如,启用特定目的地
// 重置 NEW_DEPLOY 标志为 false,以便后续轮询被识别为计划轮询
globalChannelMap.put('NEW_DEPLOY', false);
} else {
// 如果 NEW_DEPLOY 为 false,则表示这是后续的计划轮询
logger.info("NEW_DEPLOY WAS " + $gc('NEW_DEPLOY') + ", 这是计划轮询");
// 执行与计划轮询相关的逻辑,例如,禁用特定目的地
}步骤 3:根据轮询类型控制目的地执行
一旦在源过滤器/转换器中识别了轮询类型,就可以将这个信息传递下去,或者直接在此处根据条件控制后续目的地的行为。
例如,如果你想在首次部署轮询时只执行备份目的地,而在计划轮询时不执行恢复目的地,可以在源转换器中根据NEW_DEPLOY的状态来修改消息的元数据或直接操作destinationSet。
// 假设你有一个名为 'RestoreDestination' 的目的地
if ($gc('NEW_DEPLOY') == true) {
// 部署后的首次轮询,可能只执行备份,不执行恢复
// 可以在这里设置一个标志,供后续目的地过滤器使用
channelMap.put('isFirstDeployPoll', true);
} else {
// 计划轮询,可能执行备份,但不执行恢复
channelMap.put('isFirstDeployPoll', false);
// 示例:如果希望在计划轮询时移除特定目的地
// var destinationName = 'RestoreDestination';
// if (destinationSet.containsKey(destinationName)) {
// destinationSet.remove(destinationName);
// }
}然后,在“RestoreDestination”的目的地过滤器中,你可以检查channelMap.get('isFirstDeployPoll')的值来决定是否处理消息。
通过巧妙地利用Mirth Connect的全局通道变量和通道部署脚本,我们可以有效地识别通道是刚刚部署后进行的首次轮询,还是按预定计划进行的自动轮询。这为实现基于轮询类型的条件逻辑提供了基础,使得Mirth Connect通道的自动化流程更加灵活和可控。然而,对于需要区分“正在运行通道的手动触发轮询”与“计划轮询”的更复杂场景,可能需要考虑其他策略,例如使用独立的通道进行手动触发,或通过外部系统发送带有特定标志的消息来触发。
以上就是Mirth Connect中区分通道自动与手动轮询的策略的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号