mirror of
https://github.com/xcat2/confluent.git
synced 2025-01-27 19:37:57 +00:00
Have syncfiles attempt to use client ip, if feasible
When a node installs, it may not have it's node mapped address up, or may not have one at all. Try to use the ip if it would be in the same set that produced it's ssh certificate. There remains a gap if a system has no static addressing *and* doesn't map nodename to IP, but we have an impasse as the situation is too fuzzy to grant a prinicpal in an SSH cert, and without that we can't securely attempt rsync. For now, this scenario would still fail and I will just hope that doesn't come up.
This commit is contained in:
parent
13ba95bb99
commit
c612129d64
@ -281,3 +281,4 @@ if __name__ == '__main__':
|
||||
# possible checks:
|
||||
# arping on the node, check for dupes/against nodeinventory?
|
||||
# arping -D for mgt own ip addresses? check for dupes, also check for bleed through from one nic to another
|
||||
# iterate through profiles, use mtools to extract site initramfs, check if outdated
|
||||
|
@ -70,6 +70,7 @@ def handle_request(env, start_response):
|
||||
configmanager.check_quorum()
|
||||
cfg = configmanager.ConfigManager(None)
|
||||
nodename = env.get('HTTP_CONFLUENT_NODENAME', None)
|
||||
clientip = env.get('HTTP_X_FORWARDED_FOR', None)
|
||||
if env['PATH_INFO'] == '/self/registerapikey':
|
||||
crypthmac = env.get('HTTP_CONFLUENT_CRYPTHMAC', None)
|
||||
if int(env.get('CONTENT_LENGTH', 65)) > 64:
|
||||
@ -459,8 +460,11 @@ def handle_request(env, start_response):
|
||||
return
|
||||
elif env['PATH_INFO'].startswith('/self/remotesyncfiles'):
|
||||
if 'POST' == operation:
|
||||
pals = get_extra_names(nodename, cfg, myip)
|
||||
if clientip not in pals:
|
||||
clientip = None
|
||||
result = syncfiles.start_syncfiles(
|
||||
nodename, cfg, json.loads(reqbody))
|
||||
nodename, cfg, json.loads(reqbody), clientip)
|
||||
start_response(result, ())
|
||||
yield ''
|
||||
return
|
||||
|
@ -162,7 +162,7 @@ class SyncList(object):
|
||||
self.optmap[f] = entopts
|
||||
|
||||
|
||||
def sync_list_to_node(sl, node, suffixes):
|
||||
def sync_list_to_node(sl, node, suffixes, peerip=None):
|
||||
targdir = tempfile.mkdtemp('.syncto{}'.format(node))
|
||||
output = ''
|
||||
try:
|
||||
@ -187,8 +187,11 @@ def sync_list_to_node(sl, node, suffixes):
|
||||
stage_ent(sl.appendoncemap, ent,
|
||||
os.path.join(targdir, suffixes['appendonce']), True)
|
||||
sshutil.prep_ssh_key('/etc/confluent/ssh/automation')
|
||||
targip = node
|
||||
if peerip:
|
||||
targip = peerip
|
||||
output = util.run(
|
||||
['rsync', '-rvLD', targdir + '/', 'root@{}:/'.format(node)])[0]
|
||||
['rsync', '-rvLD', targdir + '/', 'root@{}:/'.format(targip)])[0]
|
||||
except Exception as e:
|
||||
if 'CalledProcessError' not in repr(e):
|
||||
# https://github.com/eventlet/eventlet/issues/413
|
||||
@ -275,7 +278,7 @@ def mkpathorlink(source, destination, appendexist=False):
|
||||
syncrunners = {}
|
||||
|
||||
|
||||
def start_syncfiles(nodename, cfg, suffixes):
|
||||
def start_syncfiles(nodename, cfg, suffixes, peerip=None):
|
||||
deployinfo = cfg.get_node_attributes(
|
||||
nodename, ('deployment.*',))
|
||||
deployinfo = deployinfo.get(nodename, {})
|
||||
@ -296,7 +299,7 @@ def start_syncfiles(nodename, cfg, suffixes):
|
||||
if not (sl.appendmap or sl.mergemap or sl.replacemap or sl.appendoncemap):
|
||||
return '200 OK' # the synclist has no actual entries
|
||||
syncrunners[nodename] = eventlet.spawn(
|
||||
sync_list_to_node, sl, nodename, suffixes)
|
||||
sync_list_to_node, sl, nodename, suffixes, peerip)
|
||||
return '202 Queued' # backgrounded
|
||||
|
||||
def get_syncresult(nodename):
|
||||
|
Loading…
x
Reference in New Issue
Block a user