iis 进程 阻塞 回收 问题

大飞为 2017-10-20 11:17:53
现在是这样 asp .net 项目 部署在IIS上 经常发送访问地址 响应超时的 问题
访问的时候会一直转圈圈。连接不上去。进到服务器 上面去 回收应用程序池就可以了。。
想知道 到底那个点导致进程卡住了。
有什么好的方法吗 ~~


...全文
782 17 打赏 收藏 转发到动态 举报
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
剑农 2019-01-16
  • 打赏
  • 举报
回复
老哥问题后来怎么解决的 分享下啊
丰云 2017-10-26
  • 打赏
  • 举报
回复
引用 13 楼 u014138682 的回复:
[quote=引用 12 楼 foren_whb 的回复:] [quote=引用 11 楼 u014138682 的回复:] [quote=引用 10 楼 foren_whb 的回复:] 还有就是连接对象嵌套创建,这也是很多新手,甚至老手常犯的错误
public static int ExecuteSql(string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLString, connection)) { try { connection.Open(); int rows = cmd.ExecuteNonQuery(); return rows; } catch (System.Data.SqlClient.SqlException e) { connection.Close(); throw e; } finally { connection.Close(); } } } } 老哥看有什么要 优化的码[/quote] 还行,有了finally释放,就没必要在catch里释放了,并且,应该同时显式释放command对象[/quote] using 到最后 会执行 Dispose Dispose中有Close 有必要这样加么 [/quote] 是没必要,我通常用了using就连try都不用了,try是个很消耗性能的操作
大飞为 2017-10-26
  • 打赏
  • 举报
回复
引用 12 楼 foren_whb 的回复:
[quote=引用 11 楼 u014138682 的回复:] [quote=引用 10 楼 foren_whb 的回复:] 还有就是连接对象嵌套创建,这也是很多新手,甚至老手常犯的错误
public static int ExecuteSql(string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLString, connection)) { try { connection.Open(); int rows = cmd.ExecuteNonQuery(); return rows; } catch (System.Data.SqlClient.SqlException e) { connection.Close(); throw e; } finally { connection.Close(); } } } } 老哥看有什么要 优化的码[/quote] 还行,有了finally释放,就没必要在catch里释放了,并且,应该同时显式释放command对象[/quote] using 到最后 会执行 Dispose Dispose中有Close 有必要这样加么
丰云 2017-10-26
  • 打赏
  • 举报
回复
引用 11 楼 u014138682 的回复:
[quote=引用 10 楼 foren_whb 的回复:] 还有就是连接对象嵌套创建,这也是很多新手,甚至老手常犯的错误
public static int ExecuteSql(string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLString, connection)) { try { connection.Open(); int rows = cmd.ExecuteNonQuery(); return rows; } catch (System.Data.SqlClient.SqlException e) { connection.Close(); throw e; } finally { connection.Close(); } } } } 老哥看有什么要 优化的码[/quote] 还行,有了finally释放,就没必要在catch里释放了,并且,应该同时显式释放command对象
闭包客 2017-10-26
  • 打赏
  • 举报
回复
你使用了连接池的话,连接是不能被显式关闭的,一个连接 Close 之后,它的状态就是 sleeping 的,所以数据库中存在多个 sleep 状态的连接是没有问题的。 从你给出的信息来看,并不能判断阻塞就是数据库连接引起的。你还需要检查你的 CPU、内存、硬盘是否跑满。 还有就是,iis 不会让一个网页一直转圈圈,它对响应不了的请求是会返回错误的,比如 server too busy 之类的错误信息,你还需要留意服务器返回的错误信息。
大飞为 2017-10-26
  • 打赏
  • 举报
回复
引用 14 楼 foren_whb 的回复:
[quote=引用 13 楼 u014138682 的回复:] [quote=引用 12 楼 foren_whb 的回复:] [quote=引用 11 楼 u014138682 的回复:] [quote=引用 10 楼 foren_whb 的回复:] 还有就是连接对象嵌套创建,这也是很多新手,甚至老手常犯的错误
public static int ExecuteSql(string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLString, connection)) { try { connection.Open(); int rows = cmd.ExecuteNonQuery(); return rows; } catch (System.Data.SqlClient.SqlException e) { connection.Close(); throw e; } finally { connection.Close(); } } } } 老哥看有什么要 优化的码[/quote] 还行,有了finally释放,就没必要在catch里释放了,并且,应该同时显式释放command对象[/quote] using 到最后 会执行 Dispose Dispose中有Close 有必要这样加么 [/quote] 是没必要,我通常用了using就连try都不用了,try是个很消耗性能的操作[/quote] 但是就是有连接没关闭 导致IIS假死。
丰云 2017-10-24
  • 打赏
  • 举报
回复
还有就是连接对象嵌套创建,这也是很多新手,甚至老手常犯的错误
大飞为 2017-10-24
  • 打赏
  • 举报
回复
引用 10 楼 foren_whb 的回复:
还有就是连接对象嵌套创建,这也是很多新手,甚至老手常犯的错误
public static int ExecuteSql(string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLString, connection)) { try { connection.Open(); int rows = cmd.ExecuteNonQuery(); return rows; } catch (System.Data.SqlClient.SqlException e) { connection.Close(); throw e; } finally { connection.Close(); } } } } 老哥看有什么要 优化的码
㤁孞 2017-10-23
  • 打赏
  • 举报
