我遇到了新的服务器设置问题.应用程序服务器启动到新服务器的分布式事务失败,但它们与现有数据库服务器一起正常工作.我需要帮助确定问题的原因.

由于各种原因,新服务器未运行Windows或sql Server的最新版本.

建立

应用服务器

>操作系统:Windows Server 2008 R2
> NetBIOS名称:WEB-02
>配置为与多个数据库服务器通信,一些是本地的,一些是远程的.
> DCOM端口限制在5000-5020范围内,用于通过防火墙与远程服务器进行通信.
>启用Windows防火墙
> DTC属性

>选中网络DTC访问
>允许远程客户端,取消选中“允许远程管理”
>交易经理沟通

>允许入站,允许出站检查
>无需身份验证

>取消选中启用XA事务
>启用SNA LU 6.2事务已选中

新的数据库服务器

>操作系统:Windows Server 2008
> NetBIOS名称:DB-06
> sql Server 2005
> DCOM端口没有限制
>禁用Windows防火墙
> DTC属性

>选中网络DTC访问
>取消选中远程客户端,
>选中“远程管理”
>交易经理沟通

>允许入站,允许出站检查
>无需身份验证

>取消选中启用XA事务
>“启用SNA LU 6.2事务”不存在

现有的数据库服务器

>操作系统:Windows Server 2003 R2
> NetBIOS名称:DB-04
> sql Server 2005
> DCOM端口没有限制
>禁用Windows防火墙
> DTC属性

>选中网络DTC访问
>取消选中远程客户端,允许出站检查
>无需身份验证

>取消选中启用XA事务
>“启用SNA LU 6.2事务”不存在

所有三台服务器都属于同一个域,并且位于同一子网中.它们之间只有一个以太网交换机,没有路由器,硬件防火墙和安全设备.

问题

ASP.NET应用程序在应用程序服务器上运行,并在对现有数据库服务器(DB-04)执行事务时正常工作.对新数据库服务器(DB-06)执行相同步骤时,它会失败并报告错误消息:与基础事务管理器的通信失败.

故障排除步骤

我们在使用此应用程序之前已经看到此错误,这通常意味着未正确配置分布式事务处理协调器或防火墙正在干扰.过去,我使用DTCPing来排除故障并纠正任何错误.

但是,这次虽然DTCPing失败,但我无法确定问题的原因,因为现有的和新的数据库服务器似乎配置相同,但操作系统版本除外.

从应用程序服务器(WEB-02)到新数据库服务器(DB-06)运行测试时,以下内容来自DTCPing日志文件.请注意,我已更改IP地址和DNS名称.

从应用程序服务器上的日志文件

10-14,16:08:11.346-->Error(0x424) at clutil.cpp @256
10-14,16:08:11.346-->-->OpenCluster
10-14,16:08:11.346-->-->1060(The specified service does not exist as an installed service.)
++++++++++++++++++++++++++++++++++++++++++++++
     DTCping 1.9 Report for WEB-02  
++++++++++++++++++++++++++++++++++++++++++++++
Firewall Port Settings:
    Port:5000-5020
RPC server is ready
++++++++++++Validating Remote Computer Name++++++++++++
10-14,16:08:22.796-->Start DTC connection test
Name Resolution:
    DB-06-->1.1.1.6-->s6.mydomain.com
10-14,16:08:22.812-->Start RPC test (WEB-02-->DB-06)
RPC test Failed

从新数据库服务器上的日志文件

10-14,16:07:46.128-->Error(0x424) at clutil.cpp @256
10-14,16:07:46.128-->-->OpenCluster
10-14,16:07:46.129-->-->1060(The specified service does not exist as an installed service.)
++++++++++++++++++++++++++++++++++++++++++++++
     DTCping 1.9 Report for DB-06  
++++++++++++++++++++++++++++++++++++++++++++++
RPC server is ready
10-14,16:08:22.785-->RPC server:DB-06 received following information:
    Network Name: DB-06
    Source  Port: 56535
    Partner LOG: WEB-022872.log
    Partner CID: 1ACD8780-9446-4E94-869D-6F1BDF787BBF

在数据库服务器上单击PING后,会将以下内容添加到日志文件中.在输出窗口中,在调用RPC方法和失败之间存在暂停,因此在超时后失败.

++++++++++++Validating Remote Computer Name++++++++++++
10-14,16:13:18.924-->Start DTC connection test
Name Resolution:
    Web-02-->1.1.1.2-->web-02.mydomain.com
10-14,16:13:18.933-->Start RPC test (DB-06-->Web-02)
Problem:fail to invoke remote RPC method
Error(0x6D9) at dtcping.cpp @303
-->RPC pinging exception
-->1753(There are no more endpoints available from the endpoint mapper.)
RPC test Failed

正如Troubleshooting MSDTC issues with the DTCPing tool在“错误消息4 – 端点映射器中没有更多端点”部分中所解释的那样,映射器实际上有更多端点.我在应用程序服务器(具有受限端口的服务器)上运行了netstat -an,它只使用了20个可用端口中的10个.

在让Microsoft参与并完成并分析了许多网络跟踪之后,我们终于找到了问题.应用程序服务器是网络负载平衡群集的一部分,Windows Server 2008 R2上的IPv6实现如何与网络负载平衡组件交互存在缺陷.

