2015-07-17 15:40:26 +00:00
<!DOCTYPE html>
<!-- [if IE 8]><html class="no - js lt - ie9" lang="en" > <![endif] -->
<!-- [if gt IE 8]><! --> < html class = "no-js" lang = "en" > <!-- <![endif] -->
< head >
< meta charset = "utf-8" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
2015-12-04 18:16:16 +00:00
< title > pylorax.monitor — Lorax 24.6 documentation< / title >
2015-07-17 15:40:26 +00:00
< link rel = "stylesheet" href = "../../_static/css/theme.css" type = "text/css" / >
2015-12-04 18:16:16 +00:00
< link rel = "top" title = "Lorax 24.6 documentation" href = "../../index.html" / >
2015-07-17 15:40:26 +00:00
< link rel = "up" title = "pylorax" href = "../pylorax.html" / >
< script src = "_static/js/modernizr.min.js" > < / script >
< / head >
< body class = "wy-body-for-nav" role = "document" >
< div class = "wy-grid-for-nav" >
< nav data-toggle = "wy-nav-shift" class = "wy-nav-side" >
< div class = "wy-side-nav-search" >
< a href = "../../index.html" class = "icon icon-home" > Lorax
< / a >
< div role = "search" >
< form id = "rtd-search-form" class = "wy-form" action = "../../search.html" method = "get" >
< input type = "text" name = "q" placeholder = "Search docs" / >
< input type = "hidden" name = "check_keywords" value = "yes" / >
< input type = "hidden" name = "area" value = "default" / >
< / form >
< / div >
< / div >
< div class = "wy-menu wy-menu-vertical" data-spy = "affix" role = "navigation" aria-label = "main navigation" >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../intro.html" > Introduction to Lorax< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../intro.html#before-lorax" > Before Lorax< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../lorax.html" > lorax< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../livemedia-creator.html" > livemedia-creator< / a > < ul >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#quickstart" > Quickstart< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#how-iso-creation-works" > How ISO creation works< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#kickstarts" > Kickstarts< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#anaconda-image-install-no-virt" > Anaconda image install (no-virt)< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#ami-images" > AMI Images< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#appliance-creation" > Appliance Creation< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#filesystem-image-creation" > Filesystem Image Creation< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#tar-file-creation" > TAR File Creation< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#live-image-for-pxe-boot" > Live Image for PXE Boot< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#atomic-live-image-for-pxe-boot" > Atomic Live Image for PXE Boot< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#using-mock-to-create-images" > Using Mock to Create Images< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#openstack-image-creation" > OpenStack Image Creation< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#docker-image-creation" > Docker Image Creation< / a > < / li >
2015-12-04 18:16:16 +00:00
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#open-container-initiative-image-creation" > Open Container Initiative Image Creation< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#vagrant-image-creation" > Vagrant Image Creation< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#creating-uefi-disk-images-with-virt" > Creating UEFI disk images with virt< / a > < / li >
2015-07-17 15:40:26 +00:00
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#debugging-problems" > Debugging problems< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../livemedia-creator.html#hacking" > Hacking< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../product-images.html" > Product and Updates Images< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../modules.html" > pylorax< / a > < ul >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../pylorax.html" > pylorax package< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#submodules" > Submodules< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.base" > pylorax.base module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.buildstamp" > pylorax.buildstamp module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.decorators" > pylorax.decorators module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.discinfo" > pylorax.discinfo module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.dnfhelper" > pylorax.dnfhelper module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.executils" > pylorax.executils module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.imgutils" > pylorax.imgutils module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.ltmpl" > pylorax.ltmpl module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.monitor" > pylorax.monitor module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.mount" > pylorax.mount module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.output" > pylorax.output module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.sysutils" > pylorax.sysutils module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.treebuilder" > pylorax.treebuilder module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax.treeinfo" > pylorax.treeinfo module< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../../pylorax.html#module-pylorax" > Module contents< / a > < / li >
< / ul >
< / li >
< / ul >
< / li >
< / ul >
< / div >
< / nav >
< section data-toggle = "wy-nav-shift" class = "wy-nav-content-wrap" >
< nav class = "wy-nav-top" role = "navigation" aria-label = "top navigation" >
< i data-toggle = "wy-nav-top" class = "fa fa-bars" > < / i >
< a href = "../../index.html" > Lorax< / a >
< / nav >
< div class = "wy-nav-content" >
< div class = "rst-content" >
< div role = "navigation" aria-label = "breadcrumbs navigation" >
< ul class = "wy-breadcrumbs" >
< li > < a href = "../../index.html" > Docs< / a > » < / li >
< li > < a href = "../index.html" > Module code< / a > » < / li >
< li > < a href = "../pylorax.html" > pylorax< / a > » < / li >
< li > pylorax.monitor< / li >
< li class = "wy-breadcrumbs-aside" >
< / li >
< / ul >
< hr / >
< / div >
< div role = "main" class = "document" >
< h1 > Source code for pylorax.monitor< / h1 > < div class = "highlight" > < pre >
< span class = "c" > # monitor.py< / span >
< span class = "c" > #< / span >
< span class = "c" > # Copyright (C) 2011-2015 Red Hat, Inc.< / span >
< span class = "c" > #< / span >
< span class = "c" > # This program is free software; you can redistribute it and/or modify< / span >
< span class = "c" > # it under the terms of the GNU General Public License as published by< / span >
< span class = "c" > # the Free Software Foundation; either version 2 of the License, or< / span >
< span class = "c" > # (at your option) any later version.< / span >
< span class = "c" > #< / span >
< span class = "c" > # This program is distributed in the hope that it will be useful,< / span >
< span class = "c" > # but WITHOUT ANY WARRANTY; without even the implied warranty of< / span >
< span class = "c" > # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the< / span >
< span class = "c" > # GNU General Public License for more details.< / span >
< span class = "c" > #< / span >
< span class = "c" > # You should have received a copy of the GNU General Public License< / span >
< span class = "c" > # along with this program. If not, see < http://www.gnu.org/licenses/> .< / span >
< span class = "c" > #< / span >
< span class = "c" > # Author(s): Brian C. Lane < bcl@redhat.com> < / span >
< span class = "c" > #< / span >
< span class = "kn" > import< / span > < span class = "nn" > logging< / span >
< span class = "n" > log< / span > < span class = "o" > =< / span > < span class = "n" > logging< / span > < span class = "o" > .< / span > < span class = "n" > getLogger< / span > < span class = "p" > (< / span > < span class = "s" > " livemedia-creator" < / span > < span class = "p" > )< / span >
< span class = "kn" > import< / span > < span class = "nn" > re< / span >
< span class = "kn" > import< / span > < span class = "nn" > socket< / span >
< span class = "kn" > import< / span > < span class = "nn" > socketserver< / span >
< span class = "kn" > import< / span > < span class = "nn" > threading< / span >
< span class = "kn" > import< / span > < span class = "nn" > time< / span >
< div class = "viewcode-block" id = "LogRequestHandler" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogRequestHandler" > [docs]< / a > < span class = "k" > class< / span > < span class = "nc" > LogRequestHandler< / span > < span class = "p" > (< / span > < span class = "n" > socketserver< / span > < span class = "o" > .< / span > < span class = "n" > BaseRequestHandler< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Handle monitoring and saving the logfiles from the virtual install< / span >
< span class = "sd" > Incoming data is written to self.server.log_path and each line is checked< / span >
< span class = "sd" > for patterns that would indicate that the installation failed.< / span >
< span class = "sd" > self.server.log_error is set True when this happens.< / span >
< span class = "sd" > " " " < / span >
< div class = "viewcode-block" id = "LogRequestHandler.setup" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogRequestHandler.setup" > [docs]< / a > < span class = "k" > def< / span > < span class = "nf" > setup< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " Start writing to self.server.log_path" " " < / span >
< span class = "k" > if< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > log_path< / span > < span class = "p" > :< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > fp< / span > < span class = "o" > =< / span > < span class = "nb" > open< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > log_path< / span > < span class = "p" > ,< / span > < span class = "s" > " w" < / span > < span class = "p" > )< / span > < span class = "c" > # pylint: disable=attribute-defined-outside-init< / span >
< span class = "k" > else< / span > < span class = "p" > :< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > fp< / span > < span class = "o" > =< / span > < span class = "bp" > None< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > request< / span > < span class = "o" > .< / span > < span class = "n" > settimeout< / span > < span class = "p" > (< / span > < span class = "mi" > 10< / span > < span class = "p" > )< / span >
< / div >
< div class = "viewcode-block" id = "LogRequestHandler.handle" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogRequestHandler.handle" > [docs]< / a > < span class = "k" > def< / span > < span class = "nf" > handle< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Write incoming data to a logfile and check for errors< / span >
< span class = "sd" > Split incoming data into lines and check for any Tracebacks or other< / span >
< span class = "sd" > errors that indicate that the install failed.< / span >
< span class = "sd" > Loops until self.server.kill is True< / span >
< span class = "sd" > " " " < / span >
< span class = "n" > log< / span > < span class = "o" > .< / span > < span class = "n" > info< / span > < span class = "p" > (< / span > < span class = "s" > " Processing logs from < / span > < span class = "si" > %s< / span > < span class = "s" > " < / span > < span class = "p" > ,< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > client_address< / span > < span class = "p" > )< / span >
< span class = "n" > line< / span > < span class = "o" > =< / span > < span class = "s" > " " < / span >
< span class = "k" > while< / span > < span class = "bp" > True< / span > < span class = "p" > :< / span >
< span class = "k" > if< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > kill< / span > < span class = "p" > :< / span >
< span class = "k" > break< / span >
< span class = "k" > try< / span > < span class = "p" > :< / span >
< span class = "n" > data< / span > < span class = "o" > =< / span > < span class = "nb" > str< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > request< / span > < span class = "o" > .< / span > < span class = "n" > recv< / span > < span class = "p" > (< / span > < span class = "mi" > 4096< / span > < span class = "p" > ),< / span > < span class = "s" > " utf8" < / span > < span class = "p" > )< / span >
< span class = "k" > if< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > fp< / span > < span class = "p" > :< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > fp< / span > < span class = "o" > .< / span > < span class = "n" > write< / span > < span class = "p" > (< / span > < span class = "n" > data< / span > < span class = "p" > )< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > fp< / span > < span class = "o" > .< / span > < span class = "n" > flush< / span > < span class = "p" > ()< / span >
< span class = "c" > # check the data for errors and set error flag< / span >
< span class = "c" > # need to assemble it into lines so we can test for the error< / span >
< span class = "c" > # string.< / span >
< span class = "k" > while< / span > < span class = "n" > data< / span > < span class = "p" > :< / span >
< span class = "n" > more< / span > < span class = "o" > =< / span > < span class = "n" > data< / span > < span class = "o" > .< / span > < span class = "n" > split< / span > < span class = "p" > (< / span > < span class = "s" > " < / span > < span class = "se" > \n< / span > < span class = "s" > " < / span > < span class = "p" > ,< / span > < span class = "mi" > 1< / span > < span class = "p" > )< / span >
< span class = "n" > line< / span > < span class = "o" > +=< / span > < span class = "n" > more< / span > < span class = "p" > [< / span > < span class = "mi" > 0< / span > < span class = "p" > ]< / span >
< span class = "k" > if< / span > < span class = "nb" > len< / span > < span class = "p" > (< / span > < span class = "n" > more< / span > < span class = "p" > )< / span > < span class = "o" > > < / span > < span class = "mi" > 1< / span > < span class = "p" > :< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > iserror< / span > < span class = "p" > (< / span > < span class = "n" > line< / span > < span class = "p" > )< / span >
< span class = "n" > line< / span > < span class = "o" > =< / span > < span class = "s" > " " < / span >
< span class = "n" > data< / span > < span class = "o" > =< / span > < span class = "n" > more< / span > < span class = "p" > [< / span > < span class = "mi" > 1< / span > < span class = "p" > ]< / span >
< span class = "k" > else< / span > < span class = "p" > :< / span >
< span class = "n" > data< / span > < span class = "o" > =< / span > < span class = "bp" > None< / span >
< span class = "k" > except< / span > < span class = "n" > socket< / span > < span class = "o" > .< / span > < span class = "n" > timeout< / span > < span class = "p" > :< / span >
< span class = "k" > pass< / span >
< span class = "k" > except< / span > < span class = "ne" > Exception< / span > < span class = "k" > as< / span > < span class = "n" > e< / span > < span class = "p" > :< / span > < span class = "c" > # pylint: disable=broad-except< / span >
< span class = "n" > log< / span > < span class = "o" > .< / span > < span class = "n" > info< / span > < span class = "p" > (< / span > < span class = "s" > " log processing killed by exception: < / span > < span class = "si" > %s< / span > < span class = "s" > " < / span > < span class = "p" > ,< / span > < span class = "n" > e< / span > < span class = "p" > )< / span >
< span class = "k" > break< / span >
< / div >
< div class = "viewcode-block" id = "LogRequestHandler.finish" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogRequestHandler.finish" > [docs]< / a > < span class = "k" > def< / span > < span class = "nf" > finish< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ):< / span >
< span class = "n" > log< / span > < span class = "o" > .< / span > < span class = "n" > info< / span > < span class = "p" > (< / span > < span class = "s" > " Shutting down log processing" < / span > < span class = "p" > )< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > request< / span > < span class = "o" > .< / span > < span class = "n" > close< / span > < span class = "p" > ()< / span >
< span class = "k" > if< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > fp< / span > < span class = "p" > :< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > fp< / span > < span class = "o" > .< / span > < span class = "n" > close< / span > < span class = "p" > ()< / span >
< / div >
< div class = "viewcode-block" id = "LogRequestHandler.iserror" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogRequestHandler.iserror" > [docs]< / a > < span class = "k" > def< / span > < span class = "nf" > iserror< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ,< / span > < span class = "n" > line< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Check a line to see if it contains an error indicating installation failure< / span >
< span class = "sd" > :param str line: log line to check for failure< / span >
< span class = "sd" > If the line contains IGNORED it will be skipped.< / span >
< span class = "sd" > " " " < / span >
< span class = "k" > if< / span > < span class = "s" > " IGNORED" < / span > < span class = "ow" > in< / span > < span class = "n" > line< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span >
< span class = "n" > simple_tests< / span > < span class = "o" > =< / span > < span class = "p" > [< / span > < span class = "s" > " Traceback (" < / span > < span class = "p" > ,< / span >
< span class = "s" > " Out of memory:" < / span > < span class = "p" > ,< / span >
< span class = "s" > " Call Trace:" < / span > < span class = "p" > ,< / span >
< span class = "s" > " insufficient disk space:" < / span > < span class = "p" > ,< / span >
< span class = "s" > " error populating transaction after" < / span > < span class = "p" > ,< / span >
< span class = "s" > " traceback script(s) have been run" < / span > < span class = "p" > ,< / span >
2015-10-07 18:28:08 +00:00
< span class = "s" > " crashed on signal" < / span > < span class = "p" > ,< / span >
2015-07-17 15:40:26 +00:00
< span class = "s" > " packaging: Missed: NoSuchPackage" < / span > < span class = "p" > ]< / span >
< span class = "n" > re_tests< / span > < span class = "o" > =< / span > < span class = "p" > [< / span > < span class = "s" > r" packaging: base repo .* not valid" < / span > < span class = "p" > ,< / span >
< span class = "s" > r" packaging: .* requires .*" < / span > < span class = "p" > ]< / span >
< span class = "k" > for< / span > < span class = "n" > t< / span > < span class = "ow" > in< / span > < span class = "n" > simple_tests< / span > < span class = "p" > :< / span >
< span class = "k" > if< / span > < span class = "n" > t< / span > < span class = "ow" > in< / span > < span class = "n" > line< / span > < span class = "p" > :< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > log_error< / span > < span class = "o" > =< / span > < span class = "bp" > True< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > error_line< / span > < span class = "o" > =< / span > < span class = "n" > line< / span >
< span class = "k" > return< / span >
< span class = "k" > for< / span > < span class = "n" > t< / span > < span class = "ow" > in< / span > < span class = "n" > re_tests< / span > < span class = "p" > :< / span >
< span class = "k" > if< / span > < span class = "n" > re< / span > < span class = "o" > .< / span > < span class = "n" > search< / span > < span class = "p" > (< / span > < span class = "n" > t< / span > < span class = "p" > ,< / span > < span class = "n" > line< / span > < span class = "p" > ):< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > log_error< / span > < span class = "o" > =< / span > < span class = "bp" > True< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > error_line< / span > < span class = "o" > =< / span > < span class = "n" > line< / span >
< span class = "k" > return< / span >
< / div > < / div >
< div class = "viewcode-block" id = "LogServer" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogServer" > [docs]< / a > < span class = "k" > class< / span > < span class = "nc" > LogServer< / span > < span class = "p" > (< / span > < span class = "n" > socketserver< / span > < span class = "o" > .< / span > < span class = "n" > TCPServer< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " A TCP Server that listens for log data" " " < / span >
< span class = "c" > # Number of seconds to wait for a connection after startup< / span >
< span class = "n" > timeout< / span > < span class = "o" > =< / span > < span class = "mi" > 60< / span >
< span class = "k" > def< / span > < span class = "nf" > __init__< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ,< / span > < span class = "n" > log_path< / span > < span class = "p" > ,< / span > < span class = "o" > *< / span > < span class = "n" > args< / span > < span class = "p" > ,< / span > < span class = "o" > **< / span > < span class = "n" > kwargs< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Setup the log server< / span >
< span class = "sd" > :param str log_path: Path to the log file to write< / span >
< span class = "sd" > " " " < / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > kill< / span > < span class = "o" > =< / span > < span class = "bp" > False< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > log_error< / span > < span class = "o" > =< / span > < span class = "bp" > False< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > error_line< / span > < span class = "o" > =< / span > < span class = "s" > " " < / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > log_path< / span > < span class = "o" > =< / span > < span class = "n" > log_path< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > _timeout< / span > < span class = "o" > =< / span > < span class = "n" > kwargs< / span > < span class = "o" > .< / span > < span class = "n" > pop< / span > < span class = "p" > (< / span > < span class = "s" > " timeout" < / span > < span class = "p" > ,< / span > < span class = "bp" > None< / span > < span class = "p" > )< / span >
< span class = "k" > if< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > _timeout< / span > < span class = "p" > :< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > _start_time< / span > < span class = "o" > =< / span > < span class = "n" > time< / span > < span class = "o" > .< / span > < span class = "n" > time< / span > < span class = "p" > ()< / span >
< span class = "n" > socketserver< / span > < span class = "o" > .< / span > < span class = "n" > TCPServer< / span > < span class = "o" > .< / span > < span class = "n" > __init__< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ,< / span > < span class = "o" > *< / span > < span class = "n" > args< / span > < span class = "p" > ,< / span > < span class = "o" > **< / span > < span class = "n" > kwargs< / span > < span class = "p" > )< / span >
< div class = "viewcode-block" id = "LogServer.log_check" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogServer.log_check" > [docs]< / a > < span class = "k" > def< / span > < span class = "nf" > log_check< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Check to see if an error has been found in the log< / span >
< span class = "sd" > :returns: True if there has been an error< / span >
< span class = "sd" > :rtype: bool< / span >
< span class = "sd" > " " " < / span >
< span class = "k" > if< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > _timeout< / span > < span class = "p" > :< / span >
< span class = "n" > taking_too_long< / span > < span class = "o" > =< / span > < span class = "n" > time< / span > < span class = "o" > .< / span > < span class = "n" > time< / span > < span class = "p" > ()< / span > < span class = "o" > > < / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > _start_time< / span > < span class = "o" > +< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > _timeout< / span > < span class = "o" > *< / span > < span class = "mi" > 60< / span > < span class = "p" > )< / span >
< span class = "k" > if< / span > < span class = "n" > taking_too_long< / span > < span class = "p" > :< / span >
< span class = "n" > log< / span > < span class = "o" > .< / span > < span class = "n" > error< / span > < span class = "p" > (< / span > < span class = "s" > " Canceling installation due to timeout" < / span > < span class = "p" > )< / span >
< span class = "k" > else< / span > < span class = "p" > :< / span >
< span class = "n" > taking_too_long< / span > < span class = "o" > =< / span > < span class = "bp" > False< / span >
< span class = "k" > return< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > log_error< / span > < span class = "ow" > or< / span > < span class = "n" > taking_too_long< / span >
< / div > < / div >
< div class = "viewcode-block" id = "LogMonitor" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogMonitor" > [docs]< / a > < span class = "k" > class< / span > < span class = "nc" > LogMonitor< / span > < span class = "p" > (< / span > < span class = "nb" > object< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Setup a server to monitor the logs output by the installation< / span >
< span class = "sd" > This needs to be running before the virt-install runs, it expects< / span >
< span class = "sd" > there to be a listener on the port used for the virtio log port.< / span >
< span class = "sd" > " " " < / span >
< span class = "k" > def< / span > < span class = "nf" > __init__< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ,< / span > < span class = "n" > log_path< / span > < span class = "o" > =< / span > < span class = "bp" > None< / span > < span class = "p" > ,< / span > < span class = "n" > host< / span > < span class = "o" > =< / span > < span class = "s" > " localhost" < / span > < span class = "p" > ,< / span > < span class = "n" > port< / span > < span class = "o" > =< / span > < span class = "mi" > 0< / span > < span class = "p" > ,< / span > < span class = "n" > timeout< / span > < span class = "o" > =< / span > < span class = "bp" > None< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Start a thread to monitor the logs.< / span >
< span class = "sd" > :param str log_path: Path to the logfile to write< / span >
< span class = "sd" > :param str host: Host to bind to. Default is localhost.< / span >
< span class = "sd" > :param int port: Port to listen to or 0 to pick a port< / span >
< span class = "sd" > If 0 is passed for the port the dynamically assigned port will be< / span >
< span class = "sd" > available as self.port< / span >
< span class = "sd" > If log_path isn' t set then it only monitors the logs, instead of< / span >
< span class = "sd" > also writing them to disk.< / span >
< span class = "sd" > " " " < / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > =< / span > < span class = "n" > LogServer< / span > < span class = "p" > (< / span > < span class = "n" > log_path< / span > < span class = "p" > ,< / span > < span class = "p" > (< / span > < span class = "n" > host< / span > < span class = "p" > ,< / span > < span class = "n" > port< / span > < span class = "p" > ),< / span > < span class = "n" > LogRequestHandler< / span > < span class = "p" > ,< / span > < span class = "n" > timeout< / span > < span class = "o" > =< / span > < span class = "n" > timeout< / span > < span class = "p" > )< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > host< / span > < span class = "p" > ,< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > port< / span > < span class = "o" > =< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > server_address< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > log_path< / span > < span class = "o" > =< / span > < span class = "n" > log_path< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server_thread< / span > < span class = "o" > =< / span > < span class = "n" > threading< / span > < span class = "o" > .< / span > < span class = "n" > Thread< / span > < span class = "p" > (< / span > < span class = "n" > target< / span > < span class = "o" > =< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > handle_request< / span > < span class = "p" > )< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server_thread< / span > < span class = "o" > .< / span > < span class = "n" > daemon< / span > < span class = "o" > =< / span > < span class = "bp" > True< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server_thread< / span > < span class = "o" > .< / span > < span class = "n" > start< / span > < span class = "p" > ()< / span >
< div class = "viewcode-block" id = "LogMonitor.shutdown" > < a class = "viewcode-back" href = "../../pylorax.html#pylorax.monitor.LogMonitor.shutdown" > [docs]< / a > < span class = "k" > def< / span > < span class = "nf" > shutdown< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ):< / span >
< span class = "sd" > " " " Force shutdown of the monitoring thread" " " < / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server< / span > < span class = "o" > .< / span > < span class = "n" > kill< / span > < span class = "o" > =< / span > < span class = "bp" > True< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > server_thread< / span > < span class = "o" > .< / span > < span class = "n" > join< / span > < span class = "p" > ()< / span > < / div > < / div >
< / pre > < / div >
< / div >
< footer >
< hr / >
< div role = "contentinfo" >
< p >
© Copyright 2015, Red Hat, Inc..
< / p >
< / div >
Built with < a href = "http://sphinx-doc.org/" > Sphinx< / a > using a < a href = "https://github.com/snide/sphinx_rtd_theme" > theme< / a > provided by < a href = "https://readthedocs.org" > Read the Docs< / a > .
< / footer >
< / div >
< / div >
< / section >
< / div >
< script type = "text/javascript" >
var DOCUMENTATION_OPTIONS = {
URL_ROOT:'../../',
2015-12-04 18:16:16 +00:00
VERSION:'24.6',
2015-07-17 15:40:26 +00:00
COLLAPSE_INDEX:false,
FILE_SUFFIX:'.html',
HAS_SOURCE: true
};
< / script >
< script type = "text/javascript" src = "../../_static/jquery.js" > < / script >
< script type = "text/javascript" src = "../../_static/underscore.js" > < / script >
< script type = "text/javascript" src = "../../_static/doctools.js" > < / script >
< script type = "text/javascript" src = "../../_static/js/theme.js" > < / script >
< script type = "text/javascript" >
jQuery(function () {
SphinxRtdTheme.StickyNav.enable();
});
< / script >
< / body >
< / html >