回复
引用 7 楼 u014138682 的回复:
[quote=引用 6 楼 Mynameisamirror 的回复:] 是不是代码有些地方没有释放数据库连接导致的,如果是请检查代码
这个改过了 一样效果不佳。[/quote] http://bbs.csdn.net/topics/80522897 http://blog.csdn.net/burgess_liu/article/details/53610490 再检查一下如果确定代码没有问题,可以先试试写个定时任务清理sleeping进程,再继续找如何彻底解决的方案
大飞为 2017-10-23
  • 打赏
  • 举报
回复
引用 6 楼 Mynameisamirror 的回复:
是不是代码有些地方没有释放数据库连接导致的,如果是请检查代码
这个改过了 一样效果不佳。
㤁孞 2017-10-23
  • 打赏
  • 举报
回复
是不是代码有些地方没有释放数据库连接导致的,如果是请检查代码
大飞为 2017-10-23
  • 打赏
  • 举报
回复
引用 4 楼 foren_whb 的回复:
这种情况多半是代码内存管理不当导致的,应当检查连接异常时服务器的资源占用情况,检查代码连接对象,文件对象,文档对象等大对象的使用逻辑,释放是否有保证
我发现个问题 我用 sp_who2 查找 该项目的连接数 异常的多。 3 400个 几乎都是 sleeping 状态。
丰云 2017-10-23
  • 打赏
  • 举报
回复
这种情况多半是代码内存管理不当导致的,应当检查连接异常时服务器的资源占用情况,检查代码连接对象,文件对象,文档对象等大对象的使用逻辑,释放是否有保证
ying1234 2017-10-23
  • 打赏
  • 举报
回复
在服务器上看看事件查看器-->windows日志-->应用程序,看看有没有web方面的错误,实在不行,就在代码上各个地方写日志,看看是哪句话执行时间太长了。一点点排除
menglingjun 2017-10-20
  • 打赏
  • 举报
回复
菜单栏--调试--附加到进程--选择iis的进程,在程序里加断点调试一下看看哪里卡住了~
正怒月神 版主 2017-10-20
  • 打赏
  • 举报
回复
有没有日志,或者看看相关的数据库查询是不是超时。 最好能模拟用户操作查看。 一般来说,系统日志必不可少。 毕竟正式环境,一般不允许调试。
大飞为 2017-10-20
  • 打赏
  • 举报
回复
引用 1 楼 menglingjun 的回复:
菜单栏--调试--附加到进程--选择iis的进程,在程序里加断点调试一下看看哪里卡住了~
已经部署到线上 的项目 用着用着卡住了
net的最近面试经典试题ASP.NET面试题集合 1. 简述 private、 protected、 public、 internal 修饰符的访问权限。 答 . private : 私有成员, 在类的内部才可以访问。 protected : 保护成员,该类内部和继承类中可以访问。 public : 公共成员,完全公开,没有访问限制。 internal: 在同一命名空间内可以访问。 2 .列举ASP.NET 页面之间传递值的几种方式。 答. 1.使用QueryString, 如....?id=1; response. Redirect().... 2.使用Session变量 3.使用Server.Transfer 3. 一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少, 用递归算法实现。 答:public class MainClass { public static void Main() { Console.WriteLine(Foo(30)); } public static int Foo(int i) { if (i 0 && i <= 2) return 1; else return Foo(i -1) + Foo(i - 2); } } 4.C#中的委托是什么?事件是不是一种委托? 答 : 委托可以把一个方法作为参数代入另一个方法。 委托可以理解为指向一个函数的引用。 是,是一种特殊的委托 5.override与重载的区别 答 : override 与重载的区别。重载是方法的名称相同。参数或参数类型不同,进行多次重载以适应不同的需要 Override 是进行基类中函数的重写。为了适应需要。 6.如果在一个B/S结构的系统中需要传递变量值,但是又不能使用Session、Cookie、Application,您有几种方法进行处理? 答 : this.Server.Transfer 7.请编程遍历页面上所有TextBox控件并给它赋值为string.Empty? 答: foreach (System.Windows.Forms.Control control in this.Controls) { if (control is System.Windows.Forms.TextBox) { System.Windows.Forms.TextBox tb = (System.Windows.Forms.TextBox)control ; tb.Text = String.Empty ; } } 8.请编程实现一个冒泡排序算法? 答: int [] array = new int ; int temp = 0 ; for (int i = 0 ; i < array.Length - 1 ; i++) { for (int j = i + 1 ; j < array.Length ; j++) { if (array[j] < array) { temp = array ; array = array[j] ; array[j] = temp ; } } } 9.描述一下C#中索引器的实现过程,是否只能根据数字进行索引? 答:不是。可以用任意类型。 10.求以下表达式的值,写出您想到的一种或几种实现方法: 1-2+3-4+……+m [Page] 答: int Num = this.TextBox1.Text.ToString() ; int Sum = 0 ; for (int i = 0 ; i < Num + 1 ; i++) { if((i%2) == 1) { Sum += i ; } else { Sum = Sum - I ; } } System.Console.WriteLine(Sum.ToString()); System.Console.ReadLine() ; 11.用.net做B/S结构的系统,您是用几层结构来开发,每一层之间的关系以及为什么要这样分层? 答:一般为3层 数据访问层,业务层,表示层。 数据访问层对数据库进行增删查改。 业务层一般分为二层,业务表观层实现与表示层的沟通,业务规则层实现用户密码的安全等。 表示层为了与用户交互例如用户添加表单。 优点: 分工明确,条理清晰,易于调试,而且具有可扩展性。 缺点: 增加成本。 12.在下面的例子里 using Sy

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