异常详细信息: System.InvalidOperationException: 内部连接致命错误

 

异常详细信息: System.InvalidOperationException: 内部连接致命错误。

系统:
某政府部门业务系统。
环境:
win2003 企业版 sp2,sql2000 企业版 sp4,iis6,.netframework(2003系统自带)
机器:
1号机器Dell 1800 Cpu TM 2.8G 内存2.5G SATA硬盘
2号机器Dell 2800 Cpu TM 2.8G 内存1G SCSI硬盘
3号机器Hp Cpu E5430 2.66G*2 内存4G,SCSI硬盘
业务量:
市+县区共9个数据库,每个数据库大概500个用户。并发访问大概在30-50左右。
系统经历过3个阶段。
一、刚开始使用1号机器,数据库和web程序都在1号机上。1年系统正常,稍稍有点慢。连接容易超时。
二、后来增加2号机器,web程序在1号机,数据库在2号机。1年半系统正常,执行长时间导出报表会出现超时。
三、2星期前采购3号机器,这是把web程序和数据库都放在3号机器上,所有软件都是相同的。
这是频繁出现 异常详细信息: System.InvalidOperationException: 内部连接致命错误。
大概在半天,业务量多的时候几个小时就来一次,重启服务器后正常。
查看数据库日志文件,里面有 “可能内存不够” 这样的错误提示。此时查看系统,sql进程占用1.3G,还有1.5G空闲物理内存。

问题:这就奇怪了,程序一点没有变动,软件也是相同的,包括win2003,sql2000,补丁。
难道增加内存也有错?

我也也在google上搜索过,很多人说是数据库连接使用了没有关闭的原因。
首先我检查过程序,基本都关闭了,其次,系统运行快3年了,内存少时都没有问题,难道内存多了,反而有问题?
还有,我查看sql企业管理器-管理-当前信息-进程信息的时候, 报内存不足的信息,但是这是系统还有1.5G的物理内存。

最近试了下解决的方法,主要有以下几个:
----------------------------------------------------
如果sql server 与 IIS服务器位于同一台服务器,web.config 里的数据库连接串中IP地址应为(local),
而不能为本机的实际静态IP地址,否则傻傻的 ado.net 就晕了!
检查类似位置:
<add key="connectionString" value="Server=210.68.68.10;Database=abc;User ID=abc;Password=abc" />
其中 Server的IP地址改成 (local)如下:
<add key="connectionString" value="Server=(local);Database=abc;User ID=abc;Password=abc" />

修改了之后,感觉此方法无效。
----------------------------------------------------
修改sql 的使用内存,把原来的4G改为1G

修改之后,目前还没有问题,已经使用了7个小时
不过这是治标不治本的办法,系统的优势没有发挥出来
----------------------------------------------------
安装win2003和sql2005 64位版本
完全解决问题
----------------------------------------------------
分析原因:
win2003和sql2000 32位版本对4G内存支持不好,在达到4G内存之前就挂了,从而无法释放资源,修改1G之后。
也许程序中会有少量没有释放的数据库连接。但是我觉得sql应该会自动回收此资源。
64位版本是默认支持4G以上内存的,NND,内存大也是一种负担。

特注:

1.32位的win2003,默认不支持4G内存,要修改boot.ini文件来支持4G以上的内存

2.根据微软专家介绍,通过使用3GB开关会导致数据库存在不稳定,如果想使用大内存就直接使用64bit的系统和安装64bit的SQL Server。
对于32bit机器而言,单个进程一般内存使用到1.6~1.7GB就差不多了

3.网上有报告称SqlServer2000对多CPU的支持有问题,即使打补丁到sp4也还是不够的,需要继续打补丁到KBxxxx。具体多少我忘了,你可以查一下你的EventLog,应该会有这个相关的SqlServer异常的。(估计你已经升级数据库了,没机会了)

顺便说一下:
1做web,2做数据库的方法可能是错误的。因为就我所知,数据库服务器除了对硬盘性能敏感外,还对内存数量敏感。
此外,既然你有多台数据库,同时原来就支持Web和数据库分开的方式,那么把数据库和Web都放在3,也不是特别好的方法。因为两者肯定会有竞争,例如对磁盘读写的竞争,或者还有IIS Log和DB备份的磁盘剩余空间竞争。分开问题少一点,而且有的时候问题比较好判断——看那一台服务器资源状况出问题了就知道了,例如CPU高的是哪一台。

4.以前使用的是sql身份验证,需要用户名和密码,web.config里的data source写的是ip地址,现在用的是windows身份验证,所以以前的用户名和密码都无效了,要改成User ID=机器名称;Integrated Security=True;" providerName="System.Data.SqlClient",就可以用了

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
这段异常详细信息显示了一个 System.InvalidOperationException,它指示了一个错误操作,错误是由于一个 URL 意外地以“/”结束导致的。URL 是统一资源定位符的缩写,用于标识互联网上的资源。在这种情况下,URL 似乎不符合预期的格式要求,因为它以“/”结束。 当编写代码时,我们通常会使用 URL 来访问网络上的资源,如网站、图像或文件。为了确保正确的访问方式,URL 需要满足特定的格式要求。其中一个要求是 URL 不能以斜杠“/”结束。 如果我们在程序中遇到以上的异常信息,意味着我们在某个地方使用了一个异常的 URL。要解决这个问题,我们需要检查并修复导致问题的代码。 首先,我们需要找到引发异常的代码行。通常,异常信息会提供引发异常的具体位置,我们可以根据提供的堆栈跟踪信息来定位问题所在。 然后,我们需要检查使用 URL 的代码行。查看错误的 URL,确保它不是以斜杠“/”结尾。如果是以斜杠“/”结尾,我们需要修改代码,移除或更改结尾的斜杠,使 URL 符合格式要求。 最后,我们重新运行程序,确保不再出现该异常。 总之,system.invalidoperationexception 异常详细信息指示了出现错误操作,即 URL 意外地以斜杠“/”结尾。为了解决这个问题,我们需要定位并修复导致异常的代码行,确保 URL 符合预期的格式要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值