blob: a7f297399eaab8d7e7e46ca9d95ade3be970604b [file] [log] [blame]
#!/usr/bin/env python
import getopt
import logging
import os
import sys
import time
from kubernetes import config
from kubernetes.client import Configuration
from kubernetes.client.api import core_v1_api
from kubernetes.client.rest import ApiException
from kubernetes.stream import stream
from kubernetes import client
# extract env variables.
namespace = os.environ['NAMESPACE']
cert = os.environ['CERT']
host = os.environ['KUBERNETES_SERVICE_HOST']
token_path = os.environ['TOKEN']
with open(token_path, 'r') as token_file:
token = token_file.read().replace('\n', '')
# setup logging
log = logging.getLogger(__name__)
handler = logging.StreamHandler(sys.stdout)
handler.setFormatter(logging.Formatter('%(asctime)s - %(levelname)s - %(message)s'))
handler.setLevel(logging.INFO)
log.addHandler(handler)
log.setLevel(logging.INFO)
configuration = client.Configuration()
configuration.host = "https://" + host
configuration.ssl_ca_cert = cert
configuration.api_key['authorization'] = token
configuration.api_key_prefix['authorization'] = 'Bearer'
configuration.assert_hostname = False
coreV1Api = client.CoreV1Api(client.ApiClient(configuration))
api_instance = client.CoreV1Api(client.ApiClient(configuration))
def run_command( pod_name, command ):
try:
exec_command = [
'/bin/sh',
'-c',
command]
resp = stream(api_instance.connect_get_namespaced_pod_exec, pod_name, namespace,
command=exec_command,
stderr=True, stdin=False,
stdout=True, tty=False)
except ApiException as e:
print("Exception when calling CoreV1Api->connect_get_namespaced_pod_exec: %s\n" % e)
return False
print(resp)
return True
def find_pod(container_name,command,pods):
ready = False
try:
response = coreV1Api.list_namespaced_pod(namespace=namespace, watch=False)
for i in response.items:
# container_statuses can be None, which is non-iterable.
if i.status.container_statuses is None:
continue
for s in i.status.container_statuses:
if s.name == container_name:
if pods == True:
print (i.metadata.name)
else:
ready = run_command(i.metadata.name,command)
else:
continue
except Exception as e:
log.error("Exception when calling list_namespaced_pod: %s\n" % e)
return ready
DESCRIPTION = "Kubernetes container readiness check utility"
USAGE = "Usage: ready.py [-t <timeout>] -c <container_name> [-c <container_name> ...]\n" \
"where\n" \
"<container_name> - name of the container to wait for\n"
def main(argv):
pods = False
command = ""
container_name = ""
try:
opts, args = getopt.getopt(argv, "ghp:c:", ["pod-container-name=", "command=", "help","getpods"])
for opt, arg in opts:
if opt in ("-h", "--help"):
print("%s\n\n%s" % (DESCRIPTION, USAGE))
sys.exit()
elif opt in ("-p", "--pod-container-name"):
container_name = arg
elif opt in ("-c", "--command"):
command = arg
elif opt in ("-g", "--getpods"):
pods = True
except (getopt.GetoptError, ValueError) as e:
print("Error parsing input parameters: %s\n" % e)
print(USAGE)
sys.exit(2)
if container_name.__len__() == 0:
print("Missing required input parameter(s)\n")
print(USAGE)
sys.exit(2)
if pods == False:
if command.__len__() == 0:
print("Missing required input parameter(s)\n")
print(USAGE)
sys.exit(2)
ready = find_pod(container_name,command,pods)
if ready == False:
sys.exit(2)
if __name__ == "__main__":
main(sys.argv[1:])