forked from micado-scale/component-policy-keeper
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhandle_occopus.py
25 lines (22 loc) · 1021 Bytes
/
handle_occopus.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
import logging
import requests
import pk_config
def scale_worker_node(endpoint,infra_name,worker_name,replicas):
log=logging.getLogger('pk_occopus')
log.info('(S) => m_node_count: {0}'.format(replicas))
wscall = '{0}/infrastructures/{1}/scaleto/{2}/{3}'.format(endpoint,infra_name,worker_name,replicas)
log.debug('-->curl -X POST {0}'.format(wscall))
if not pk_config.simulate():
response = requests.post(wscall).json()
log.debug('-->response: {0}'.format(response))
return
def query_number_of_worker_nodes(endpoint,infra_name,worker_name):
log=logging.getLogger('pk_occopus')
instances=1
wscall = '{0}/infrastructures/{1}'.format(endpoint,infra_name)
log.debug('-->curl -X GET {0}'.format(wscall))
if not pk_config.simulate():
response = requests.get(wscall).json()
instances = response.get(worker_name,dict()).get('scaling',dict()).get('target',0)
log.debug('-->instances: {0}, response: {1}'.format(instances,response))
return instances