ASP.NET页面记日志的问题,文件老是被占用,如何解决?

windstore 2010-03-05 11:04:09
应用场景是这样的,有个asp.net页面,当用户请求的时候,会记录到日志中,现在我的做法是直接写入到日志文件中。可问题来了,当用户并发量高的时候,日志文件老被占用,导致日志有部分写不进去。

我的想法是来一个请求的时候,把写日志操作插入线程池,用线程池来执行写文件操作。但是一想也不行,这样会把线程池占满,而线程池没处理完的时候,也会丢失一部分日志。

还有一个办法是丢入MSMQ,然后用另一个线程持续读取msmq写入日志。但是在这样太麻烦了。像log4net是怎么处理这个高并发请求日志的,请高人指点?
...全文
283 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
windstore 2010-03-07
  • 打赏
  • 举报
回复
这么说,我就用log4net了、、
aofengdaxia 2010-03-07
  • 打赏
  • 举报
回复
多线程放置资源冲突。设置一个全局的singleton变量。然后在读的时候锁死。
zming 2010-03-07
  • 打赏
  • 举报
回复
想不明白,为什么不直接使用 log4net ???

windstore 2010-03-06
  • 打赏
  • 举报
回复
我这个页面要求快速响应的,写数据库必然会浪费个几秒时间。 这样的方法貌似不行的
winner2050 2010-03-06
  • 打赏
  • 举报
回复
写进数据库里面算了。

就为个日志功能开发出高并发的功能不值得。
andy796746 2010-03-06
  • 打赏
  • 举报
回复
在项目里添加一个Global.asax项,在这里可以处理用户访问的并发问题。
kaizi_sun 2010-03-06
  • 打赏
  • 举报
回复
没睡的帮你顶下:)回复内容还短啊
wuyq11 2010-03-06
  • 打赏
  • 举报
回复
log4net
在大并发的情况下很好的解决了写入同一文件的问题.
winner2050 2010-03-06
  • 打赏
  • 举报
回复
引用 4 楼 windstore 的回复:
我这个页面要求快速响应的,写数据库必然会浪费个几秒时间。 这样的方法貌似不行的


绝对不会慢。
windstore 2010-03-06
  • 打赏
  • 举报
回复
没人指点帮我顶一下也成啊
  • 打赏
  • 举报
回复
是啊,数据库吧,就多一张表而已
windstore 2010-03-06
  • 打赏
  • 举报
回复
请假高人指点下呀。。。。。。
windstore 2010-03-05
  • 打赏
  • 举报
回复
都睡了?都睡了?回复内容太短了!

62,244

社区成员

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

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

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

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