C#多线程写日志
由于程序是3层架构的,所有多线程记录日志成了比较棘手的问题,以前还真就没有在意过写日志的问题,认为不过是写文件罢了~~!如今发现原来要实现文件共享,并且能够使多线程同时操作日志还不能相互冲突,真的很麻烦。当然要实现它我首先想到的是在网上搜,结果可能是我搜的不得其法,没发现结果,多数都是用lock,mutx等线程锁或互斥的方式写日志,偶想这样和单线程有啥区别吗?还是没能起到多线程应该有的效率!
后来问朋友,发现个log4net的东西,不过此物依然用到了线程互斥,看了源码发现的!
网络不行,朋友不知道,只好自己想办法。想了几种方法如下:
1、写多个文件,然后找个机会把这些文件合并!
2、干脆放弃写文件,改写数据库!
3、把文件看成一个表结构,实现行级锁。也就是一个线程写一行。
4、把文件看成内存块,每块写完再合并!
以上几种方法缺点:
1、多个文件。。。想起来就恶心!
2、写数据库?太没技术含量咱不干!
3、行级锁?我一个线程要写入多行不是看起来很乱?
4、没想到啥缺点,实现它吧!
以下是偶经过了10000线程并发测试,也没发现问题的代码!
- using System;
- using System.Collections.Generic;
- using System.Text;
- namespace MTW
- {
- public class MTWFile
- {
- private string _fileName;
- private static Dictionary<long, long> lockDic = new Dictionary<long, long>();
- /// <summary>
- /// 获取或设置文件名称
- /// </summary>
- public string FileName
- {
- get { return _fileName; }
- set { _fileName = value; }
- }
- /// <summary>
- /// 构造函数
- /// </summary>
- /// <param name="byteCount">每次开辟位数大小,这个直接影响到记录文件的效率</param>
- /// <param name="fileName">文件全路径名</param>
- public MTWFile(string fileName)
- {
- _fileName = fileName;
- }
- /// <summary>
- /// 创建文件
- /// </summary>
- /// <param name="fileName"></param>
- public void Create(string fileName)
- {
- if (!System.IO.File.Exists(fileName))
- {
- using (System.IO.FileStream fs = System.IO.File.Create(fileName))
- {
- fs.Close();
- }
- }
- }
- /// <summary>
- /// 写入文本
- /// </summary>
- /// <param name="content">文本内容</param>
- private void Write(string content, string newLine)
- {
- if (string.IsNullOrEmpty(_fileName))
- {
- throw new Exception("FileName不能为空!");
- }
- using (System.IO.FileStream fs = new System.IO.FileStream(_fileName, System.IO.FileMode.OpenOrCreate, System.IO.FileAccess.ReadWrite, System.IO.FileShare.ReadWrite, 8, System.IO.FileOptions.Asynchronous))
- {
- //Byte[] dataArray = System.Text.Encoding.ASCII.GetBytes(System.DateTime.Now.ToString() + content + "/r/n");
- Byte[] dataArray = System.Text.Encoding.Default.GetBytes(content + newLine);
- bool flag = true;
- long slen = dataArray.Length;
- long len = 0;
- while (flag)
- {
- try
- {
- if (len >= fs.Length)
- {
- fs.Lock(len, slen);
- lockDic[len] = slen;
- flag = false;
- }
- else
- {
- len = fs.Length;
- }
- }
- catch (Exception ex)
- {
- while (!lockDic.ContainsKey(len))
- {
- len += lockDic[len];
- }
- }
- }
- fs.Seek(len, System.IO.SeekOrigin.Begin);
- fs.Write(dataArray, 0, dataArray.Length);
- fs.Close();
- }
- }
- /// <summary>
- /// 写入文件内容
- /// </summary>
- /// <param name="content"></param>
- public void WriteLine(string content)
- {
- this.Write(content, System.Environment.NewLine);
- }
- /// <summary>
- /// 写入文件
- /// </summary>
- /// <param name="content"></param>
- public void Write(string content)
- {
- this.Write(content, "");
- }
- }
- }
调用起来很简单,实例化,然后随便调用一个write或writeLine方法!
C#多线程写日志的更多相关文章
- 一种多线程写日志文件的解决方案 c#源代码演示
using System;using System.Collections.Generic;using System.Collections;using System.Text;using Syste ...
- c# 多线程使用队列顺序写日志的类 (需要再优化)
using System; using System.Collections.Generic; using System.Threading; public class LogManager { // ...
- Delphi 写日志的类
unit uProgLog; interface uses Windows, SysUtils, SyncObjs; const C_LOG_LEVEL_TRACE = $; C_LOG_LEVEL_ ...
- 重复造轮子,编写一个轻量级的异步写日志的实用工具类(LogAsyncWriter)
一说到写日志,大家可能推荐一堆的开源日志框架,如:Log4Net.NLog,这些日志框架确实也不错,比较强大也比较灵活,但也正因为又强大又灵活,导致我们使用他们时需要引用一些DLL,同时还要学习各种用 ...
- C#写日志工具类
代码: using System; using System.Collections.Generic; using System.IO; using System.Linq; using System ...
- .NET Core的日志[5]:利用TraceSource写日志
从微软推出第一个版本的.NET Framework的时候,就在“System.Diagnostics”命名空间中提供了Debug和Trace两个类帮助我们完成针对调试和跟踪信息的日志记录.在.NET ...
- [转]ASP.NET Core 开发-Logging 使用NLog 写日志文件
本文转自:http://www.cnblogs.com/Leo_wl/p/5561812.html ASP.NET Core 开发-Logging 使用NLog 写日志文件. NLog 可以适用于 . ...
- Spring 使用 SLF4J代替 Commons Logging 写日志 异常
项目的日志更换成slf4j和logback后,发现项目无法启动.错误提示 Caused by: java.lang.NoClassDefFoundError: Lorg/apache/commons/ ...
- 程序员的修养 -- 如何写日志(logging)
在程序中写日志是一件非常重要,但是很容易被开发人员忽视的地方.写好程序的日志可以帮助我们大大减轻后期维护压力. 在实际的工作中,开发人员往往迫于的巨大时间压力,而写日志又是一个非常繁琐的事情,往往 ...
随机推荐
- MySQL数据库引擎详解
作为Java程序员,MySQL数据库大家平时应该都没少使用吧,对MySQL数据库的引擎应该也有所了解,这篇文章就让我详细的说说MySQL数据库的Innodb和MyIASM两种引擎以及其索引结构.也来巩 ...
- 006.Zabbix添加监控主机
一 配置步骤和流程 Zabbix完整的监控配置流程可以简单的描述为: Host groups(主机组)---->Hosts(主机)---->Applications(监控项组)----&g ...
- 001.Postfix简介
一 简介 postfix是Wietse Venema在IBM的GPL协议之下开发的MTA(邮件传输代理)软件.Postfix提供更快.更容易管理.更安全,同时还与 sendmail保持足够的兼容性,是 ...
- 解决Windows10下无法对docker容器进行端口访问(端口映射的问题)
解决Windows10下无法对docker容器进行端口访问(端口映射的问题) 问题详情 在Windows10系统服务器中安装了docker和docker-compose 并尝试在其中运行Nginx服务 ...
- 【转载】Android dip,px,pt,sp 的区别
dip: device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA.HVGA和QVGA 推荐使用这个,不依赖像素. ...
- Java 与 .NET 的平台发展之争
Java 8即将正式发布,从早期版本中,我们已经可以领略到一些令人兴奋的特性.但是开发者Andrew C. Oliver表示,尽管如此,Java语言在某些特性上还是落后于.Net.比如,Java 8中 ...
- Message Queue协议AMQP
历史: Message Queue的需求由来已久,80年代最早在金融交易中,高盛等公司采用Teknekron公司的产品,当时的Message queuing软件叫做:the information b ...
- 使用CefSharp在.Net程序中嵌入Chrome浏览器(六)——调试
chrome强大的调试功能令许多开发者爱不释手,在使用cef的时候,我们也可以继承这强大的开发者工具. 集成调试: 我们可以使用如下函数直接使用集成在chrome里的开发者工具 _chrome.Sho ...
- python dtrace 安装与应用
https://ipfans.github.io/2016/09/tracing-python-program-with-dtrace/?utm_source=tuicool&utm_medi ...
- cmd 递归删除目录或文件
递归删目录 for /r <TARGET DIR> %i in (<DIR NAME or Pattern>) do rd /s /q %i 递归删文件 for /r < ...