sysklogd/ChangeLog.md
Joachim Nilsson ad686ca86d Update ChangeLog and bump version for v2.0.3 release
Signed-off-by: Joachim Nilsson <troglobit@gmail.com>
2019-12-01 21:40:20 +01:00

12 KiB
Raw Blame History

Change Log

All relevant changes to the project are documented in this file.

v2.0.3 - 2019-12-01

Changes

  • Always run domark() timer, regardless of -m interval setting, it is used for internal housekeeping, runs every 15 sec
  • Handle DNS lookup of unknown remote syslog hosts in domark()
  • Only enable debug mode when -d is given on the command line
  • Always create PID file, even in debug mode
  • Add -F, as alias for -n, to klogd for compat. with syslogd

Fixes

  • When logging to a remote host using @FQDN previous releases of syslogd gave up after 10 tries. In many industrial cases intermittent access to the DNS is very likely, so this release includes a fix to retry the IP address lookup forever. The interval for retries is configurable
  • Fix accidental blocking of SIGHUP/SIGALRM when an invalid facility is found in the internal logmsg() function
  • Fix leaking of internal error messages (like DNS lookup failure) to /dev/console during reconfiguration, i.e. after initial start

v2.0.2 - 2019-11-28

Changes

  • Add missing remote:port info in error message when failing to send to a remote syslog server.

Fixes

  • Fix assert() in fprintlog_successive(), caused by never being reset in fprintlog_first(), found by Westermo
  • Issue #6: Workaround for systems with vanilla autoconf 2.69 that does not support --runstatedir=PATH, e.g. CRUX https://crux.nu/

v2.0.1 - 2019-11-25

Minor bug fix release.

Changes

  • Make logger tool and man page optional in build, by Lars Wendler
  • Expand resulting directories in configure summary

Fixes

  • Add missing -k and -T command line flags to getopt()
  • Issue #3: Don't guess PID file location, use configre's $runstatedir

v2.0 - 2019-11-15

This release represents a major refresh of the sysklogd project. The venerable syslogd gets an infusion of new blood from NetBSD and FreeBSD to fully support RFC3164 and RFC5424. Also included is a user library and a replacement for syslog.h to enable new features in RFC5424.

Note: as of this release klogd is disabled by default, syslogd can read Linux kernel messages on its own now.

