multi cluster
This commit is contained in:
56
app.py
56
app.py
@@ -8,11 +8,19 @@ import flask
|
||||
import logging
|
||||
import os
|
||||
import requests
|
||||
import tokens
|
||||
|
||||
from urllib.parse import urljoin
|
||||
|
||||
|
||||
DEFAULT_CLUSTERS = 'http://localhost:8001/'
|
||||
|
||||
app = connexion.App(__name__)
|
||||
session = requests.Session()
|
||||
|
||||
tokens.configure(from_file_only=True)
|
||||
tokens.manage('read-only')
|
||||
|
||||
|
||||
@app.app.route('/')
|
||||
def index():
|
||||
@@ -20,36 +28,40 @@ def index():
|
||||
|
||||
|
||||
def get_clusters():
|
||||
api_server_url = 'http://localhost:8001/'
|
||||
response = session.get('{}/api/v1/nodes'.format(api_server_url), timeout=5)
|
||||
response.raise_for_status()
|
||||
nodes = []
|
||||
nodes_by_name = {}
|
||||
for node in response.json()['items']:
|
||||
obj = {'name': node['metadata']['name'], 'labels': node['metadata']['labels'], 'status': node['status'], 'pods': []}
|
||||
nodes.append(obj)
|
||||
nodes_by_name[obj['name']] = obj
|
||||
response = session.get('http://localhost:8001/api/v1/pods', timeout=5)
|
||||
response.raise_for_status()
|
||||
for pod in response.json()['items']:
|
||||
if 'nodeName' in pod['spec']:
|
||||
nodes_by_name[pod['spec']['nodeName']]['pods'].append(pod)
|
||||
|
||||
try:
|
||||
response = session.get('{}/api/v1/namespaces/kube-system/services/heapster/proxy/apis/metrics/v1alpha1/nodes'.format(api_server_url), timeout=5)
|
||||
clusters = []
|
||||
for api_server_url in os.getenv('CLUSTERS', DEFAULT_CLUSTERS).split(','):
|
||||
session.headers['Authorization'] = 'Bearer {}'.format(tokens.get('read-only'))
|
||||
response = session.get(urljoin(api_server_url, '/api/v1/nodes'), timeout=5)
|
||||
response.raise_for_status()
|
||||
for metrics in response.json()['items']:
|
||||
nodes_by_name[metrics['metadata']['name']]['usage'] = metrics['usage']
|
||||
except:
|
||||
logging.exception('Failed to get metrics')
|
||||
nodes = []
|
||||
nodes_by_name = {}
|
||||
for node in response.json()['items']:
|
||||
obj = {'name': node['metadata']['name'], 'labels': node['metadata']['labels'], 'status': node['status'], 'pods': []}
|
||||
nodes.append(obj)
|
||||
nodes_by_name[obj['name']] = obj
|
||||
response = session.get(urljoin(api_server_url, '/api/v1/pods'), timeout=5)
|
||||
response.raise_for_status()
|
||||
for pod in response.json()['items']:
|
||||
if 'nodeName' in pod['spec']:
|
||||
nodes_by_name[pod['spec']['nodeName']]['pods'].append(pod)
|
||||
|
||||
return {'kubernetes_clusters': [{'nodes': nodes}]}
|
||||
try:
|
||||
response = session.get(urljoin(api_server_url, '/api/v1/namespaces/kube-system/services/heapster/proxy/apis/metrics/v1alpha1/nodes'), timeout=5)
|
||||
response.raise_for_status()
|
||||
for metrics in response.json()['items']:
|
||||
nodes_by_name[metrics['metadata']['name']]['usage'] = metrics['usage']
|
||||
except:
|
||||
logging.exception('Failed to get metrics')
|
||||
clusters.append({'api_server_url': api_server_url, 'nodes': nodes})
|
||||
|
||||
return {'kubernetes_clusters': clusters}
|
||||
|
||||
|
||||
app.add_api('swagger.yaml')
|
||||
|
||||
if __name__ == '__main__':
|
||||
logging.basicConfig(level=logging.INFO)
|
||||
|
||||
if os.getenv('DEBUG', False):
|
||||
kwargs = {'debug': True}
|
||||
else:
|
||||
|
||||
@@ -1,2 +1,3 @@
|
||||
connexion
|
||||
gevent
|
||||
stups-tokens
|
||||
|
||||
Reference in New Issue
Block a user