Class: Syslog::Logger

Inherits:
Object
  • Object
show all
Defined in:
lib/syslog/logger.rb

Overview

Syslog::Logger is a Logger work-alike that logs via syslog instead of to a file. You can use Syslog::Logger to aggregate logs between multiple machines.

By default, Syslog::Logger uses the program name ‘ruby’, but this can be changed via the first argument to Syslog::Logger.new.

NOTE! You can only set the Syslog::Logger program name when you initialize Syslog::Logger for the first time. This is a limitation of the way Syslog::Logger uses syslog (and in some ways, a limitation of the way syslog(3) works). Attempts to change Syslog::Logger’s program name after the first initialization will be ignored.

Example

The following will log to syslogd on your local machine:

require 'syslog/logger'

log = Syslog::Logger.new 'my_program'
log.info 'this line will be logged via syslog(3)'

You may need to perform some syslog.conf setup first. For a BSD machine add the following lines to /etc/syslog.conf:

!my_program
*.*                                             /var/log/my_program.log

Then touch /var/log/my_program.log and signal syslogd with a HUP (killall -HUP syslogd, on FreeBSD).

If you wish to have logs automatically roll over and archive, see the newsyslog.conf(5) and newsyslog(8) man pages.

Defined Under Namespace

Classes: Formatter

Constant Summary collapse

VERSION =

The version of Syslog::Logger you are using.

'2.0'
LEVEL_MAP =

Maps Logger warning types to syslog(3) warning types.

Messages from ruby applications are not considered as critical as messages from other system daemons using syslog(3), so most messages are reduced by one level. For example, a fatal message for ruby’s Logger is considered an error for syslog(3).

{
  ::Logger::UNKNOWN => Syslog::LOG_ALERT,
  ::Logger::FATAL   => Syslog::LOG_ERR,
  ::Logger::ERROR   => Syslog::LOG_WARNING,
  ::Logger::WARN    => Syslog::LOG_NOTICE,
  ::Logger::INFO    => Syslog::LOG_INFO,
  ::Logger::DEBUG   => Syslog::LOG_DEBUG,
}

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(program_name = 'ruby') ⇒ Logger

Fills in variables for Logger compatibility. If this is the first instance of Syslog::Logger, program_name may be set to change the logged program name.

Due to the way syslog works, only one program name may be chosen.



177
178
179
180
181
182
# File 'lib/syslog/logger.rb', line 177

def initialize program_name = 'ruby'
  @level = ::Logger::DEBUG
  @formatter = Formatter.new

  @@syslog ||= Syslog.open(program_name)
end

Instance Attribute Details

#formatterObject

Logging formatter, as a Proc that will take four arguments and return the formatted message. The arguments are:

severity

The Severity of the log message.

time

A Time instance representing when the message was logged.

progname

The #progname configured, or passed to the logger method.

msg

The Object the user passed to the log message; not necessarily a String.

The block should return an Object that can be written to the logging device via write. The default formatter is used when no formatter is set.



168
169
170
# File 'lib/syslog/logger.rb', line 168

def formatter
  @formatter
end

#levelObject

Log level for Logger compatibility.



154
155
156
# File 'lib/syslog/logger.rb', line 154

def level
  @level
end

Class Method Details

.make_methods(meth) ⇒ Object

Builds a methods for level meth.



98
99
100
101
102
103
104
105
106
107
108
109
# File 'lib/syslog/logger.rb', line 98

def self.make_methods meth
  level = ::Logger.const_get(meth.upcase)
  eval <<-EOM, nil, __FILE__, __LINE__ + 1
    def #{meth}(message = nil, &block)
      add(#{level}, message, &block)
    end

    def #{meth}?
      @level <= #{level}
    end
  EOM
end

.syslogObject

Returns the internal Syslog object that is initialized when the first instance is created.



84
85
86
# File 'lib/syslog/logger.rb', line 84

def self.syslog
  @@syslog
end

.syslog=(syslog) ⇒ Object

Specifies the internal Syslog object to be used.



91
92
93
# File 'lib/syslog/logger.rb', line 91

def self.syslog= syslog
  @@syslog = syslog
end

Instance Method Details

#add(severity, message = nil, progname = nil, &block) ⇒ Object

Almost duplicates Logger#add. progname is ignored.



187
188
189
190
191
192
# File 'lib/syslog/logger.rb', line 187

def add severity, message = nil, progname = nil, &block
  severity ||= ::Logger::UNKNOWN
  @level <= severity and
    @@syslog.log LEVEL_MAP[severity], '%s', formatter.call(severity, Time.now, progname, (message || block.call))
  true
end

#severityObject

:method: debug

Logs a message at the debug (syslog debug) log level, or logs the message returned from the block.



147
148
149
# File 'lib/syslog/logger.rb', line 147

Logger::Severity::constants.each do |severity|
  make_methods severity.downcase
end