mirror of
https://github.com/xcat2/confluent.git
synced 2025-01-28 11:57:37 +00:00
Utility function for running commands
Given the python2/3 differences, good to have a single run that returns stdout and stderr. This should trigger the same behavior as timeout did, but in a manner consistent between 2 and 3.
This commit is contained in:
parent
02da50af8b
commit
343e5eabe5
@ -1,5 +1,6 @@
|
||||
import os
|
||||
import confluent.collective.manager as collective
|
||||
import confluent.util as util
|
||||
from os.path import exists
|
||||
import shutil
|
||||
import socket
|
||||
@ -15,10 +16,7 @@ def get_openssl_conf_location():
|
||||
raise Exception("Cannot find openssl config file")
|
||||
|
||||
def get_ip_addresses():
|
||||
try:
|
||||
lines = subprocess.check_output('ip addr'.split(' '), timeout=86400)
|
||||
except TypeError:
|
||||
lines = subprocess.check_output('ip addr'.split(' '))
|
||||
lines = util.run(['ip', 'addr'])
|
||||
if not isinstance(lines, str):
|
||||
lines = lines.decode('utf8')
|
||||
for line in lines.split('\n'):
|
||||
@ -102,12 +100,8 @@ def assure_tls_ca():
|
||||
if e.errno != 17:
|
||||
raise
|
||||
shutil.copy2('/etc/confluent/tls/cacert.pem', fname)
|
||||
try:
|
||||
hv = subprocess.check_output(
|
||||
['openssl', 'x509', '-in', '/etc/confluent/tls/cacert.pem', '-hash', '-noout'], timeout=86400)
|
||||
except TypeError:
|
||||
hv = subprocess.check_output(
|
||||
['openssl', 'x509', '-in', '/etc/confluent/tls/cacert.pem', '-hash', '-noout'])
|
||||
hv = util.run(
|
||||
['openssl', 'x509', '-in', '/etc/confluent/tls/cacert.pem', '-hash', '-noout'])
|
||||
if not isinstance(hv, str):
|
||||
hv = hv.decode('utf8')
|
||||
hv = hv.strip()
|
||||
|
@ -211,8 +211,7 @@ def handle_request(env, start_response):
|
||||
pass
|
||||
if needlocalectl:
|
||||
try:
|
||||
langinfo = subprocess.check_output(
|
||||
['localectl', 'status'], timeout=86400).split(b'\n')
|
||||
langinfo = util.run(['localectl', 'status'])[0].split(b'\n')
|
||||
except Exception:
|
||||
langinfo = []
|
||||
for line in langinfo:
|
||||
@ -236,10 +235,7 @@ def handle_request(env, start_response):
|
||||
if ckeymap == 'n/a':
|
||||
continue
|
||||
keymap = ckeymap
|
||||
try:
|
||||
tdc = subprocess.check_output(['timedatectl'], timeout=86400).split(b'\n')
|
||||
except TypeError:
|
||||
tdc = subprocess.check_output(['timedatectl']).split(b'\n')
|
||||
tdc = util.run(['timedatectl'])[0].split(b'\n')
|
||||
for ent in tdc:
|
||||
ent = ent.strip()
|
||||
if ent.startswith(b'Time zone:'):
|
||||
|
@ -3,6 +3,7 @@
|
||||
import base64
|
||||
import confluent.config.configmanager as cfm
|
||||
import confluent.collective.manager as collective
|
||||
import confluent.util as util
|
||||
import eventlet.green.subprocess as subprocess
|
||||
import eventlet
|
||||
import glob
|
||||
@ -43,10 +44,7 @@ def assure_agent():
|
||||
if agent_pid is None:
|
||||
try:
|
||||
agent_starting = True
|
||||
try:
|
||||
sai = subprocess.check_output(['ssh-agent'], timeout=86400)
|
||||
except TypeError:
|
||||
sai = subprocess.check_output(['ssh-agent'])
|
||||
sai = util.run(['ssh-agent'])[0]
|
||||
for line in sai.split(b'\n'):
|
||||
if b';' not in line:
|
||||
continue
|
||||
|
@ -19,7 +19,7 @@ import os
|
||||
import shutil
|
||||
import tempfile
|
||||
import confluent.sshutil as sshutil
|
||||
import eventlet.green.subprocess as subprocess
|
||||
import confluent.util as util
|
||||
import confluent.noderange as noderange
|
||||
import eventlet
|
||||
import pwd
|
||||
@ -168,12 +168,8 @@ 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')
|
||||
try:
|
||||
output = subprocess.check_output(
|
||||
['rsync', '-rvLD', targdir + '/', 'root@{}:/'.format(node)], timeout=86400)
|
||||
except TypeError:
|
||||
output = subprocess.check_output(
|
||||
['rsync', '-rvLD', targdir + '/', 'root@{}:/'.format(node)])
|
||||
output = util.run(
|
||||
['rsync', '-rvLD', targdir + '/', 'root@{}:/'.format(node)])[0]
|
||||
except Exception as e:
|
||||
if 'CalledProcessError' not in repr(e):
|
||||
# https://github.com/eventlet/eventlet/issues/413
|
||||
|
@ -26,6 +26,17 @@ import re
|
||||
import socket
|
||||
import ssl
|
||||
import struct
|
||||
import subprocess
|
||||
|
||||
|
||||
def run(cmd):
|
||||
with subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE) as process:
|
||||
stdout, stderr = process.communicate()
|
||||
retcode = process.poll()
|
||||
if retcode:
|
||||
raise subprocess.CalledProcessError(retcode, process.args, output=stdout, stderr=stderr)
|
||||
return stdout, stderr
|
||||
|
||||
|
||||
def stringify(instr):
|
||||
# Normalize unicode and bytes to 'str', correcting for
|
||||
|
Loading…
x
Reference in New Issue
Block a user