从报错“无效操作,连接被关闭”探究Transaction的Timeout超时机制
1、报错如下:Invalid Operation the connection is closed,无效操作,连接被关闭。这个错误是并不是每次都报,只有在复杂操作、大事务的情况下才偶然报出来。
stackOverflow上有很多关于这个问题的讨论,例如这个:《System.Data.OracleClient random Invalid Operation the connection is closed》,但较零散,全扫了一遍之后,我仍然有如下疑问:
1)怎么看TransactionScope里的Timeout到底是多少,比如通过TransactionOptions.Timeout = new TimeSpan(0,0,3)设置之后,怎么知道TransactionScope里的超时就是3s?
2)默认MaxTimeout=10m,怎么才能设置任意值?
3)嵌套事务的外层超时是否包括所有内层事务的时间?
4)超时机制是怎么起作用的?
通过Reflector之类的工具查看源码,终于有了初步的理解,不对的地方,请大家指正!
2、怎么看TransactionScope里的Timeout?
用调试器逐级展开TransactionScope实例如下:
scope->committableTransaction->base->internalTransaction->absoluteTimeout //注:这是展开过程,不是代码
这个absoluteTimeout就是实际结果,但往往与你设置的值不匹配,比如:
TimeSpan | absoluteTimeout |
3s | 5 |
10s | 19 |
1m | 117 |
10m | 1171 |
30m | 3515 |
1h | 7031 |
看起来是经过某个算法转换后的值,这个算法写在TransactionTable.TimeoutTicks()里:
internal long TimeoutTicks(TimeSpan timeout){
if(timeout != TimeSpan.Zero) {
return (timeout.Ticks / 10000L >> ) + this.ticks;
}
return 9223372036854775807L;
}
这就清楚了,再加上上面那张对照表,就可以通过absoluteTimeout清楚知道设置是否生效。
3、默认MaxTimeout=10m,怎么才能设置任意值?
1)先说一下这个10m怎么来的?
TransactionScope.ctr()->TransactionManager.ValidateTimeout()->MaximumTimeout->MachineSettingsSection.MaximumTimeout
这个属性先读取c:\windows\Microsoft.NET\Framework\v4.0.30319\Config\machine.config里的值://注意对应的framework的版本!
<system.transactions>
<machineSettings maxTimeout="00:10:00" />
</system.transactions>
当然,我查看下来,所有版本的machine.config里默认都没有这个节点。那么退一步,由Attribute设置默认值:
[ConfigurationProperty("maxTimeout", DefaultValue = "00:10:00")]
public TimeSpan MaxTimeout
2)再说一下怎么改成任意值?
2.1)修改machine.config,优点:方便,缺点:会影响机器上的所有事务。方法是在全局的machine.config里添加对应节点,注意在自己的app/web.config里添加<machineSettings>节点会报错。
2.2)用反射(神器)!优点:只作用于自己的事务,缺点:用反射、稍麻烦、稍慢。
static void ChangeMaximumTimeout() {
Type t = typeof(TransactionManager);
FieldInfo f = t.GetField("_cachedMaxTimeout", BindingFlags.NonPublic | BindingFlags.Static);
f.SetValue(null, true);
f = t.GetField("_maximumTimeout", BindingFlags.NonPublic | BindingFlags.Static);
f.SetValue(null, new TimeSpan(, , ));
}
这么写是因为最终大家取的都是static类里的static属性:
public static class TransactionManager {
public static TimeSpan MaximumTimeout {
get {
if(!_cachedMaxTimeout) {
_maximumTimeout = MachineSettings.MaxTimeout;
}
return _maximumTimeout; }}}
贴出来,一目了然!
4、嵌套事务的外层超时是否包括所有内层事务的时间?
我理解外层超时包含所有内层事务的执行时间,测试代码如下:
option.Timeout = new TimeSpan(,,);
using(var scope = new TransactionScope(TransactionScopeOption.Required, option)) {
Thread.Sleep(); option1.Timeout = new TimeSpan(,,);
using(var scope1 = new TransactionScope(TransactionScopeOption.Required, option)) {
Thread.Sleep(); // 800以上基本就报超时错误了
}}
5、超时机制是怎么起作用的?
1)对于非根(committableTransaction == null)的事务,会构造一个scopeTimer = new Timer(timeSpan, TimeoutCallback)来触发超时回滚;
2)对于committableTransaction != null的根事务,超时机制尚未找到,有待补充完整。
从报错“无效操作,连接被关闭”探究Transaction的Timeout超时机制的更多相关文章
- DB2读取CLOB字段-was报错:操作无效:已关闭 Lob。 ERRORCODE=-4470, SQLSTATE=null
DB2读取CLOB字段-was报错:操作无效:已关闭 Lob. ERRORCODE=-4470, SQLSTATE=null 解决方法,在WAS中要用的数据源里面配置连个定制属性: progressi ...
- Vmware Pro 14报错:无法连接 MKS: 套接字连接尝试次数太多;正在放弃。
软件环境: 虚拟机软件:VMware Pro 14 母机操作系统:win7 客户机操作系统:CentOS 7 问题详情: 报错:无法连接 MKS: 套接字连接尝试次数太多:正在放弃. ...
- 【已解决】ckfinder_php_3.4.4 IIS 报错 无效请求
ckfinder_php_3.4.4 IIS 报错 无效请求 (Invalid request) Apache 正常,但是在IIS环境下报错,解决方法 设置 C:\Windows\Temp 目录 给 ...
- 【spring data jpa】使用spring data jpa 的删除操作,需要加注解@Modifying @Transactional 否则报错如下: No EntityManager with actual transaction available for current thread - cannot reliably process 'remove' call
使用spring data jpa 的删除操作,需要加注解@Modifying @Transactional 否则报错如下: No EntityManager with actual tran ...
- C# 保存PictureBox中的图片到数据库,并从数据库读取图片显示到PictrueBox,解决报错 “无效参数”
下面是两段关键代码: /// <summary> /// 将一张图片转换为字节 /// </summary> /// <param name="img" ...
- 编译时.test文件报错无法解决的方法,关闭test编译
有几次遇到从网上下载到的iOS开源代码编译报错,报错位置为Test Target的源文件,我就挺奇怪我又没做测试为啥会编译Test Target的源文件,之前的暴力解决方法是把Test Target直 ...
- 启动mongodb报错,无法连接mongodb
报错原因如下: MongoDB shell version v3.4.2 connecting to: mongodb://127.0.0.1:27017 --01T12:: W NETWORK [t ...
- Python Django 协程报错,进程池、线程池与异步调用、回调机制
一.问题描述 在Django视图函数中,导入 gevent 模块 import gevent from gevent import monkey; monkey.patch_all() from ge ...
- magento后台登陆被锁定 索引报错的解决:General error: 1205 Lock wait timeout
1. magento在索引的时候用shell,有时候会报错: General error: 1205 Lock wait timeout exceeded 这个时候,是因为行锁的原因,在表中您直接用s ...
随机推荐
- Java中List的使用
package ch8; import java.util.*; /** * Created by Jiqing on 2016/11/27. */ public class ListTest { p ...
- CentOS6.x最下化安装及优化配置
一.最小化安装自定义额外包组 1.1 选择最小化安装 1.2 自定义额外的包组 Base System的选择 Development的选择 如果需要中文的支持可以在Languages中勾选中文 1.3 ...
- TCP/IP协议学习(一) LWIP实现网络远程IAP下载更新
最近需要实现通过TCP/IP远程IAP在线更新功能,忙了2周终于在原有嵌入式服务器的基础上实现了该功能,这里就记录下实现的过程. IAP又称在应用编程,其实说简单点就是实现不需要jlink,仅通过芯片 ...
- [转]C++中引用(&)的用法和应用实例
from: here 对于习惯使用C进行开发的朋友们,在看到c++中出现的&符号,可能会犯迷糊,因为在C语言中这个符号表示了取地址符,但是在C++中它却有着不同的用途,掌握C++的&符 ...
- Request 接收参数乱码原理解析
起因: 今天早上被同事问了一个问题:说接收到的参数是乱码,让我帮着解决一下. 实际情景: 同事负责的平台是Ext.js框架搭建的,web.config配置文件里配置了全局为“GB2312”编码: &l ...
- Animation用法
测试代码及说明: <!DOCTYPE html> <html lang="en-US"> <head> <meta charset=&qu ...
- Android Toolbar样式定制详解
前言 Marterial Design出来也有一段时间了,为了紧跟Google的设计规范,决定在项目中使用Toolbar.使用了一段时间之后,发现很多时候原始的Toolbar并不能满足项目的要求.为了 ...
- (01)odoo模型中调用窗体动作
*模型代码 addons/stock/stock.py ---------------- #移库单执行移库动作(弹出详细框) @api.cr_uid_ids_context def ...
- exit(0)和exit(1)区别
exit(0):正常退出程序: exit(1):非正常退出程序: return:返回. return是语言级别的,表示调用堆栈的返回: exit是系统调用级别的,表示一个进程的退出.
- Javascript的"预编译"思考
今天工作需要,搜索下JS面试题,看到一个题目,大约是这样的 <script> var x = 1, y = z = 0; function add(n) { n = n+1; } y = ...