Changes

  • Support for true RFC3164 formatted log messages to remote log servers, including timestamp and hostname. Use ;RFC3161 rule option
  • Support for RFC5424 from UNIX domain socket, from remote servers and also to remote servers. Requires new API syslogp() to unlock these features on the UNIX socket. Still compatible with GLIBC/musl/uClibc
  • Support for options to syslog.conf rules. E.g. ;RFC5424 to enable sending/writing log messages with RFC3339 style timestamps, and more
  • Support for include /etc/syslog.d/*.conf in syslog.conf
  • New tool logger from the Finit project, BSD licensed. Supports all the features of RFC5424, so very useful for trying out the "new" standard
  • Support for reading from a custom UNIX domain socket path, -p SOCK, for unit testing with logger -u /path/to/sock
  • Support for sending to a custom port on a remote server, @host:port
  • New syslogp() API from NetBSD, for applications wanting to use RFC5424 features like MsgID or structured data
  • Many incompatible changes to command line options in syslogd and klogd for compatiblity with FreeBSD and NetBSD syslogd. Examples:
    • In syslogd: -b and -c have been replaced with -r for global log rotation, -a has been replaced with the new -p support. The -r flag and -s HOST has also been dropped in favor of the BSD -s flag to control two levels of secure mode. The -n flag is now -F and -n means something else entirely ... there's more
    • In klogd: -i and -I have been removed
  • klogd is not built by default anymore, syslogd can read /proc/kmsg on Linux on its own. Reduces complexity and gives you one daemon less
  • When systemd support is detected by the configure script the unit file(s) are now installed into the systemd system services folder
  • Update COPYING file to GPL 2 rev 2, with new FSF address and other minor stuff
  • Update license header in all files:
    • Sync 3-clause BSD license change with upstream NetBSD and FreeBSD sources
    • Sync GPL license header, new FSF address
    • Add SPDX license identifiers to all source files

Fixes

  • Fix GCC 8 warnings; "too small destination buffer in snprintf()"
  • Major code cleanup and rewrite inspired by both NetBSD and FreeBSD sources, e.g. removed all previous unit TESTING #ifdefs

v1.6 - 2018-09-25

Changes

  • IPv6 support forward ported from FreeBSD, by John Haxby john.haxby@oracle.com
  • Built-in log rotation support from BusyBox syslogd, disabled by default
    • Enable from command line using '-b SIZE' and '-c COUNT', or
    • Per log file in syslog.conf using 'SIZE:COUNT'
  • Automatic compression (gzip) of rotated files from .1
  • Only read /etc/services when needed, by Martin Schulze joey@infodrom.org
  • Improved sleep/alarm/mark implementation,
    by Alan Jenkins alan-jenkins@tuffmail.co.uk
  • Move hostname setting code from main() into init() so it is re-read on SIGHUP, by Thomas Jarosch thomas.jarosch@intra2net.com
  • Documentation update by Martin Schulze joey@infodrom.org
  • Re-indent code to Linux KNF
  • Touch PID file on SIGHUP, for integration with Finit
  • Add systemd unit files
  • Add GNU configure & build system
    • Add configure flags to enable features and control behavior
    • Detect systemd PATHs

Fixes

  • Flush log files independent of MARK, by Martin Schulze joey@infodrom.org
  • Fix segfault, remove faulty fclose(), found by Andrea Morandi and Sean Young. Fixed by Martin Schulze joey@infodrom.org
  • Correct continuation line problems on 64bit architecture,
    by David Couture glowplugrelayw0rks@gmail.com
  • Bugfix against invalid PRI values (CVE-2014-3634), by mancha mancha1@zoho.com
  • Ignore backed up (low baud rate) console, and do not close it. Instead, continue writing when its unclogged
  • Increase socket receive buffer size (double), patch from FreeBSD

v1.5.1 - 2014-10-06

Fixes

v1.5 - 2007-07-27

  • Dmitry V. Levin ldv@altlinux.org
    • Close file descriptor in FindSymbolFile() in ksym.c in order not to leak file descriptors.
  • Solar Designer solar@openwall.com
    • improve crunch_list()
    • Prevent potential buffer overflow in reading messages from the kernel log ringbuffer.
    • Ensure that "len" is not placed in a register, and that the endtty() signal handler is not installed too early which could cause a segmentation fault or worse.
  • Steve Grubb linux_4ever@yahoo.com
    • fix memory calculation in crunch_list()
  • Martin Schulze joey@infodrom.org
    • klogd will reconnect to the logger (mostly syslogd) after it went away
    • On heavily loaded system syslog will not spit out error messages anymore when recvfrom() results in EAGAIN
    • Makefile improvements
    • Local copy of module.h
    • Improved sysklogd.8
    • Always log with syslogd's timezone and locale
    • Remove trailing newline when forwarding messages
    • Continue working properly if /etc/service is missing and ignore network activity
    • Continue writing to log files as soon as space becomes available again after a filled up disk
    • Removed test to detect control characters > 0x20 as this prevented characters encoded in UTF-8 to be properly passed through
    • Only resolve the local domain when accepting messages from remote
    • Properly accompany the MARK message with the facility
    • Improved daemonise routine in klogd to stabilise startup
    • klogd will not change the console log level anymore unless -c is given
    • Added back /usr/src/linux/System.map as fall-back location
    • Rewrote the module symbol parser to read from /proc/kallsyms
    • Notify the waiting parent process if the client dies so it doesn't wait the entire five minutes.
    • Complete rewrite of the oops kernel module for Linux 2.6
    • Only read kernel symbols from /proc/kallsyms if no System.map has been read
    • Improved symbol lookup
    • Prevent named pipes from becoming the controlling tty
  • Jon Burgess Jon_Burgess@eur.3com.com
    • Moved the installation of the signal handler up a little bit so it guaranteed to be available when the child is forked, hence, fixing a race condition. This used to create problems with UML and fast machines.
  • Greg Trounson gregt@maths.otago.ac.nz
    • Improved README.linux
  • Ulf H<>rnhammar Ulf.Harnhammar.9485@student.uu.se
    • Boundary check for fscanf() in InitKsyms() and CheckMapVersion()
  • Colin Phipps cph@cph.demon.co.uk
    • Don't block on the network socket in case of packet loss
  • Dirk Mueller mueller@kde.org
    • Don't crash when filesize limit is reached (e.g. without LFS)
  • Miquel van Smoorenburg miquels@cistron.nl
    • Fix spurious hanging syslogd in connection with futex and NPTL introduced in recent glibc versions and Linux 2.6 (Details: http://bugs.debian.org/301511)
  • Eric Tucker et@tallmaple.com
    • Improved syslog.conf(5) manpage
  • Mike Frysinger vapier@gentoo.org
    • use socklen_t where appropriate
  • Kelledin kelledin@skarpsey.dyndns.org
    • use newer query_module function rather than stepping through /dev/kmem.
  • Matthew Fischer futhark@vzavenue.net
    • Remove special treatment of the percent sign in klogd

[v1.4.1][] - 2001-03-11

  • klogd will set the console log level only if -c' is given on the commandline, not overwriting local settings in /etc/sysctl.conf'.
  • Bugfix: klogd will use SOCK_DGRM as well, re-enables kernel logging
  • Bugfix: Don't make syslogd fail with broken `-a'
  • Bugfix: klogd will skip zero bytes and not enter a busy loop anymore
  • Thomas Roessler roessler@does-not-exist.org
    • Patch to prevent LogLine() from being invoked with a negative counter as an argument.

v1.4 - 2000-09-19

  • Skip newline when reading in klog messages
  • Use lseek64() instead of llseek() which is deprecated these days
  • Close symbol file before returning with 0 when an error occurred while reading it. This will enable systems to umount that partition with no open file descriptor left over.
  • Solar Designer solar@false.com
    • printline() fixes
    • priority decoding fix
  • Daniel Jacobowitz dan@debian.org
    • printchopped() fix
  • Keith Owens kaos@ocs.com.au
    • Fixed bug that caused klogd to die if there is no sym_array available.
    • When symbols are expanded, print the line twice. Once with addresses converted to symbols, once with the raw text. Allows external programs such as ksymoops do their own processing on the original data.
  • Olaf Kirch okir@caldera.de
    • Remove Unix Domain Sockets and switch to Datagram Unix Sockets
  • Several bugfixes and improvements, please refer to the .c files