由于服务器具有可公共路由的IPv4地址,因此IPv6堆栈会自动创建“6to4”地址.这是一个特殊的IPv6地址,对应于计算机可公开路由的IPv4地址.它为机器自己的地址和共享集群地址执行此操作.缺陷是它以自己的名义在DNS中注册了6到4个地址.这与IPv4堆栈在同一台计算机上的工作方式不同.使用IPv4时,群集IP地址未在DNS中注册.

结果是当连接到新数据库服务器和数据库服务器的应用程序服务器尝试反向绑定到应用程序服务器时,它会看到应用程序服务器有IPv6地址并尝试使用其中一个地址进行连接.但是因为它使用了与集群IP地址相对应的6to4地址,集群中的另一台服务器将接收连接,并且由于该服务器上的DTC不期望反向绑定,因此失败.

现有的数据库服务器(Windows Server 2003 R2)不使用IPv6,因此没有遇到问题.

解决方案是禁用自动6to4地址生成.您可以通过组策略或使用以下命令行执行此操作:

netsh interface 6to4 set state disabled

要将其设置回来,您将运行以下命令:

netsh interface 6to4 set state default

要查看当前设置,请运行以下命令.在Windows 2008 R2 / Windows 7及更高版本中,它还将指示当前设置是否归因于组策略.

netsh interface 6to4 show state

windows-server-2008 – Windows Server 2008的分布式事务失败的更多相关文章

  1. 详解前端HTML5几种存储方式的总结

    本篇文章主要介绍了前端HTML5几种存储方式的总结 ,主要包括本地存储localstorage,本地存储sessionstorage,离线缓存(application cache),Web SQL,IndexedDB。有兴趣的可以了解一下。

  2. PhoneGap / iOS上的SQLite数据库 – 超过5mb可能

    我误解了什么吗?Phonegap中的sqlitedbs真的有5mb的限制吗?我正在使用Phonegap1.2和iOS5.解决方法您可以使用带有phonegap插件的原生sqliteDB,您将没有任何限制.在iOS5.1中,Websql被认为是可以随时删除的临时数据…

  3. ios – 领域:如何获取数据库的当前大小

    是否有RealmAPI方法使用RealmSwift作为数据存储来获取我的RealmSwift应用程序的当前数据库大小?

  4. ios – Realm – 无法使用现有主键值创建对象

    我有一个对象有许多狗的人.应用程序有单独的页面,它只显示狗和其他页面显示人的狗我的模型如下我有人存储在Realm中.人有详细页面,我们取,并显示他的狗.如果狗已经存在,我会更新该狗的最新信息并将其添加到人的狗列表中,否则创建新狗,保存并将其添加到人员列表中.这适用于coredata.在尝试用他的狗更新人时,领域会抛出异常无法使用现有主键值创建对象解决方法这里的问题是,即使你正在创建一个全新的Rea

  5. ios – UIWebView中的WebSQL / SQLite数据库的最大大小(phonegap)

    我知道一般来说,Web应用程序的本地存储空间有5MB的限制.本地网页浏览应用程式是否也有这个限制?

  6. ios – 如何在使用自动可再生应用内购买时恢复正确的交易?

    这个问题是关于自动再生IAP的问题,以及如何恢复.这些链接:this和this没有帮助我不幸.在我的应用程序中,我有用户订阅自动可再生应用内购买.他们可以订阅1,6或12个月.当他们订阅时,交易收据将发送到我的服务器以备以后验证.我不会立即验证收据,因为它会减慢用户体验(对苹果服务器的收据验证查询大约需要1–2秒).相反,我使用天真的方法,并提供用户订阅的内容,无需任何直接的接收验证.我安排一个c

  7. ios – Firebase离线存储高级 – 手动同步和进度信息

    >我可以提供一个捆绑数据库–安装App后我可以已经离线查询了Firebase数据?然后我有另一个关于Firebase的主要问题:>JSON存储是伟大的–但是这样我们不关心一个独特的结构,我们必须注意这一点插入总是正确的数据集?我从来没有试图显示实际的进展,但是当您从firebase中检索数据时,始终会在成功检索数据时调用onDataChange方法.https://firebase.google.com/docs/database/android/retrieve-data#read_data_onceC

  8. ios – Xcode上传错误:无法打开ssh会话. (16)

    注意:我们终于上传了该应用程序,但是我们并没有真正解决这个问题,所以如果有人可以分享一些有关这个问题的宝贵意见或经验,我将不胜感激.我也检查了以下2个类似的问题,但这些没有帮助:>Erroruploadingiosapplicationtoitunesconnect“failedtoopensshsession(16)”>AppStoresubmission/distributionerror“f

  9. ios – 如何处理多用户数据库

    我的应用程序就像很多应用程序–它有一个用户输入用户名和密码的登录屏幕,以及登录按钮我的应用程序还使用CoreData来保存大多数用户的业务对象,当然也是用户特定的.我也有一个登出按钮来启用切换用户.这不会发生很多,但仍然是必要的).现在如果不同的用户登录,我需要获取他的具体数据.但是我该如何做呢?

  10. ios – Swift从Firebase数据库中获取特定价值

    我正在尝试从Firebase数据库中获取特定值.我看了一些像谷歌这样的文件,但我做不到.这是数据库的JSON文件:SWIFT代码:我想获得用户的电子邮件价值,而不是每个人.我怎样才能做到这一点?解决方法在您的代码中,快照将包含子值的字典.要访问它们,请将snapshot.value转换为Dictionary,然后访问各个子项是一个快照

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部