summaryrefslogtreecommitdiff
path: root/api-guide/source/accelerator-support.rst
blob: 9d1b4d77b4da7d5b8efe8d4f13dcc4445812f372 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
==============================
Using accelerators with Cyborg
==============================

Starting from microversion 2.82, nova supports creating servers with
accelerators provisioned with the Cyborg service, which provides lifecycle
management for accelerators.

To launch servers with accelerators, the administrator (or an user with
appropriate privileges) must do the following:

* Create a device profile in Cyborg, which specifies what accelerator
  resources need to be provisioned. (See `Cyborg device profiles API`_.)

  .. _`Cyborg device profiles API`: https://docs.openstack.org/api-ref/accelerator/#device-profiles

* Set the device profile name as an extra spec in a chosen flavor,
  with this syntax:

  .. code::

    accel:device_profile=$device_profile_name

  The chosen flavor may be a newly created one or an existing one.

* Use that flavor to create a server:

  .. code::

    openstack server create --flavor $myflavor --image $myimage $servername

Nova supports only specific operations for instances with accelerators.
The lists of supported and unsupported operations are as below:

* Supported operations.

  * Creation and deletion.
  * Reboots (soft and hard).
  * Pause and unpause.
  * Stop and start.
  * Take a snapshot.
  * Backup.
  * Rescue and unrescue.
  * Rebuild.
  * Evacuate.
  * Shelve and unshelve.

* Unsupported operations

  * Resize.
  * Suspend and resume.
  * Cold migration.
  * Live migration.

.. versionchanged:: 22.0.0(Victoria)

   Added support for rebuild and evacuate operations.

.. versionchanged:: 23.0.0(Wallaby)

   Added support for shelve and unshelve operations.

Some operations, such as lock and unlock, work as they are effectively
no-ops for accelerators.

Caveats
-------

.. note::

   This information is correct as of the 21.0.0 Ussuri release. Where
   improvements have been made or issues fixed, they are noted per item.

For nested resource providers:

* Creating servers with accelerators provisioned with the Cyborg service, if
  a flavor asks for resources that are provided by nested Resource Provider
  inventories (e.g. vGPU) and the user wants multi-create (i.e. say --max 2)
  then the scheduler could be returning a NoValidHosts exception even if each
  nested Resource Provider can support at least one specific instance, if the
  total wanted capacity is not supported by only one nested Resource Provider.
  (See `bug 1874664 <https://bugs.launchpad.net/nova/+bug/1874664>`_.)

  For example, creating servers with accelerators provisioned with the Cyborg
  service, if two children RPs have 4 vGPU inventories each:

  * You can ask for a device profile in the flavor with 2 vGPU with --max 2.
  * But you can't ask for a device profile in the flavor with 4 vGPU and
    --max 2.

=======================
Using SRIOV with Cyborg
=======================

Starting from Xena release, nova supports creating servers with
SRIOV provisioned with the Cyborg service.

To launch servers with accelerators, the administrator (or an user with
appropriate privileges) must do the following:

* Create a device profile in Cyborg, which specifies what accelerator
  resources need to be provisioned. (See `Cyborg device profiles API`_,
  `Cyborg SRIOV Test Report`_.)

  .. _`Cyborg device profiles API`: https://docs.openstack.org/api-ref/accelerator/#device-profiles
  .. _`Cyborg SRIOV Test Report`: https://wiki.openstack.org/wiki/Cyborg/TestReport/IntelNic

* create a 'accelerator-direct' vnic type port with the device-profile name
  set as cyborg device profile with this syntax:

  .. code::

    openstack port create $port_name --network $network_name --vnic-type=accelerator-direct --device-profile $device_profile_name

* create a server with that port:

  .. code::

    openstack server create --flavor $myflavor --image $myimage $servername --nic port-id=$port-ID

Nova supports only specific operations for instances with accelerators.
The lists of supported and unsupported operations are as below:

* Supported operations.

  * Creation and deletion.
  * Reboots (soft and hard).
  * Pause and unpause.
  * Stop and start.
  * Rebuild.
  * Rescue and unrescue.
  * Take a snapshot.
  * Backup.

* Unsupported operations

  * Resize.
  * Suspend and resume.
  * Cold migration.
  * Live migration.
  * Shelve and unshelve.
  * Evacuate.
  * Attach/detach a port with device profile.