Merge remote-tracking branch 'ungleich/feature/trigger' into feature/trigger

This commit is contained in:
Darko Poljak 2016-10-30 15:09:26 +01:00
commit 7c169f2d0a
3 changed files with 41 additions and 12 deletions

View File

@ -136,7 +136,7 @@ class Config(object):
import multiprocessing
# FIXME: Refactor relict - remove later
log = logging.getLogger("cdist")
log = logging.getLogger(__name__)
if args.manifest == '-' and args.hostfile == '-':
raise cdist.Error(("Cannot read both, manifest and host file, "
@ -227,6 +227,8 @@ class Config(object):
raise cdist.Error("Failed to configure the following hosts: " +
" ".join(failed_hosts))
@classmethod
def onehost(cls, host, host_base_path, host_dir_name, args, parallel):
"""Configure ONE system"""
@ -317,6 +319,16 @@ class Config(object):
else:
raise
# FIXME begin to cleanup with this method
@staticmethod
def create_host_tmpdir(host):
base_dir = tempfile.mkdtemp()
hostdir = cdist.str_hash(host)
return (base_dir, hostdir)
def run(self):
"""Do what is most often done: deploy & cleanup"""
start_time = time.time()

View File

@ -29,7 +29,8 @@ from http.server import BaseHTTPRequestHandler, HTTPServer
import multiprocessing
import cdist
import cdist.config
import cdist.install
log = logging.getLogger(__name__)
@ -42,16 +43,22 @@ class Trigger():
self.http_port = int(http_port)
self.ipv4only = ipv4only
self.args = "fun"
# can only be set once
multiprocessing.set_start_method('forkserver')
# Create pool suitable for passing objects
def __init_pool(self):
pass
def run_httpd(self):
server_address = ('', self.http_port)
if self.ipv4only:
httpd = HTTPServerV4(server_address, TriggerHttp)
httpd = HTTPServerV4(self.args, server_address, TriggerHttp)
else:
httpd = HTTPServerV6(server_address, TriggerHttp)
httpd = HTTPServerV6(self.args, server_address, TriggerHttp)
httpd.serve_forever()
@ -65,15 +72,14 @@ class Trigger():
t.run()
class TriggerHttp(BaseHTTPRequestHandler):
def __init__(self, *args, **kwargs):
http.server.BaseHTTPRequestHandler.__init__(self, *args, **kwargs)
def do_GET(self):
# FIXME: dispatch to pool instead of single process
host = self.client_address[0]
code = 200
mode = None
print(self.server.cdistargs)
m = re.match("^/(?P<mode>config|install)/.*", self.path)
if m:
mode = m.group('mode')
@ -95,12 +101,12 @@ class TriggerHttp(BaseHTTPRequestHandler):
def run_cdist(self, mode, host):
log.debug("Running cdist {} {}".format(mode, host))
cname = mode.title()
module = getattr(cdist, mode)
theclass = getattr(module, cname)
class HTTPServerV4(http.server.HTTPServer):
"""
Server that listens only to IPv4 requests.
"""
address_family = socket.AF_INET
host_base_path, hostdir = theclass.create_host_tmpdir(host)
theclass.onehost(host, host_base_path, hostdir, args, parallel=False)
class HTTPServerV6(http.server.HTTPServer):
@ -108,3 +114,13 @@ class HTTPServerV6(http.server.HTTPServer):
Server that listens both to IPv4 and IPv6 requests.
"""
address_family = socket.AF_INET6
def __init__(self, cdistargs, *args, **kwargs):
self.cdistargs = cdistargs
http.server.HTTPServer.__init__(self, *args, **kwargs)
class HTTPServerV4(HTTPServerV6):
"""
Server that listens to IPv4 requests
"""
address_family = socket.AF_INET

View File

@ -150,6 +150,7 @@ def commandline():
'-s', '--sequential',
help='Operate on multiple hosts sequentially (default)',
action='store_false', dest='parallel')
# remote-copy and remote-exec defaults are environment variables
# if set; if not then None - these will be futher handled after
# parsing to determine implementation default