Nodes#

Author: Sam Eure May 5, 2025

CREATE#

We can create new nodes for a simulation by using the api.nodes.create method:

[2]:
from air_sdk import AirApi
from air_sdk.endpoints.nodes import Node
from air_sdk.endpoints.simulations import Simulation

api = AirApi.with_ngc_config()
# Or use SAK directly
# api = AirApi.with_api_key(api_key='nvapi-xyz')

sim: Simulation = api.simulations.create(name='Blank Simulation')
ubuntu_2204 = next(api.images.list(search='generic/ubuntu2204'))

node: Node = api.nodes.create(
    simulation=sim,
    image=ubuntu_2204,
    name='ubuntu-server',
    console_username='ubuntu',
    console_password='nvidia',
)
node.dict()
[2]:
{'id': 'ab51b7fa-a0a7-4969-ba48-e49c7302c3d5',
 'created': datetime.datetime(2025, 5, 5, 19, 27, 12, 522911, tzinfo=datetime.timezone.utc),
 'modified': datetime.datetime(2025, 5, 5, 19, 27, 12, 522921, tzinfo=datetime.timezone.utc),
 'name': 'ubuntu-server',
 'simulation': '75dd1ce1-7927-46e1-a84c-07ec00661884',
 'image': 'f42d97f1-e217-470a-b63b-59368ef18ec9',
 'state': 'READY',
 'category': 'SERVER',
 'split_options': None,
 'cpu': 1,
 'memory': 1024,
 'storage': 10,
 'pos_x': 0,
 'pos_y': 0,
 'console_username': 'ubuntu',
 'console_password': 'nvidia'}

Nodes can also be created off of an existing Simulation instance:

[ ]:
from air_sdk.endpoints.nodes import Node
from air_sdk.endpoints.simulations import Simulation

sim: Simulation = api.simulations.create(name='Blank Simulation')
ubuntu_2204 = next(api.images.list(search='generic/ubuntu2204'))

# You do not have to specify `simulation=sim` in the payload when using this method.
node: Node = sim.nodes.create(name='new-node', image=ubuntu_2204)
node.dict()
{'id': 'fe4ba46d-1142-4a1c-a9f1-86b453272c1c',
 'created': datetime.datetime(2025, 5, 5, 19, 27, 14, 536811, tzinfo=datetime.timezone.utc),
 'modified': datetime.datetime(2025, 5, 5, 19, 27, 14, 536820, tzinfo=datetime.timezone.utc),
 'name': 'new-node',
 'simulation': '75dd1ce1-7927-46e1-a84c-07ec00661884',
 'image': 'f42d97f1-e217-470a-b63b-59368ef18ec9',
 'state': 'READY',
 'category': 'SERVER',
 'split_options': None,
 'cpu': 1,
 'memory': 1024,
 'storage': 10,
 'pos_x': 0,
 'pos_y': 0,
 'console_username': '',
 'console_password': ''}

GET#

How to list, filter, order, and search for nodes of a simulation.

[1]:
from air_sdk.endpoints.images import Image
from air_sdk.endpoints.simulations import Simulation

ubuntu_2204: Image = next(api.images.list(search='generic/ubuntu2204'))
cumulus_5_6_0: Image = next(api.images.list(search='cumulus-vx-5.6.0'))
sim: Simulation = api.simulations.create(name='Blank Simulation')
[2]:
# Create nodes with various specifications
sim.nodes.create(name='ubuntu-1', image=ubuntu_2204)
sim.nodes.create(name='ubuntu-2', image=ubuntu_2204)
sim.nodes.create(name='ubuntu-12', image=ubuntu_2204)
sim.nodes.create(name='special-node', image=ubuntu_2204)
sim.nodes.create(name='node14', image=cumulus_5_6_0)
sim.nodes.create(name='node15', image=cumulus_5_6_0)
sim.nodes.create(name='node16', image=cumulus_5_6_0)

for node in sim.nodes.list():
    print(node)
Node(id='42917bde-000a-4209-a20b-59db0c15b1a1', name='ubuntu-1')
Node(id='552b72bd-e4c5-4226-b50e-0e763c7890b8', name='ubuntu-2')
Node(id='c2903bfe-fa0b-43ec-ae75-7faf80f1f049', name='ubuntu-12')
Node(id='7f6772aa-76ef-4012-a2e0-e6d30ceb78a4', name='special-node')
Node(id='f61db084-99da-4928-bdb3-7bbd5950416e', name='node14')
Node(id='1a77d4bd-f533-48a7-a169-1415d52d8d91', name='node15')
Node(id='4abe2036-b4d1-438e-ad3b-9c236fd32e47', name='node16')

Order nodes by specific fields#

[8]:
for node in sim.nodes.list(ordering='name'):
    print(node.name)
node14
node15
node16
special-node
ubuntu-1
ubuntu-12
ubuntu-2

Search for nodes by name#

[4]:
for node in sim.nodes.list(search='node'):
    print(node.name)
node14
node15
node16

Filter node by specific properties#

[5]:
for node in sim.nodes.list(image=cumulus_5_6_0):
    print(node.name, node.image.name)
node14 cumulus-vx-5.6.0
node15 cumulus-vx-5.6.0
node16 cumulus-vx-5.6.0

This can be used to obtain a specific node by name

[11]:
list(sim.nodes.list(name='special-node'))
[11]:
[Node(id='7f6772aa-76ef-4012-a2e0-e6d30ceb78a4', name='special-node')]