2

在开发机器上,我们将 BizTalk 2010 服务器升级到 BizTalk 2013。我们正在将 HL72 消息从另一台机器发送到这台机器,并收到未找到架构的错误:

备用错误号:301 备用错误说明:未找到架构http://microsoft.com/HealthCare/HL7/2X#ORU_R01_23_GLO_DEF备用编码系统:HL7-BTA

该消息将“LAB”指定为发送应用程序,并且我们有一个名为“LAB”的方将“”指定http://mycompany/myapplication/HL7/2X/2.3/ORU/v1为模式命名空间,因此我们无法弄清楚它为什么要在默认的微软命名空间中寻找 ORU R01 2.3 模式.

在此处输入图像描述

我们的消息如下所示:

MSH|^~\&|LAB|ABC|LAB||201311071138||ORU^R01|D2863329|D|2.3|
PID|1|A00003766|XX00014202|9191610101|Ihhendrickson^Plis||19691202|M|||8423 Panko Pvt^^Here^BC^XXX XXX||111-1111|||||xx0055355x3|9x9x6x0x0x|
PV1|1|R|TRAKBHLB||||93190^Plisihd^xxxxxx^^^Dr^^xxxxxx|||||||||||RCR||BC|||||||||||||||||||xxxxx||REG|||201207261453|
ORC|RE|PT80755100.0010|||CM|N|||201311071138|^xxxxxx^Linda^^^^^xxxx||93190^xxxx^Aaron^^^Dr^^xxxx|xxx|
OBR|1|PT0711:T00001R100.0010|PT0711:T00001R|100.0010^Group \T\ Screen^00050252^34532-2^Blood Type \T\ Indirect Antibody Screen^pCLOCD|R|201311071004|201311071004|||G|||PLIS Testing|201311071004|T|93190^Plisihd^xxx^^^Dr^^Pxxxxx||00050252|||xxx|201311071004||BBK|F|||93190^xxx^Aaron^^^Dr^^xxxx|
NTE|1||Date required: 20131107|
NTE|2||Any previous transfusions? Unknown|
NTE|3||Specify any underlying blood disorders: U|
NTE|4||Has consent for blood products been obtained? Yes|
OBX|1|ST|150.0100^Patient Blood Group^00050252^882-1^Blood Type \T\ Indirect Antibody Screen^pCLOCD||OPOS^O Rh Pos|||||A~S|F|||201311071137|xx^xx^L|IH001^^Blood Group^Patient Blood Group^150.0100|
OBX|2|ST|200.0100^Ab Screen Gel^00050252^XBC1931-6^Blood Type \T\ Indirect Antibody Screen^pCLOCD||NEGATIVE^NEGATIVE|||||A~S|F|||201311071138|xx^xx^L|IH001^^Ab Scr Gel^Antibody Screen Gel^200.0100|
ZDR||xxx^xxxx^Aaron^^^Dr^^^^^^^^^ATP|
ZPR||

有人有我们应该尝试的想法吗?

4

2 回答 2

1

将 BizTalk 2010 就地升级到 BizTalk 2013 存在已知问题,可能是由于以下原因之一。最好不要就地升级,而是进行全新安装和迁移应用程序。

  1. BizTalk 2010 到 BizTalk 2013 的就地升级不会更新 Microsoft.BizTalk.GlobalPropertySchemas
  2. 将 BizTalk Server 2010 升级到 2013 – 需要在 BizTalkMgmtDb.bts_dynamic_sendport_handlers 表上设置权限
  3. 升级到 BizTalk 2013 – 无法加载文件或程序集“'Microsoft.BizTalk.Interop.SSOClient
于 2013-11-09T05:07:27.550 回答
1

对于发送端口,HL7 2.X Assembler 组件应该使用 MSH 5 字段值来确定使用方。发送端口上的管道配置应该有一个选项来启用部分名称解析 ( EnablePartialNameResolutionForReceivingApplication),这在打开时可能会有所帮助。

在接收位置,HL7 2X Disassembler 组件应使用 MSH 3 来解决聚会问题。接收位置的 BTAHL72XReceivePipeline 配置已调用设置EnablePartialNameResolutionForSendingApplicationEnablePartialNameResolutionForReceivingApplication供您打开。

旧版本的 BizTalk 需要修补程序才能使这些设置正常工作,但这不再是必需的。从该页面,设置的描述是:

对于发送管道,BTAHL7 2.X 汇编器包含以下属性:

Property name: Enable Partial Name Resolution For Receiving Application 
Default value: False 
Description for the property:
First check party with name MSH5.1 + MSH5.2 + MSH5.3. If not found, check party with name MSH5.1 + MSH5.2. If not found, check with name MSH5.1. 

对于接收管道,BTAHL7 2.X 反汇编程序包含以下属性:

Property name: Enable Partial Name Resolution For Receiving Application 
Default value: False 
Description for the property:
First check party with name MSH5.1 + MSH5.2 + MSH5.3. If not found, check party with name MSH5.1 + MSH5.2. If not found, check with name MSH5.1.
Property name: Enable Partial Name Resolution For Sending Application 
Default value: False 
Description for the property:
First check party with name MSH3.1 + MSH3.2 + MSH3.3. If not found, check party with name MSH3.1 + MSH3.2. If not found, check with name MSH3.1.

如果这没有帮助,那么还有另一件事可以尝试仅用于发送端口:在参与方配置中,尝试将参与方分配给您的发送端口,如此处第三步所述。这是试图强迫它使用适当的派对的一种方法。不过,这无助于接收位置。

于 2013-11-09T03:36:52.590 回答