Log4Net RollingFileAppender无法将文件作为网络服务删除

时间:2016-09-22 09:02:45

标签: c# iis log4net

我有一个log4net每天在Windows 2008服务器上创建一个日志和调试文件,作为作为网络服务运行的ASP.MVC应用程序的一部分。它可以很好地创建日志,但是还有一个运行的清理操作,但这有删除文件的权限问题。我收到错误:

Access to the path 'C:\inetpub\Testing\MyApplication\log\Error-2016.08.22.log' is denied. 

如果我更改了文件的权限,以便网络服务完全控制,那么应用程序可以将其删除。

以下是代码:

    private void ConfigLog4Net(int maxAgeInDays)
    {
        var sFilename = AppDomain.CurrentDomain.BaseDirectory + @"\Log4Net.config";
        log4net.Config.XmlConfigurator.ConfigureAndWatch(
            new System.IO.FileInfo(sFilename));

        Log.InfoFormat("Log4Net Config - {0}", sFilename);

        var repository = LogManager.GetRepository() as Hierarchy;
        if (repository != null)
        {
            var appenders = repository.GetAppenders();
            if (appenders != null)
            {
                foreach (var appender in appenders)
                {
                    if (appender is RollingFileAppender)
                    {
                        var rollingFileAppender = appender as RollingFileAppender;
                        CleanupLogs(rollingFileAppender, maxAgeInDays);
                    }
                }
            }
        }
    }


    private void CleanupLogs(RollingFileAppender appender, int maxAgeInDays)
    {
        if (!File.Exists(appender.File)) return;
        var datePatternBits = appender.DatePattern.Split(new char[]{'\''}, StringSplitOptions.None);
        if (datePatternBits.Count() != 5 || datePatternBits[0].Length > 0 || datePatternBits[4].Length > 0)
            throw new ApplicationException(
                string.Format(
                    "Log4Net RollingFileAppender ({0} DatePattern unexpected format. Expected \"\'xxx\'date\'eee\'\" {1},{2},{3}",
                    appender.Name, datePatternBits.Count(), datePatternBits[0].Length, datePatternBits[4].Length));
        List<string> logPatternsToKeep = new List<string>();
        for (var i = 0; i <= maxAgeInDays; i++)
            logPatternsToKeep.Add(DateTime.Now.AddDays(-i).ToString(appender.DatePattern));

        FileInfo fileInfo = new FileInfo(appender.File);

        var searchString = string.Format("{0}*{1}", datePatternBits[1], datePatternBits[3]);
        var folderFiles =
            fileInfo.Directory.GetFiles(searchString);
        var logFiles = folderFiles
            .Where(x => logPatternsToKeep.All(y => !x.Name.Contains(y) && x.Name != fileInfo.Name));

        foreach (var log in logFiles)
            if (File.Exists(log.FullName)) File.Delete(log.FullName);
    }

我是否需要对网络服务权限执行某些操作,或者是否需要更改代码以便自动允许网络服务删除该文件?

1 个答案:

答案 0 :(得分:2)

网络服务没有权限删除日志目录中的文件。

您需要授予网络服务权限才能删除C:\ inetpub \ Testing \ MyApplication \ log \目录中的文件(不是其中的文件,而是目录本身)。