Big bunch of improvements for the caching daemon. kb/rrdd
authorKevin Brintnall <kbrint@rufus.net>
Sun, 14 Sep 2008 07:26:58 +0000 (09:26 +0200)
committerFlorian Forster <octo@verplant.org>
Sun, 14 Sep 2008 07:26:58 +0000 (09:26 +0200)
commit8c142e988f1341067034b01241d3b2683dd1f497
treecfa9081a50491236cb3ba57043a93426f365051d
parent8fdbf4660969f9bde7f0f434f2d1002028d36814
Big bunch of improvements for the caching daemon.

Tobi et al.,

I have made some enhancements to Florian's rrdcached patch.  This patch
(against /trunk) can be found at the following URL.  Testing has shown it
to be production ready.

http://dist.rufus.net/~kbrint/rrdcached/rrdcache.patch
http://dist.rufus.net/~kbrint/rrdcached/rrdcache.patch.asc

It applies cleanly to 1.3.2 as well (with obligatory automake;autoconf).

The enhancements over Florian's version are in the postscript.

--
 kevin brintnall =~ /kbrint@rufus.net/

=================================================================

fixed: removed extra compiler pragmas that caused portability problems

added: more server logging (startup, shutdown, ...)

added: client maintains a cached connection across multiple commands.
  correctly handles a long-running process where some commands are specified
  with --daemon and others are specified without

fixed: consolidated duplicate code for finding daemon addr (from --daemon
  or environment).

fixed: update with --template and daemon specified by environment was not
  treated properly in rrd_update.c:rrd_update(line ~442)

fixed: memory leak with ci->values not being freed

added: added -z to spread write load

fixed: check that file is writable before accepting UPDATE

fixed: queue_thread_main: avoid tight-spin when we're scheduling the next
  flush.  old code called flush_old_values(-1) once per update for up to a
  full second. ("<" vs "<=" comparison)

added: journal support with recovery

fixed: signal handlers wake up queue_thread for timely shutdown

fixed: refuse to start if pid file present at startup

added: more stats

fixed: "flush file" should not error if file exists on the file system,
  but not in update cache.  the file may have been flushed due to
  inactivity, or the daemon may have just started up.  if the file exists,
  return success.  still fails if files does not exist at all on disk.

fixed: ENODATA is not portable
16 files changed:
doc/rrdcached.pod
src/librrd.sym.in
src/rrd_client.c
src/rrd_client.h
src/rrd_daemon.c
src/rrd_dump.c
src/rrd_fetch.c
src/rrd_flush.c
src/rrd_graph.c
src/rrd_graph.h
src/rrd_info.c
src/rrd_last.c
src/rrd_lastupdate.c
src/rrd_tool.h
src/rrd_update.c
src/rrd_xport.c