[Kimchi-devel] [PATCH] [Kimchi 2/4] Improve log messages printed by the serial console

Aline Manera alinefm at linux.vnet.ibm.com
Fri Mar 11 13:45:26 UTC 2016


Reviewed-by: Aline Manera <alinefm at linux.vnet.ibm.com>

On 03/09/2016 04:04 PM, Jose Ricardo Ziviani wrote:
>   - Include the process name in the log to highlight messages from
>     different process and thus make is easier to debug.
>
> Signed-off-by: Jose Ricardo Ziviani <joserz at linux.vnet.ibm.com>
> ---
>   serialconsole.py | 56 ++++++++++++++++++++++++++------------------------------
>   1 file changed, 26 insertions(+), 30 deletions(-)
>
> diff --git a/serialconsole.py b/serialconsole.py
> index 47f4c2d..74f6b8a 100644
> --- a/serialconsole.py
> +++ b/serialconsole.py
> @@ -27,9 +27,8 @@ import time
>
>   from multiprocessing import Process
>
> -
> -from wok.utils import wok_log
>   from wok.plugins.kimchi import model
> +from wok.utils import wok_log
>
>
>   SOCKET_QUEUE_BACKLOG = 0
> @@ -70,8 +69,6 @@ class SocketServer(Process):
>           self._uri = URI
>           self._server_addr = os.path.join(BASE_DIRECTORY, guest_name)
>           if os.path.exists(self._server_addr):
> -            wok_log.error('Cannot connect to %s due to an existing '
> -                          'connection', guest_name)
>               raise RuntimeError('There is an existing connection to %s' %
>                                  guest_name)
>
> @@ -82,7 +79,8 @@ class SocketServer(Process):
>                                   1)
>           self._socket.bind(self._server_addr)
>           self._socket.listen(SOCKET_QUEUE_BACKLOG)
> -        wok_log.info('socket server to guest %s created', guest_name)
> +        wok_log.info('[%s] socket server to guest %s created', self.name,
> +                     guest_name)
>
>       def run(self):
>           """Implements customized run method from Process.
> @@ -98,7 +96,8 @@ class SocketServer(Process):
>               data = stream.recv(1024)
>
>           except Exception as e:
> -            wok_log.info('Error when reading from console: %s', e.message)
> +            wok_log.info('[%s] Error when reading from console: %s',
> +                         self.name, e.message)
>               return
>
>           # return if no data received or client socket(opaque) is not valid
> @@ -125,11 +124,11 @@ class SocketServer(Process):
>           """
>           libvirt.virEventRegisterDefaultImpl()
>           try:
> -            guest = LibvirtGuest(self._guest_name, self._uri)
> +            guest = LibvirtGuest(self._guest_name, self._uri, self.name)
>
>           except Exception as e:
> -            wok_log.error('Cannot open the guest %s due to %s',
> -                          self._guest_name, e.message)
> +            wok_log.error('[%s] Cannot open the guest %s due to %s',
> +                          self.name, self._guest_name, e.message)
>               self._socket.close()
>               sys.exit(1)
>
> @@ -147,8 +146,8 @@ class SocketServer(Process):
>               pass
>
>           finally:
> -            wok_log.info("Shutting down the socket server to %s console",
> -                         self._guest_name)
> +            wok_log.info("[%s] Shutting down the socket server to %s console",
> +                         self.name, self._guest_name)
>               self._socket.close()
>               if os.path.exists(self._server_addr):
>                   os.unlink(self._server_addr)
> @@ -157,7 +156,8 @@ class SocketServer(Process):
>                   console.eventRemoveCallback()
>
>               except Exception as e:
> -                wok_log.info('Callback is probably removed: %s', e.message)
> +                wok_log.info('[%s] Callback is probably removed: %s',
> +                             self.name, e.message)
>
>               guest.close()
>
> @@ -171,8 +171,7 @@ class SocketServer(Process):
>           """
>           client, client_addr = self._socket.accept()
>           client.settimeout(DEFAULT_TIMEOUT)
> -        wok_log.info('Client %s connected to %s',
> -                     str(client_addr),
> +        wok_log.info('[%s] Client connected to %s', self.name,
>                        self._guest_name)
>
>           # register the callback to receive any data from the console
> @@ -191,9 +190,8 @@ class SocketServer(Process):
>                   data = client.recv(1024)
>
>               except Exception as e:
> -                wok_log.info('Client %s disconnected from %s: %s',
> -                             str(client_addr),
> -                             self._guest_name,
> +                wok_log.info('[%s] Client %s disconnected from %s: %s',
> +                             self.name, str(client_addr), self._guest_name,
>                                e.message)
>                   break
>
> @@ -206,8 +204,8 @@ class SocketServer(Process):
>                   console.send(data)
>
>               except:
> -                wok_log.info('Console of %s is not accessible',
> -                             self._guest_name)
> +                wok_log.info('[%s] Console of %s is not accessible',
> +                             self.name, self._guest_name)
>                   break
>
>           # clear used resources when the connection is closed and, if possible,
> @@ -222,26 +220,25 @@ class SocketServer(Process):
>
>   class LibvirtGuest(object):
>
> -    def __init__(self, guest_name, uri):
> +    def __init__(self, guest_name, uri, process_name):
>           """
>           Constructs a guest object that opens a connection to libvirt and
>           searchs for a particular guest, provided by the caller.
>           """
> +        self._proc_name = process_name
>           try:
>               libvirt = model.libvirtconnection.LibvirtConnection(uri)
>               self._guest = model.vms.VMModel.get_vm(guest_name, libvirt)
>
>           except Exception as e:
> -            wok_log.error('Cannot open guest %s: %s', guest_name, e.message)
> +            wok_log.error('[%s] Cannot open guest %s: %s', self._proc_name,
> +                          guest_name, e.message)
>               raise
>
>           self._libvirt = libvirt.get()
>           self._name = guest_name
>           self._stream = None
>
> -    def get_name(self):
> -        return self._name
> -
>       def is_running(self):
>           """
>           Checks if this guest is currently in a running state.
> @@ -258,8 +255,8 @@ class LibvirtGuest(object):
>           # guest must be in a running state to get its console
>           counter = 10
>           while not self.is_running():
> -            wok_log.info('Guest %s is not running, waiting for it',
> -                         self._name)
> +            wok_log.info('[%s] Guest %s is not running, waiting for it',
> +                         self._proc_name, self._name)
>
>               counter -= 1
>               if counter <= 0:
> @@ -269,8 +266,8 @@ class LibvirtGuest(object):
>
>           # attach a stream in the guest console so we can read from/write to it
>           if self._stream is None:
> -            wok_log.info('Opening the console for guest %s',
> -                         self._name)
> +            wok_log.info('[%s] Opening the console for guest %s',
> +                         self._proc_name, self._name)
>               self._stream = self._libvirt.newStream(libvirt.VIR_STREAM_NONBLOCK)
>               self._guest.openConsole(None,
>                                       self._stream,
> @@ -295,8 +292,7 @@ def main(guest_name, URI):
>           server = SocketServer(guest_name, URI='qemu:///system')
>
>       except Exception as e:
> -        wok_log.error('Cannot create the socket server for %s due to %s',
> -                      guest_name, e.message)
> +        wok_log.error('Cannot create the socket server: %s', e.message)
>           raise
>
>       server.start()




More information about the Kimchi-devel mailing list