I seguenti esempi illustrano come creare una sessione di autenticazione nell'API di BFC.
Esempio di Curl:
%export BFC_HOST=10.10.x.x
%curl -k https://$BFC_HOST:8443/BFC/1.0/login -X POST \
-d "{\"username\":\"core/admin\",\"password\":\"changeme\"}" \
-H "Content-Type:application/json"
RESPONSE= <session token> i.e. "d147eb4031217717c5af68edf33cd40c"%
%export BFC_SESSION= d147eb4031217717c5af68edf33cd40c
Esempio di Python:
from httplib import HTTPSConnection
import json
bfcHost = "10.10.x.x"
conn = HTTPSConnection(bfcHost + ':8443')
conn.connect()
conn.request(method='POST', url='/BFC/1.0/login',
body='{"username":"admin","password":"changeme"}',
headers={'Content-Type':'application/json'})
session = json.loads(conn.getresponse().read())
print session
I seguenti esempi illustrano come recuperare le informazioni su un set di griglie.
Esempio di Curl:
curl -k -v https://$BFC_HOST:8443/BFC/grids \ -H "Content-Type:application/json" \ -H "Authorization:$BFC_SESSION"
Esempio di Python:
session = get_session()
conn = HTTPSConnection(bfcHost + ':8443')
conn.connect()
conn.request(method='GET',
url='/BFC/grids',
headers={'Content-Type':'application/json',
'Authorization':session})
grids = json.loads(conn.getresponse().read())
print grids
I seguenti esempi illustrano come recuperare le informazioni su una griglia singola.
Esempio di Curl:
curl -k -v https://$BFC_HOST:8443/BFC/grids/$GRID_NAME \ -H "Content-Type:application/json" \ -H "Authorization:$BFC_SESSION"
Esempio di Python:
session = get_session()
gridName = 'productionApiTest'
conn = HTTPSConnection(bfcHost + ':8443')
conn.connect()
conn.request(method='GET',
url='/BFC/grids/' + gridName,
headers={'Content-Type':'application/json',
'Authorization':session})
grid = json.loads(conn.getresponse().read())
print grid
I seguenti esempi illustrano come creare una griglia nell'API di BFC.
Esempio di Curl:
curl -k -v -X POST "https://$BFC_HOST:8443/BFC/grids?numAppIPs=3" \
-H "Content-Type:application/json" \
-H "Authorization:$BFC_SESSION" \
-d "{\"grid\":{\"name\":\"productionApiTest\",
\"xen_config\":{\"grid_server_configuration\":{\"min\":1,
\"target\":1,
\"max\":1,
\"selection_criteria\":[]}},
\"grid_controller_user\":\"cadev@ca.com\",
\"grid_controller_password\":\"myPass\",
\"description\":\"Xen grid for demo\"}}"
Esempio di Python:
session = get_session()
conn = HTTPSConnection(bfcHost + ':8443')
conn.connect()
conn.request(method='POST',
url='/BFC/grids?numAppIPs=2',
headers={'Content-Type':'application/json',
'Authorization':session},
body = json.dumps({"grid":{"name":"productionApiTest",
"xen_config":{"grid_server_configuration":{
"min":1,
"target":1,
"max":2,
"selection_criteria":[]}},
"grid_controller_user":"cadev@ca.com",
"grid_controller_password":"c0tr011er",
"description":"Xen grid for demo"}}))
resp = conn.getresponse()
if resp.status > 201:
print 'Failed grid create - '
print json.loads(resp.read())
else:
print 'Grid created'
È possibile eseguire le seguenti operazioni sulla griglia: avvio, arresto, riavvio, clearFailure, applyHotfixes e removeNodes. Gli esempi di seguito illustrano come avviare una griglia nell'API di BFC. Sostituire il parametro di avvio con un parametro diverso per le altre operazioni di griglia.
Esempio di Curl:
curl -k -v -X POST https://$BFC_HOST:8443/BFC/grids/$GRID_NAME/operations/start \ -H "Content-Type:application/json" \ -H "Authorization:$BFC_SESSION"
Esempio di Python:
session = get_session()
conn = HTTPSConnection(bfcHost + ':8443')
gridName = 'productionApiTest'
operation = 'start'
conn.connect()
conn.request(method='POST',
url='/BFC/grids/' + gridName + "/operations/" + operation ,
headers={'Content-Type':'application/json',
'Authorization':session})
resp = conn.getresponse()
if resp.status > 202:
print 'Failed grid operation - '
print json.loads(resp.read())
else:
print 'Operation successful'
I seguenti esempi illustrano come eseguire un aggiornamento di griglia in cui la descrizione cambia e il conteggio del nodo di destinazione di xen viene modificato da 1 a 2.
Esempio di Curl:
curl -k -v -X PUT https://$BFC_HOST:8443/BFC/grids/$GRID_NAME \
-H "Content-Type:application/json" \
-H "Authorization:$BFC_SESSION" \
-d "{\"grid\":{\"description\":\"New Description\",
\"xen_config\":{\"grid_server_configuration\":{\"min\":1,
\"target\":2,
\"max\":2,
\"selection_criteria\":[]}}}}"
Esempio di Python:
session = get_session()
conn = HTTPSConnection(bfcHost + ':8443')
gridName = 'productionApiTest'
conn.connect()
conn.request(method='PUT',
url='/BFC/grids/' + gridName,
headers={'Content-Type':'application/json',
'Authorization':session},
body = json.dumps({"grid":{
"xen_config":{"grid_server_configuration":{
"min":1,
"target":2,
"max":2,
"selection_criteria":[]}},
"description":"New Description"}}))
resp = conn.getresponse()
if resp.status > 201:
print 'Failed grid create - '
print json.loads(resp.read())
else:
print 'Grid created'
I seguenti esempi illustrano come eliminare una griglia nell'API di BFC.
Esempio di Curl:
curl -k -v -X DELETE https://$BFC_HOST:8443/BFC/grids/$GRID_NAME \ -H "Content-Type:application/json" \ -H "Authorization:$BFC_SESSION"
Esempio di Python:
session = get_session()
gridName = 'productionApiTest'
conn = HTTPSConnection(bfcHost + ':8443')
conn.connect()
conn.request(method='DELETE',
url='/BFC/grids/' + gridName,
headers={'Content-Type':'application/json',
'Authorization':session})
resp = conn.getresponse()
if resp.status > 202:
print 'Failed grid delete - '
print json.loads(resp.read())
else:
print 'Grid deleted'
|
Copyright © 2013 CA.
Tutti i diritti riservati.
|
|