0

使用 BizTalk 2016 FP3 CU5。

我有一个 BRE 规则,它接受 4 个键入的 xml 文档和一个数据连接。我已经设置了一个编排来使用调用规则形状来执行它。

我正在使用 BizTalk 部署框架 (BTDF) 进行部署,这可以很好地部署 BRE 策略。我的问题是,在策略的导出 xml(名为 NotificationService.xml)中有一个对规则中使用的数据库的硬编码引用 - 如下所示:

 <datarow ref="db_32" server="SDEIDBTI04\CrossRef" dataset="CrossRef" table="Lookups"

这引用了我的开发虚拟机,但随着解决方案通过测试推广并投入生产,服务器名称需要相应更改。

我目前对这个问题的解决方案是使用 BTDF 预处理 xml 文件的能力,并用从 SSO 获取的 EnvironmentSettings excel 文件中的值替换。因此,我创建了一个“NotificationService.Dynamic.xml”,其中我将前一行更改为:

<!-- ifdef ${_xml_preprocess} -->
  <datarow ref="db_32" server="${Common.Components.CrossRefDbServer}\CrossRef" dataset="CrossRef" table="Lookups" instances="16" selectivity="1" isdataconnection="true" instance="0" />
  <!-- endif -->

(*我必须保留 ifdef 是有充分理由的!)

在我的 deployment.btdfproj 文件中,我添加了以下内容以确保已部署的预处理策略是:

<FilesToXmlPreprocess Include="NotificationService.Dynamic.xml" 
Condition="'$(Configuration)' == 'Server'">
  <LocationPath>..\</LocationPath>
  <OutputFilename>NotificationService.Dynamic_Processed.xml</OutputFilename>
</FilesToXmlPreprocess>

<FilesToXmlPreprocess Include="NotificationService.Dynamic.xml" Condition="'$(Configuration)' != 'Server'">
  <LocationPath>..\NotificationService\NotificationService.BRE</LocationPath>
  <OutputFilename>NotificationService.Dynamic_Processed.xml</OutputFilename>
</FilesToXmlPreprocess>

<RulePolicies Include="NotificationService.Dynamic_Processed.xml">
  <LocationPath>..\NotificationService\NotificationService.BRE</LocationPath>
</RulePolicies>

这是可行的,但我不禁认为我的解决方案过于复杂。每次我导出新版本的策略时,我现在都必须经历从导出的 NotificationService.xml 文件创建 NotificationService.Dynamic.xml 文件的麻烦。人们在不使用 BTDF 时如何解决同样的问题?

如果事实证明我已经走上了最好的道路,那么希望这个问题将来会对其他人有所帮助 - 我找不到谷歌的答案!

4

1 回答 1

1

我会创建一个静态方法,您可以在其中创建所有逻辑来获取您的查找值。

CrossRefDbServer因此,在此方法中,您将使用SSOSettingsFileReader.dll获取 SSO设置,然后执行一些 c# 代码来调用您的查找表并返回值。

如果将注册表设置StaticSupport设置为,则可以在 BRE 中调用此方法1

于 2018-11-10T11:54:44.077 回答