Member 13232535 Ответов: 1

Как записать данные в файл с помощью nlog в приложении службы windows C#


Привет,
Я просто попытался записать данные в файл с помощью Nlog в приложении службы windows c#, но проблема в том, что служба запускается нормально, и никакой другой файл не создается для регистрации ; мне нужна помощь . Nlog не записывает данные в текстовый файл.

Что я уже пробовал:

namespace NlogTestService
{
    public partial class NlogTestService : ServiceBase
    {
        public NlogTestService()
        {
            InitializeComponent();
        }
        Logger logger = LogManager.GetCurrentClassLogger();
        protected override void OnStart(string[] args)
        {
            logger.Debug("Service get started");
            Thread thread1 = new Thread(new ThreadStart(NlogTestThread));
            thread1.Start();
        }

        protected override void OnStop()
        {
            logger.Debug("Service got stopped");
        }
        public void NlogTestThread()
        {
            logger.Debug("NlogTestThread get started");
        }
    }
}

-------------------------------------------------------------------------------
<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"

      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

      xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"

      autoReload="true"

      throwExceptions="false"

      internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log">

  <!-- optional, add some variables
  https://github.com/nlog/NLog/wiki/Configuration-file#variables
  -->
  <variable name="myvar" value="myvalue"/>

  <!--
  See https://github.com/nlog/nlog/wiki/Configuration-file
  for information on customizing logging rules and outputs.
   -->
  <targets>
    <target name ="f1" xsi:type="File" fileName="C:\Users\Lbluser\Desktop\Projects\NlogTestService\NlogTestServiceLog.txt"/>
    <!--
    add your targets here
    See https://github.com/nlog/NLog/wiki/Targets for possible targets.
    See https://github.com/nlog/NLog/wiki/Layout-Renderers for the possible layout renderers.
    -->

    <!--
    Write events to a file with the date in the filename.
    <target xsi:type="File" name="f" fileName="${basedir}/logs/${shortdate}.log"
            layout="${longdate} ${uppercase:${level}} ${message}" />
    -->
  

  <rules>
    <logger name="*" minlevel="Debug" writeTo="f1" />
    <!-- add your logging rules here -->

    <!--
    Write all events with minimal level of Debug (So Debug, Info, Warn, Error and Fatal, but not Trace)  to "f"
    <logger name="*" minlevel="Debug" writeTo="f" />
    -->

1 Ответов

Рейтинг:
8

Jochen Arndt

Видеть Конфигурационный файл · NLog / NLog Wiki · GitHub: ведение журнала устранения неполадок[^]:

Цитата:
Иногда наше приложение ничего не записывает в лог-файлы, даже если мы якобы правильно настроили ведение журнала. Может быть много причин, по которым журналы не записываются. Наиболее распространенными проблемами являются проблемы с разрешениями, как правило, в ASP.NET процесс, где aspnet_wp.exe или w3wp.exe процесс может не иметь доступа на запись в каталог, в котором мы хотим хранить журналы.
Я предполагаю, что это произошло здесь, потому что ваш сервис, вероятно, не имеет доступа на запись в каталог C:\Users\Lbluser\Desktop\Projects\NlogTestService.

Удалить или изменить
internalLogLevel="Off"
в конфигурационном файле ("выкл." - недопустимая опция в соответствии с документацией) и проверьте указанный внутренний файл журнала на наличие ошибок (но также убедитесь, что ваша служба имеет доступ на запись в каталог внутреннего файла журнала).