Newer
Older
Tests that all webserver services (vhosts) are available and reachable.
'''
This script checks for all enabled vhosts in Nginx conf that:
* The response status code is 200 or 403.
* The host is resolved as 127.0.0.1.
* The Wowza response is correct on /streaming/ (only for mediaserver vhosts).
'''
# check that Nginx dir exists
nginx_dir = '/etc/nginx/sites-enabled'
if not os.path.exists(nginx_dir):
print('Nginx dir does not exists ("%s").' % nginx_dir)
# check that Wowza is installed
wowza_dir = '/usr/local/WowzaStreamingEngine'
if not os.path.exists(wowza_dir):
print('Info: Wowza is not installed ("%s" does not exist).' % wowza_dir)
wowza_dir = None
print('Info: Wowza is installed, /streaming/ will be tested on mediaserver vhosts.')
# get enabled vhosts
requests.packages.urllib3.disable_warnings()
found = False
errors = 0
for name in os.listdir(nginx_dir):
path = os.path.join(nginx_dir, name)
with open(path, 'r') as fo:
conf = fo.read()
conf = conf.replace('\t', ' ')
matching = re.search(r'.*server_name\ +([0-9a-zA-Z\.\-\_\ ]+);.*', conf)
if not matching:
print('The server_name was not found in: "%s".' % path)
errors += 1
continue
domains = matching.groups()[0].strip().split(' ')
https = re.search(r'listen +\w* +ssl;', conf) is not None \
or re.search(r'ssl +on;', conf) is not None
for domain in domains:
if domain == 'localhost':
continue # status vhost
found = True
url = '%s://%s' % ('https' if https else 'http', domain)
sys.stdout.write('Testing url "%s":\n' % url)
# test domain IP
ip_error = None
try:
ip = socket.gethostbyname(domain)
except Exception as e:
ip_error = 'domain is not resolved: %s' % e
ip_error = 'domain is resolved with %s instead of 127.0.0.1' % ip
sys.stdout.write(' IP: ')
if ip_error:
sys.stdout.write('\033[91mKO (%s)\033[0m' % ip_error)
else:
sys.stdout.write('\033[92mOK (127.0.0.1)\033[0m')
# test url
sys.stdout.write(', status: ')
req_error = False
try:
req = requests.get(url, verify=False, proxies={'http': '', 'https': ''}, timeout=10)
except Exception as e:
code = str(e)
else:
code = req.status_code
if code not in (200, 403):
sys.stdout.write('\033[91mKO (%s)\033[0m' % code)
req_error = True
else:
sys.stdout.write('\033[92mOK (%s)\033[0m' % code)
if 'mediaserver' in name and wowza_dir:
# test /streaming url
sys.stdout.write(', streaming: ')
req = requests.get(url + '/streaming/', verify=False, proxies={'http': '', 'https': ''}, timeout=10)
except Exception as e:
code = str(e)
else:
code = req.status_code
sys.stdout.write('\033[91mKO (%s)\033[0m' % code)
req_error = True
elif 'Wowza Streaming Engine' not in req.text:
sys.stdout.write('\033[91mKO (%s, %s)\033[0m' % (code, req.text.replace('\n', ' ')[:200]))
req_error = True
else:
sys.stdout.write('\033[92mOK (%s)\033[0m' % code)
sys.stdout.write('.\n')
if ip_error or req_error:
errors += 1
if errors:
print('%s vhost(s) did not correctly responded.' % errors)
sys.exit(1)
if not found:
print('No vhost found in Nginx sites-enabled dir.')
sys.exit(1)