python-compute/docs/source/python-api/index.rst

48 lines
1.3 KiB
ReStructuredText
Raw Normal View History

2023-11-06 17:47:56 +03:00
Python API
==========
2023-11-06 18:38:24 +03:00
The API allows you to perform actions on instances programmatically. Below is
an example of changing parameters and launching the `myinstance` instance.
2023-11-06 17:47:56 +03:00
.. code-block:: python
import logging
from compute import Session
logging.basicConfig(level=logging.DEBUG)
with Session() as session:
instance = session.get_instance('myinstance')
instance.set_vcpus(4)
instance.start()
instance.set_autostart(enabled=True)
2023-11-06 18:38:24 +03:00
:class:`Session` context manager provides an abstraction over :class:`libvirt.virConnect`
and returns objects of other classes of the present library.
2023-11-06 17:47:56 +03:00
2023-11-06 18:38:24 +03:00
Entity representation
---------------------
2023-11-06 17:47:56 +03:00
2023-11-06 18:38:24 +03:00
Entities such as a compute-instance are represented as classes. These classes directly
call libvirt methods to perform operations on the hypervisor. An example class is
:class:`Volume`.
2023-11-06 17:47:56 +03:00
2023-11-06 18:38:24 +03:00
The configuration files of various libvirt objects in `compute` are described by special
dataclasses. The dataclass stores object parameters in its properties and can return an
XML config for libvirt using the ``to_xml()`` method. For example :class:`VolumeConfig`.
2023-11-06 17:47:56 +03:00
2023-11-06 18:38:24 +03:00
`Pydantic <https://docs.pydantic.dev/>`_ models are used to validate input data.
For example :class:`VolumeSchema`.
2023-11-06 17:47:56 +03:00
2023-11-06 18:38:24 +03:00
Modules documentation
---------------------
2023-11-06 17:47:56 +03:00
.. toctree::
:maxdepth: 4
session
instance/index
2023-11-06 18:38:24 +03:00
storage/index