powershell - 尝试让 log4net 与 PowerShell 一起工作(混合使用 log4net 配置文件)

标签 powershell log4net log4net-configuration log4net-appender

我一直在努力让 log4net 与 PowerShell 一起使用。我有以下 PowerShell 代码,它使用配置文件拉入 log4net,然后尝试创建一个简单的日志文件条目,但出现错误。

Clear-History
Clear-Host
#
Write-Host "BEGIN: Importing module psm_logger.psm1"
Import-Module "C:\Users\Administrator\Desktop\ps\IIS\psm_logger.psm1" -Force
Write-Host "BEGIN: log4net configuration definition"
$log = New-Logger -Configuration "C:\Users\Administrator\Desktop\ps\IIS\logging\log4net.config" -Dll "C:\Users\Administrator\Desktop\ps\IIS\logging\log4net.dll"
Write-Host "END: log4net configuration definition"
Write-Host "BEGIN: log4net configuration DEBUG definition"
#$log.DebugFormat("Logger configuration file is : '{0}'", (Resolve-Path "C:\Users\Administrator\Desktop\ps\IIS\logging\log4net.config"))
Write-Host "END: log4net DEBUG configuration definition"
#======================
$ThisHostname = $env:COMPUTERNAME
#======================
Write-Host "BEGIN: Module/Snapin import/addition"
Write-Host ""
$log.Info("BEGIN: Module/Snapin import/addition")
#======================

上面引用的 psm_logger.psm1 文件包含:

function New-Logger
{
#Write-Host "BEGIN: New-Logger"
<#
.SYNOPSIS
      This function creates a log4net logger instance already configured
.OUTPUTS
      The log4net logger instance ready to be used
#>
     [CmdletBinding()]
     Param
     (
          [string]
          # Path of the configuration file of log4net
          $Configuration,
          [Alias("Dll")]
          [string]
          # Log4net dll path
          $log4netDllPath
     )
     Write-Verbose "[New-Logger] Logger initialization"
     $log4netDllPath = Resolve-Path $log4netDllPath -ErrorAction SilentlyContinue -ErrorVariable Err
     if ($Err)
     {
          throw "Log4net library cannot be found on the path $log4netDllPath"
     }
     else
     {
          Write-Verbose "[New-Logger] Log4net dll path is : '$log4netDllPath'"
          [void][Reflection.Assembly]::LoadFrom($log4netDllPath) | Out-Null
          # Log4net configuration loading
          $log4netConfigFilePath = Resolve-Path $Configuration -ErrorAction SilentlyContinue -ErrorVariable Err
          if ($Err)
          {
               throw "Log4Net configuration file $Configuration cannot be found"
          }
          else
          {
               Write-Verbose "[New-Logger] Log4net configuration file is '$log4netConfigFilePath' "
               $FileInfo = New-Object System.IO.FileInfo($log4netConfigFilePath)
               [log4net.Config.XmlConfigurator]::Configure($FileInfo)
               $script:MyCommonLogger = [log4net.LogManager]::GetLogger("root")
               Write-Verbose "[New-Logger] Logger is configured"
               return $MyCommonLogger
          }
     }
}

log4net 的配置文件如下所示:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" **requirePermission="false"**/>
    </configSections>
    <log4net>
        <appender name="LogFileAppender" type="log4net.Appender.FileAppender">
            <param name="File" value="C:\Users\Administrator\Desktop\ps\IIS\LOGS\LogTest2.txt" />
            <param name="AppendToFile" value="true" />
            <layout type="log4net.Layout.PatternLayout">
                <param name="Header" value="[Header]\r\n" />
                <param name="Footer" value="[Footer]\r\n" />
                <param name="ConversionPattern" value="%d [%t] %-5p %c %m%n" />
            </layout>
        </appender>
        <root>
            <level value="ALL" />
            <appender-ref ref="LogFileAppender" />
        </root>
    </log4net>
</configuration>

运行时产生的输出和错误是:

开始:导入模块 psm_logger.psm1 开始:log4net 配置定义 结束:log4net配置定义 BEGIN:log4net 配置 DEBUG 定义 结束:log4net DEBUG 配置定义 开始:模块/管理单元导入/添加

方法调用失败,因为 [System.Object[]] 不包含名为“Info”的方法。 在 C:\Users\Administrator\Desktop\ps\IIS\IIS_localLogs.ps1:18 char:10 + $log.Info <<<< ("BEGIN: 模块/管理单元导入/添加") + 类别信息:无效操作:(信息:字符串)[],运行时异常 + FullQualifiedErrorId:MethodNotFound

任何帮助将不胜感激!

(仅供引用:我最初是从此处的最佳实践博客条目中获取此代码:http://blog.octo.com/en/powershell-v2-my-best-practices/ 我发现它非常有帮助)

最佳答案

找到解决方案...

配置文件因顶部出现一些星号而损坏。删除这些解决了问题。感谢任何可能已经开始关注此问题的人,我希望这对将来的其他人有所帮助。

配置文件现在如下所示:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" requirePermission="false"/>
    </configSections>
    <log4net>
        <appender name="LogFileAppender" type="log4net.Appender.FileAppender">
            <param name="File" value="C:\Users\Administrator\Desktop\ps\IIS\LOGS\LogTest2.txt" />
            <param name="AppendToFile" value="true" />
            <layout type="log4net.Layout.PatternLayout">
                <param name="Header" value="[Header]\r\n" />
                <param name="Footer" value="[Footer]\r\n" />
                <param name="ConversionPattern" value="%d [%t] %-5p %c %m%n" />
            </layout>
        </appender>
        <root>
            <level value="ALL" />
            <appender-ref ref="LogFileAppender" />
        </root>
    </log4net>
</configuration>

关于powershell - 尝试让 log4net 与 PowerShell 一起工作(混合使用 log4net 配置文件),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13496363/

相关文章:

c# - 在没有xml文件的情况下初始化log4net

c# - Log4Net 单独的配置文件不起作用

log4net - 如何为控制台输出设置 DEBUG,为 FileAppender 设置 INFO?

log4net - 写入两个位置不起作用

PowerShell,异常处理 : Create custom logfile from Set-ADUser

使用 MSVC 从 Windows Powershell 编译 C 程序

configuration - Log4Net 过滤器 "OR"

c# - Entity Framework 记录任何错误

azure - PowerShell 获取 Azure API 报告?

arrays - 在 Powershell 中为每个数组值添加一个字符串前缀