Visual Studio 如何在日志文件名中包含git的提交ID?

xuo3flqw  于 2022-12-04  发布在  Git
关注(0)|答案(1)|浏览(143)

NLog produces the following log filename MyMachine_MyExe_1.0.0.0.log . It includes the assembly version, but not the git's commit id which can be seen in dll's Product version property below.
Is there a way, either via NLog.config or programmatically to include the git's commit id in the log's filename?

NLog.config

<variable name="callsite" value="${callsite:includeNamespace=false:className=true:methodName=true}"/>
<variable name="baseLogDir" value="logs" />
<variable name="baseLogFilename" value="${machinename}_${processname}_${assembly-version}" />
<variable name="debugTraceLayout" value="${longdate}|${level:uppercase=true}|${callsite}|${message}" />
<targets>
    <target
        xsi:type="Console"
        name="console"
        layout="${longdate}|${level:uppercase=true}|${message}" />
    <target xsi:type="File"
        name="fileInfo"
        fileName="${baseLogDir}/${baseLogFilename}.log"
        layout="${longdate}|${level:uppercase=true}|${message}"
        archiveFileName="${baseLogDir}/archive/${baseLogFilename}_{#}.log"
        archiveNumbering="Date"
        archiveOldFileOnStartup="true"
        archiveDateFormat="yyyyMMdd_HHmmss" />

MyProject.csproj

<Project Sdk="Microsoft.NET.Sdk">
    <Target Name="SetSourceRevisionId" BeforeTargets="InitializeSourceControlInformation">
        <Exec Command="git describe --long --always --dirty --exclude=* --abbrev=8" ConsoleToMSBuild="True" IgnoreExitCode="False">
            <Output PropertyName="SourceRevisionId" TaskParameter="ConsoleOutput" />
        </Exec>
    </Target>       
</Project>

MyLibrary.dll Properties

lrpiutwd

lrpiutwd1#

我将在msbuild项目中定义附加的程序集属性;

<Project Sdk="Microsoft.NET.Sdk">
    <Target Name="SetSourceRevisionId" BeforeTargets="InitializeSourceControlInformation">
        <Exec ...></Exec>
        <ItemGroup>
            <AssemblyMetadata Include="SourceRevisionId" Value="$(SourceRevisionId)" />
        </ItemGroup>
    </Target>       
</Project>

我相信你可以用它来定义NLog的Global Diagnostic Context(GDC)

GlobalDiagnosticsContext.Set(
    "SourceRevisionId",
    typeof(Program).Assembly
        .GetCustomAttributes<AssemblyMetadataAttribute>()
        .Where(a => a.Key == "SourceRevisionId")
        .Single()
        .Value
);

并定义输出文件名;

fileName="${baseLogDir}/${gdc:item=SourceRevisionId}.log"

相关问题