From 4faa7f927149a5c4ef7a03523f7bc14523cb9baa Mon Sep 17 00:00:00 2001 From: Stuart Mackie Date: Fri, 7 Oct 2016 12:24:58 -0700 Subject: Charms for Contrail 3.1 with Mitaka Change-Id: Id37f3b9743d1974e31fcd7cd9c54be41bb0c47fb Signed-off-by: Stuart Mackie --- charms/trusty/cassandra/hooks/loglog.py | 42 +++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 charms/trusty/cassandra/hooks/loglog.py (limited to 'charms/trusty/cassandra/hooks/loglog.py') diff --git a/charms/trusty/cassandra/hooks/loglog.py b/charms/trusty/cassandra/hooks/loglog.py new file mode 100644 index 0000000..33f3af8 --- /dev/null +++ b/charms/trusty/cassandra/hooks/loglog.py @@ -0,0 +1,42 @@ +# Copyright 2015 Canonical Ltd. +# +# This file is part of the Cassandra Charm for Juju. +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 3, as +# published by the Free Software Foundation. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranties of +# MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR +# PURPOSE. See the GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +import atexit +import subprocess +import threading +import time + +from charmhelpers.core import hookenv + + +def loglog(filename, prefix='', level=hookenv.DEBUG): + '''Mirror an arbitrary log file to the Juju hook log in the background.''' + tailproc = subprocess.Popen(['tail', '-F', filename], + stdout=subprocess.PIPE, + universal_newlines=True) + atexit.register(tailproc.terminate) + + def loglog_t(tailproc=tailproc): + while True: + line = tailproc.stdout.readline() + if line: + hookenv.log('{}{}'.format(prefix, line), level) + else: + time.sleep(0.1) + continue + + t = threading.Thread(target=loglog_t, daemon=True) + t.start() -- cgit 1.2.3-korg