.net实现日志文件重命名且保留历史日志文件

发布时间:2020-07-25 23:29:25 作者:mstan
来源:网络 阅读:677

一.当WebSurver.log日志文件内容大于多少M时,进行重命名,重命名的名字是系统当前时间(可以根据自己的需要更改名字),以时间重命名的日志都是一些历史记录,以便日后查看,但最新记录的东西还是会记录在WebSurver.log中

.net实现日志文件重命名且保留历史日志文件

二.以下是实现的代码

    

        public static void WriteSysLog(string p_strLogMsg)
        {
            //获取Web.config中设置的一个盘符路径
            string customPath = ConfigurationManager.AppSettings["ImagePath"].ToString();
            string[] strSplit = customPath.Split('\\');
            string letter = strSplit[0].ToString();//获得盘符
            string strFileDirectory = letter + "\\XCKY_Chancel\\";//文件夹名称         
            string strFileName = strFileDirectory + "WebSurver.log";//文件名称

            string sourceFileName = strFileName;
            string extension = sourceFileName.Substring(sourceFileName.LastIndexOf('.'), sourceFileName.Length - sourceFileName.LastIndexOf('.'));//获得文件后缀
            string newName = DateTime.Now.ToString("yyyyMMddHHmmssfff").ToString();//新文件的名称

            if (!Directory.Exists(strFileDirectory))//文件不存在
            {
                Directory.CreateDirectory(strFileDirectory);
            }

            if (File.Exists(strFileName))//如果文件存在
            {
                FileInfo fi = new FileInfo(strFileName);
                if (fi.Length > 1024*1024*10)//如果文件大于10M,则重命名
                {
                   
                    if (!File.Exists(Path.Combine(strFileDirectory, newName + extension)))//判断是否存在相同的名字
                    {
                        string currNewFilePath = Path.Combine(strFileDirectory, newName);
                        fi.MoveTo(currNewFilePath + extension);//生成一个重命名的文件
                    }
                }
            }

            if (File.Exists(strFileName))
            {
                string strLogMsg = "[" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss fff") + "]" + p_strLogMsg + "\r\n";
                File.AppendAllText(strFileName, strLogMsg);
            }
            else
            {
                FileStream fs1 = new FileStream(strFileName, FileMode.Create, FileAccess.Write);//创建写入文件 
                StreamWriter sw = new StreamWriter(fs1);
                sw.WriteLine("[" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss fff") + "]" + p_strLogMsg + "\r");//开始写入值
                sw.Close();
                fs1.Close();
            }
        }


推荐阅读:
  1. 浅谈Linux日志文件
  2. 如何处理日志文件丢失

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

记录 历史 命名

上一篇:openstack 实例获取不到IP地址

下一篇:let与expr命令的用法与实战案例

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》