Syslog
From HerzbubeWiki
Overview
This page has information about the System Logging Daemon (syslogd) and the syslog service it provides. At the moment I use rsyslog because this has become the default since Debian "lenny". 
Syslog Daemon packages
When I started using Debian, the standard syslogd package on Debian was sysklogd. This provides an advanced version of the standard Berkeley utility program. Its rules allow to redirect log messages based on the terms "facility" and "priority", which are both concepts originating in C preprocessor macros defined in the POSIX standard system header 
/usr/include/syslog.h
sysklogd is therefore limited in its capabilities to values preconceived by those who designed the POSIX standard. This has long been sufficient for me, but at a certain point I was interested in getting more fine-grained levels of control, especially when I enabled my ADSL router and Wi-Fi access point to forward their log messages to my Linux server. 
A few noteworthy alternatives to sysklogd are: 
- dsyslog: More modular and expandable than the regular package
- syslog-ng: Improved configurability, also filtering based on message content
- rsyslog: Enterprise-class, may write to databases (e.g. MySQL), may be used to form relay chains over TCP and SSL/TLS
I eventually decided to start to use rsyslog as a replacement for sysklogd, mainly because this has become the standard syslogd on Debian since the release of Debian 5.0 (lenny). There are a variety of reasons why Debian has gone for rsyslog; some of them can be read up on this wiki page (e.g. sysklogd has become pretty much unmaintained over the years), but the main reason why not to go for syslog-ng is that this project is dual-licensed, i.e. not entirely GPL. Finally, read this blog article by the author of rsyslog for his (IMHO sound) reasons for creating yet another syslog solution... 
sysklogd
References
man sysklogd man syslog.conf
Remote logging
If external sources (e.g. ADSL router, Wi-Fi access point) should be able to log messages over the network, the syslog daemon needs to be run with the special option -r. This can be configured in the following file:
osgiliath:/etc/init.d# cat /etc/default/syslogd SYSLOGD="-r"
When started with the -r option, sysklogd listens on UDP port 514. 
Configuration
The configuration file is this
/etc/syslog.conf
If something in the configuration file has changed, the daemon can be notified so that it re-reads the file, in the same way as inetd</code: 
kill -SIGHUP $(cat /var/run/syslogd.pid)
The configuration file consists of rules that specify what is logged where. Each rule consists of two fields: 
- The selector field (defining which messages are logged) 
- The action field (defining where messages are sent, often the path to a file) 
The selector field itself again consists of two parts, which are separated by a period ("."): 
- The facility (specifying the subsystem that produced the message) 
- The priority (defining the severity of the message) 
Both facility and priority names correspond to the similar <code>LOG_ values in 
/usr/include/syslog.h
An asterisk ("*") stands for "all" facilities or priorities.
rsyslog
Upgrade from sysklogd
The rsyslog package description says that "it is quite compatible to stock sysklogd and can be used as a drop-in replacement." Since I have not made any customizations to /etc/syslog.conf, the upgrade was very simple: 
- Install rsyslogpackage
- This automatically causes sysklogdto be removed
- klogdis also automatically removed because its status of "automatically installed" due to a- sysklogddependency
- sysklogdand- klogdsimply need to be purged to remain all configuration file traces
- Finally, mark rsyslogas automatically installed
References
- man rsyslogd
- man rsyslog.conf
- /usr/share/doc/rsyslog-doc (if the rsyslog-docpackage is installed)
- Filter conditions: http://www.rsyslog.com/doc-rsyslog_conf_filter.html
- Available properties: http://www.rsyslog.com/doc-property_replacer.html
- Actions: http://www.rsyslog.com/doc-rsyslog_conf_actions.html
Configuration
The main configuration file is
/etc/rsyslog.conf
The configuration can be extended by dropping files in
/etc/rsyslog.d
If something in the configuration files has changed, the daemon can be notified so that it re-reads the files, in the same way as inetd</code: 
kill -SIGHUP $(cat /var/run/rsyslogd.pid)
For easy maintenance, I create the following file with all my local modifications 
/etc/rsyslog.d/osgiliath.conf
Note that the file must have the <code>.conf extension to be recognized. 
Remote logging
If external sources (e.g. ADSL router, Wi-Fi access point) should be able to log messages over the network, the following configuration snippet needs to be placed into /etc/rsyslog.d/osgiliath.conf: 
# Provides UDP syslog reception $ModLoad imudp $UDPServerRun 514
rsyslogd now listens on UDP port 514. 
Place messages in separate files depending on the sender's hostname
First create a directory that will receive the log files:
mkdir /var/log/remote
Then place the following configuration snippet into /etc/rsyslog.d/osgiliath.conf: 
# Template for hostname-based log files $template RemoteHostLogfile,"/var/log/remote/system-%HOSTNAME%.log" # Template for service name-based log files $template ServiceLogfile,"/var/log/%programname%/%programname%.log" # Route messages from defined remote hosts into log files based on # the name of the remote host. The parts of this rule are: # - ":" indicates that this is a property-based filter (traditionally # the filter would be a severity/facility based selector) # - "hostname" names the property whose value should be examined # - "," a simple separator # - "ereregex" indicates the compare-operation, in this case that the # property value should be compared against an extended regular # expression (another compare-operation is "isequal") # - "," a simple separator # - "(host1|host2|...)" the regular expression to compare against # - "?" indicates that the action is a dynamic filename (as opposed # to static files that must be specified starting with a "/") # - "RemoteHostLogfile" is the name of the template that must be # evaluated to get the actual filename # - "&" on a new line indicates that for the same filter rule there # is another action coming up # - "~" is the "discard" action, i.e. the message is not processed # any further :hostname, ereregex, "(landroval|alcarondas)" ?RemoteHostLogfile & ~ # Route messages from defined services into log files based on # the name of the service. See above for a detailed discussion of # the parts of this rule. :programname, ereregex, "(named|dhcpd|hddtemp|collectd)" ?ServiceLogfile & ~
Add the following block to /etc/logrotate/osgiliath.conf: 
/var/log/remote/*.log {
  size 1000k
  missingok
  rotate 10
  compress
  nocreate
  postrotate
    invoke-rc.d rsyslog reload > /dev/null
  endscript
}
/var/log/named/*.log 
/var/log/dhcpd/*.log
/var/log/hddtemp/*.log
/var/log/collectd/*.log {
  size 1000k
  missingok
  rotate 10
  compress
  nocreate
  postrotate
    invoke-rc.d rsyslog reload > /dev/null
  endscript
}
Log rotation
Rotation of default log files such as /var/log/syslog is triggered by 
/etc/logrotate.d/rsyslog
 
                    
                     
                    
                 
                    
                 

 
         
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号