Failed to create the XA control connection. Error: "找不到存储过程 'master..xp_sqljdbc_xa_init_ex'。
Failed to create the XA control connection. Error: "找不到存储过程 'master..xp_sqljdbc_xa_init_ex'。
抛出异常的环境:使用atomikos配置分布式事务(MySQL和SQL server),在启动项目的时候抛出的异常。
分析原因:没有开启SQL server对XA事务支持
解决办法:
1.首先了解XA事务并下载JDBC驱动,参考:http://technet.microsoft.com/zh-cn/library/aa342335.aspx
2.对下载的驱动进行解压缩得到文件

3.将对应文件放入目标文件夹下,具体使用32位还是64位,看自己的操作系统
3.1 将auth\x86(x64|IA64)\sqljdbc_auth.dll放入WINDOWS\system32中
3.2 将xa\x86(x64|IA64)\sqljdbc_xa.dll放入Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER\MSSQL\Binn下 (具体在那个硬盘下,需要看SQL server的安装位置)
4.执行xa_install.sql生成sqlJDBCXAUser角色

5.创建新的SQL server用户,并将该角色赋给新建用户,可参考:http://www.blogjava.net/zyw090111/
6.修改操作系统上的配置:
6.1 在 Windows XP 和 Windows Server 2003 上:
6.1.1.在“控制面板”中,打开“管理工具”,然后打开“组件服务”。也可以单击“开始”按钮,单击“运行”,在“打开”框中键入dcomcnfg,然后按“确定”打开“组件服务”。
6.1.2.展开“组件服务”、“计算机”,右键单击“我的电脑”,然后选择“属性”。
6.1.3.单击“MSDTC”选项卡,再单击“安全性配置”。
6.1.4.选中“启用 XA 事务”复选框,然后单击“确定”。这将使 MS DTC 服务重新启动。
6.1.5.再次单击“确定”以关闭“属性”对话框,然后关闭“组件服务”。
6.1.6.停止 SQL Server,然后重新启动,以确保它与 MS DTC 更改同步。
6.2 在Win8或Server 2008上:
6.2.1.在“控制面板”中,打开“管理工具”,然后打开“组件服务”。也可以单击“开始”按钮,单击“运行”,在“打开”框中键入dcomcnfg,然后按“确定”打开“组件服务”。
6.2.2.展开“组件服务”\“计算机”\"Distribute Transaction Coordinator",右键单击“本地DTC”,然后选择“属性”。
6.2.3.单击“安全”选项卡,再单击“启用XA事务”。
6.2.4.然后单击“确定”。这将使 MS DTC 服务重新启动。
6.2.5.再次单击“确定”以关闭“属性”对话框,然后关闭“组件服务”。
6.2.6.停止 SQL Server,然后重新启动,以确保它与 MS DTC 更改同步。
7.配置时候遇到的问题:
7.1 所有的操作都配置好并且重启了SQL server以后再次启动项目抛出异常:
Failed to create the XA control connection. Error: "无法加载 DLL SQLJDBC_XA.dll 或它引用的一个 DLL。原因:
无法加载首先想到的就是找不到dll文件,,但是我明明放进去了,当时我参考了一篇博客放置的DLL SQLJDBC_XA.dll文件,由于博客描述不清楚,然后我全局搜索文件找到了两个,我就把dll放进去了其中我感觉更像的哪一个,结果明显不行,那就只能两个一起放了,后边进行追溯原因的时候发现第一次放的位置是c盘下的,但是我的SQL server安装的时候我选择的是e盘,所以会抛出上边的异常
原文:https://blog.csdn.net/gjf8510/article/details/16118687
该文章大部分内容来自于https://blog.csdn.net/gjf8510/article/details/16118687,本人只是对其中的一些地方进行了更改
Failed to create the XA control connection. Error: "找不到存储过程 'master..xp_sqljdbc_xa_init_ex'。的更多相关文章
- javax.transaction.xa.XAException: java.sql.SQLException: 无法创建 XA 控制连接。错误: 未能找到存储过程 'master..xp_sqljdbc_xa_init'
配置JTA SQL Server XADataSource参考:https://msdn.microsoft.com/zh-cn/library/aa342335.aspx 使用 JDBC 驱动程序 ...
- AndroidStudio 更新gradle Error:Failed to complete Gradle execution. Cause: Connection reset
Android Studio 报错:Error:Failed to complete Gradle execution. Cause: Connection reset.把最新可以运行的项目中g ...
- 安装VMWare WorkStation 10 异常【 Failed to create the requested registry keyKey:Installer Error: 1021】
下载了新的workstation 10,在安装的时候出现了异常Failed to create the requested registry keyKey:Installer Error: 1021. ...
- Connection to Oracle failed. [66000][12505] Listener refused the connection with the following error: ORA-12505, TNS:listener does not currently know of SID given in connect descriptor .
我安装了Oracle数据库,默认的数据库用户名是system,密码口令是安装过程中你自己设置的.可以先使用命令框,输入 sqlplus system; 然后再输入密码即可. 然后我的数据库连接工具使用 ...
- pip错误-failed to create process/fatal error in launcher
电脑同时装了python2和python3,并且都配置了环境变量 将python2的python.exe改成python2.exe,python3的python.exe没有改(主要用python2时则 ...
- Object type TYPE failed to create with error
ORA-39083: Object type TYPE failed to create with error: ORA-02304: invalid object identifier litera ...
- ubuntu下pig报错ERROR 2999: Unexpected internal error. Failed to create DataStorage的解决
2019-03-04 00:10:03,998 [main] ERROR org.apache.pig.Main - ERROR 2999: Unexpected internal error. Fa ...
- 在k8s中安装flannel的故障解决: Failed to create SubnetManager: error retrieving pod spec for : the server does not allow access to the requested resource
花了一个上午来追踪问题,k8s都反复新建了十多次,docker都重启了几次.(一次显示不有获取磁盘空间,重启docker,清空存储解决) 在用kubeadm安装容器化的几个组件时,flannel组件死 ...
- ERROR 14856 --- [reate-882003853] com.alibaba.druid.pool.DruidDataSource : create connection error, url: jdbc:mysql://localhost:3306/xhb?useUnicode=true&characterEncoding=UTF-8, errorCode 1045, sta
ERROR 14856 --- [reate-882003853] com.alibaba.druid.pool.DruidDataSource : create connection error, ...
随机推荐
- C#UDP广域网,局域网通信-原理分析
一.UDP局域网通信. 这个比较简单,关于局域网中的2台或者更多的计算机之间的UDP通信,网络上一大把,直接复制粘贴就可以使用,原理也非常简单.所以,本文不做详细介绍. 二.UDP广域通信(包括路由器 ...
- 网络编程-day3
---恢复内容开始--- 一.缓冲区: 将程序和网络解耦 输入缓冲区 输出缓冲区 每个 socket 被创建后,都会分配两个缓冲区,输入缓冲区和输出缓冲区. write()/send() 并不立即向 ...
- spoj mpoint
题解: 判断每一次加进来的时候有几个被破坏,几个添加 然后单调栈维护 代码: #include<bits/stdc++.h> using namespace std; ; ,now,oo= ...
- 一般处理程序、Ajax多图片上传带进度条
<!DOCTYPE html><html><head> <meta charset="utf-8" /> <tit ...
- spring boot开发环境搭建(三)
软件151 王帅 新建一个maven工程 Maven配置文件: <!-- Inherit defaults from Spring Boot --> <parent> & ...
- 【基于微信小程序的社区电商平台】第一次迭代心得(非正式版本
一.迭代任务 团队在第八周确认迭代计划时,是想要在第一阶段实现电商小程序的核心功能,就是买和卖,也是前端和后台数据交换的核心模块.涉及到首页浏览商品信息,查看商品详情及评论,选择加入购物车.关注卖家以 ...
- xcode: 解决 __nw_connection_get_connected_socket_block_invoke 1 Connection has no connected handler
Run -> Arguments -> Environment Variables -> Add -> Name: "OS_ACTIVITY_MODE", ...
- ShellExecute, WinExec与CreateProcess
0x01 ShellExecute ShellExecute的功能是运行一个外部程序(或者是打开一个已注册的文件.打开一个目录.打印一个文件等等),并对外部程序有一定的控制. 函数原型: Shel ...
- linux 查看并对外开放端口(防火墙拦截处理)
[转]https://blog.csdn.net/qq564425/article/details/80760528 Web应用在Tomcat部署后无法访问,可能是防火墙端口限制导致 查看端口是否可访 ...
- centos7 eclispe 编译C++遇到的问题总结
最近由于工作的需要,又开始回归之前已经遗忘了的技术.arm嵌入式这个古老的名词. 开始选择了linuxminit,开始的linuxminit17以前还可以,可是用了一下linuxminit19,发现r ...