Can database Logger write to watchdog, in addition to ultimate_cron_log?

Created on 27 March 2019, over 5 years ago
Updated 12 April 2023, over 1 year ago

Problem/Motivation

The ultimate cron database logger writes entries to the ultimate_cron_log table instead of watchdog.

It's increasingly common to configure watchdog entries to logstash or similar log aggregation system.

The basic question is if streaming to watchdog is currently possible by a ultimate_cron configuration we're overlooking.

If not, should we look at implementing a logger plugin for this, or would there be appetite for having us contribute back a patch to the database logger to allow configuration for writing log records to watchdog as well as ultimate_cron_log table.

Proposed resolution

Log to core logger as well as the ultimate cron table.

Remaining tasks

  1. Do it
  2. Review

User interface changes

None.

API changes

None.

Data model changes

None.

Release notes snippet

TBD

Feature request
Status

Needs review

Version

2.0

Component

Plugins

Created by

🇺🇸United States August1914

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇧🇪Belgium jOpdebeeck

    We had an issue with the latest patch,

    In our case, the strings from RfcLogLevel::getLevels() were translated, which resulted in a Call to undefined method Drupal\Core\Logger\LoggerChannel::***()

    I fixed this in the latest patch and also added the comment suggestion from #10

          // A severity of -1 is not a valid RfcLogLevel but is the default value. With -1,
          // Ultimate Cron logs a message saying that cron has been executed, which is
          // unnecessary if you're running cron every minute as recommended.
          if ($log_entry->severity > -1) {
            $severityLevels = RfcLogLevel::getLevels();
            $severity = strtolower($severityLevels[$log_entry->severity]->getUntranslatedString());
            $this->loggerFactory->get('ultimate_cron_' . $log_entry->name)->{$severity}($log_entry->message ?: $log_entry->formatInitMessage());
          }
    
  • 🇪🇨Ecuador jwilson3

    For anyone curious, because there was no interdiff between 8 and 11, (aside from the comment addition) the change from #11 amounts to this:

    -        $severity = strtolower($severityLevels[$log_entry->severity]);
    +        $severity = strtolower($severityLevels[$log_entry->severity]->getUntranslatedString());
    

    Makes sense.

  • 🇮🇳India pratikshad Mumbai

    This is one of important functionality which is missing in ultimate cron.
    Shared path in #11 is working for me, Thanks @jOpdebeeck for sharing it.

  • Status changed to Needs work 11 months ago
  • 🇨🇭Switzerland berdir Switzerland

    I don't think it is necessary to uses a separate channel for every job, that could be part of the message.

    watchdog messages are translatable, they must not contain dynamic parts or every unique message will be its own separate translatable string. This could also be a security issue.

    Instead, formatInitMessage() needs to be re-implemented to use placeholders.

    Not convinced that this should be built into the Database logger. Either it should be it's own logger plugin (but then you can't have both I guess) or a separate setting.

  • 🇸🇪Sweden devdits

    Hi everyone,

    Will it have sense to use general `log` method instead of calling method from variable? Less code + Less magic in the code = Easier to read.

    I also think that from logs searching perspective logs should be placed in the old channel and not in a new one. If log comes from a module it should be written into the modules channel and not into a new one.

          // A severity of -1 is not a valid RfcLogLevel but is the default value. With -1,
          // Ultimate Cron logs a message saying that cron has been executed, which is
          // unnecessary if you're running cron every minute as recommended.
          if ($log_entry->severity > -1) {
            $log_message = strip_tags($log_entry->message ?: $log_entry->formatInitMessage());
            $this
              ->loggerFactory
              ->get($log_entry->name)
              ->log($log_entry->severity, $log_message);
          }
    

    I have added strip_tags in my example to convert such error messages:

    LogicException: Tratata in super_duper_cron() (line 44 of

    To this:

    LogicException: Tratata in super_duper_cron() (line 44 of /var/www/html/web/modules/custom/my_module/my_module.module).

Production build 0.71.5 2024