Creating an OMI from a VM
You can create an OUTSCALE Machine Image (OMI) from a virtual machine (VM). The OMI is created with all data contained in the VM.
This action also creates a snapshot of the root volume of the VM, as well as a snapshot of each BSU volume attached to the VM. For more information, see About OMIs.
Creating an Image from a VM Using Cockpit
| Before you begin: 
 | 
| You can also do this action in the VMs dashboard, by hovering over the row of a VM and clicking the  | 
- 
In the Images dashboard, click Create Image. 
 The CREATE IMAGE dialog box appears.
- 
In the Name field, type a name for the image. This name must be unique and must contain between 3 and 128 characters. Allowed characters are a-z, A-Z, 0-9, spaces, and [_()/.-]. 
- 
(optional) In the Description field, type a description for the image. 
- 
Select From VM and select a VM from the VM selection list. You cannot create an image from a terminated VM. 
- 
(optional) To stop the VM before the creation of the image and then reboot it, switch on Reboot VM. 
- 
Click Create Image. 
 The image is created. The snapshots created for the image appear on the Snapshots dashboard.
Creating an OMI from a VM Using OSC CLI
| Before you begin: 
 | 
The CreateImage command creates an OUTSCALE machine image (OMI).
You can use this method for different use cases:
- 
Creating from a VM: You create an OMI from one of your virtual machines (VMs). 
- 
Copying an OMI: You copy an existing OMI. The source OMI can be one of your own OMIs, or an OMI owned by another account that has granted you permission via the UpdateImage method. 
- 
Registering from a snapshot: You register an OMI from an existing snapshot. The source snapshot can be one of your own snapshots, or a snapshot owned by another account that has granted you permission via the UpdateSnapshot method. 
- 
Registering from a bucket by using a manifest file: You register an OMI from the manifest file of an OMI that was exported to an OUTSCALE Object Storage (OOS) bucket. First, the owner of the source OMI must export it to the bucket by using the CreateImageExportTask method. Then, they must grant you permission to read the manifest file via a pre-signed URL. For more information, see Creating a Pre-Signed URL. 
| Registering from a bucket enables you to copy an OMI across Regions. For more information, see About OMIs. | 
$ osc-cli api CreateImage --profile "default" \
    --ImageName "create-image-example" \
    --VmId "i-12345678" \
    --NoReboot TrueThis command contains the following attributes that you need to specify:
- 
BootModes: (optional) The boot modes compatible with the OMI.
 Possible values:uefi|legacy.
- 
Description: (optional) A description for the new OMI.
- 
DryRun: (optional) If true, checks whether you have the required permissions to perform the action.
- 
ImageName: (optional) A unique name for the new OMI.
 Constraints: 3-128 alphanumeric characters, underscores (_), spaces (`), parentheses (()), slashes (/), periods (.), or dashes (-`).
- 
NoReboot: (optional) When creating from a VM: If false, the VM shuts down before creating the OMI and then reboots. If true, the VM does not.
- 
ProductCodes: (optional) The product codes associated with the OMI.
- 
TpmMandatory: (optional) By default or if set to false, a virtual Trusted Platform Module (vTPM) is not mandatory on VMs created from this OMI. If true, VMs created from this OMI must have a vTPM enabled.
- 
VmId: (optional) (required) When creating from a VM: The ID of the VM from which you want to create the OMI.
The CreateImage command returns the following elements:
- 
Image: Information about the OMI.- 
AccountAlias: The account alias of the owner of the OMI.
- 
AccountId: The account ID of the owner of the OMI.
- 
Architecture: The architecture of the OMI.
- 
BlockDeviceMappings: One or more block device mappings.- 
Bsu: Information about the BSU volume to create.- 
DeleteOnVmDeletion: If set to true, the volume is deleted when terminating the VM. If false, the volume is not deleted when terminating the VM.
 Default: true.
- 
Iops: The number of I/O operations per second (IOPS). This parameter must be specified only if you create anio1volume. The maximum number of IOPS allowed forio1volumes is13000with a maximum performance ratio of 300 IOPS per gibibyte.
- 
SnapshotId: The ID of the snapshot used to create the volume.
- 
VolumeSize: The size of the volume, in gibibytes (GiB).
 If you specify a snapshot ID, the volume size must be at least equal to the snapshot size.
 If you specify a snapshot ID but no volume size, the volume is created with a size similar to the snapshot one.
- 
VolumeType: The type of the volume (standard|io1|gp2). If not specified in the request, astandardvolume is created.
 For more information about volume types, see About Volumes > Volume Types and IOPS.
 
- 
- 
DeviceName: The device name for the volume. For a root device, you must use/dev/sda1. For other volumes, you must use/dev/sdX,/dev/sdXX,/dev/xvdX, or/dev/xvdXX(where the firstXis a letter betweenbandz, and the secondXis a letter betweenaandz).
- 
VirtualDeviceName: The name of the virtual device (ephemeralN).
 
- 
- 
BootModes: The boot modes compatible with the OMI.
 Possible values:uefi|legacy.
- 
CreationDate: The date and time (UTC) at which the OMI was created.
- 
Description: The description of the OMI.
- 
FileLocation: The location from which the OMI files were created.
- 
ImageId: The ID of the OMI.
- 
ImageName: The name of the OMI.
- 
ImageType: The type of the OMI.
- 
PermissionsToLaunch: Permissions for the resource.- 
AccountIds: One or more account IDs that the permission is associated with.
- 
GlobalPermission: A global permission for all accounts.
 (Request) Set this parameter to true to make the resource public (if the parent parameter isAdditions) or to make the resource private (if the parent parameter isRemovals).
 (Response) If true, the resource is public. If false, the resource is private.
 
- 
- 
ProductCodes: The product codes associated with the OMI.
- 
RootDeviceName: The name of the root device.
- 
RootDeviceType: The type of root device used by the OMI (alwaysbsu).
- 
SecureBoot: Whether secure boot is activated or not.
- 
State: The state of the OMI (pending|available|failed).
- 
StateComment: Information about the change of state.- 
StateCode: The code of the change of state.
- 
StateMessage: A message explaining the change of state.
 
- 
- 
Tags: One or more tags associated with the OMI.- 
Key: The key of the tag, with a minimum of 1 character.
- 
Value: The value of the tag, between 0 and 255 characters.
 
- 
- 
TpmMandatory: If true, a virtual Trusted Platform Module (vTPM) is mandatory for VMs created from this OMI. If false, a vTPM is not mandatory.
 
- 
- 
ResponseContext: Information about the context of the response.- 
RequestId: The ID of the request.
 
- 
{
  "ResponseContext": {
    "RequestId": "0475ca1e-d0c5-441d-712a-da55a4175157"
  },
  "Image": {
    "TpmMandatory": false,
    "StateComment": {},
    "State": "pending",
    "RootDeviceType": "bsu",
    "RootDeviceName": "/dev/sda1",
    "ProductCodes": [
      "0001"
    ],
    "PermissionsToLaunch": {
      "GlobalPermission": false,
      "AccountIds": []
    },
    "AccountId": "123456789012",
    "Tags": [],
    "Description": "",
    "ImageId": "ami-12345678",
    "BlockDeviceMappings": [
      {
        "DeviceName": "/dev/sda1",
        "Bsu": {
          "VolumeType": "standard",
          "DeleteOnVmDeletion": true,
          "VolumeSize": 50,
          "SnapshotId": "snap-12345678"
        }
      }
    ],
    "BootModes": [
      "legacy"
    ],
    "SecureBoot": false,
    "ImageType": "machine",
    "CreationDate": "2010-10-01T12:34:56.789Z",
    "FileLocation": "123456789012/create-image-example",
    "Architecture": "x86_64",
    "ImageName": "create-image-example"
  }
}Creating an OMI from a VM Using oapi-cli
| Before you begin: 
 | 
The CreateImage command creates an OUTSCALE machine image (OMI).
You can use this method for different use cases:
- 
Creating from a VM: You create an OMI from one of your virtual machines (VMs). 
- 
Copying an OMI: You copy an existing OMI. The source OMI can be one of your own OMIs, or an OMI owned by another account that has granted you permission via the UpdateImage method. 
- 
Registering from a snapshot: You register an OMI from an existing snapshot. The source snapshot can be one of your own snapshots, or a snapshot owned by another account that has granted you permission via the UpdateSnapshot method. 
- 
Registering from a bucket by using a manifest file: You register an OMI from the manifest file of an OMI that was exported to an OUTSCALE Object Storage (OOS) bucket. First, the owner of the source OMI must export it to the bucket by using the CreateImageExportTask method. Then, they must grant you permission to read the manifest file via a pre-signed URL. For more information, see Creating a Pre-Signed URL. 
| Registering from a bucket enables you to copy an OMI across Regions. For more information, see About OMIs. | 
$ oapi-cli --profile "default" CreateImage \
    --ImageName "create-image-example" \
    --VmId "i-12345678" \
    --NoReboot trueThis command contains the following attributes that you need to specify:
- 
BootModes: (optional) The boot modes compatible with the OMI.
 Possible values:uefi|legacy.
- 
Description: (optional) A description for the new OMI.
- 
DryRun: (optional) If true, checks whether you have the required permissions to perform the action.
- 
ImageName: (optional) A unique name for the new OMI.
 Constraints: 3-128 alphanumeric characters, underscores (_), spaces (`), parentheses (()), slashes (/), periods (.), or dashes (-`).
- 
NoReboot: (optional) When creating from a VM: If false, the VM shuts down before creating the OMI and then reboots. If true, the VM does not.
- 
ProductCodes: (optional) The product codes associated with the OMI.
- 
TpmMandatory: (optional) By default or if set to false, a virtual Trusted Platform Module (vTPM) is not mandatory on VMs created from this OMI. If true, VMs created from this OMI must have a vTPM enabled.
- 
VmId: (optional) (required) When creating from a VM: The ID of the VM from which you want to create the OMI.
The CreateImage command returns the following elements:
- 
Image: Information about the OMI.- 
AccountAlias: The account alias of the owner of the OMI.
- 
AccountId: The account ID of the owner of the OMI.
- 
Architecture: The architecture of the OMI.
- 
BlockDeviceMappings: One or more block device mappings.- 
Bsu: Information about the BSU volume to create.- 
DeleteOnVmDeletion: If set to true, the volume is deleted when terminating the VM. If false, the volume is not deleted when terminating the VM.
 Default: true.
- 
Iops: The number of I/O operations per second (IOPS). This parameter must be specified only if you create anio1volume. The maximum number of IOPS allowed forio1volumes is13000with a maximum performance ratio of 300 IOPS per gibibyte.
- 
SnapshotId: The ID of the snapshot used to create the volume.
- 
VolumeSize: The size of the volume, in gibibytes (GiB).
 If you specify a snapshot ID, the volume size must be at least equal to the snapshot size.
 If you specify a snapshot ID but no volume size, the volume is created with a size similar to the snapshot one.
- 
VolumeType: The type of the volume (standard|io1|gp2). If not specified in the request, astandardvolume is created.
 For more information about volume types, see About Volumes > Volume Types and IOPS.
 
- 
- 
DeviceName: The device name for the volume. For a root device, you must use/dev/sda1. For other volumes, you must use/dev/sdX,/dev/sdXX,/dev/xvdX, or/dev/xvdXX(where the firstXis a letter betweenbandz, and the secondXis a letter betweenaandz).
- 
VirtualDeviceName: The name of the virtual device (ephemeralN).
 
- 
- 
BootModes: The boot modes compatible with the OMI.
 Possible values:uefi|legacy.
- 
CreationDate: The date and time (UTC) at which the OMI was created.
- 
Description: The description of the OMI.
- 
FileLocation: The location from which the OMI files were created.
- 
ImageId: The ID of the OMI.
- 
ImageName: The name of the OMI.
- 
ImageType: The type of the OMI.
- 
PermissionsToLaunch: Permissions for the resource.- 
AccountIds: One or more account IDs that the permission is associated with.
- 
GlobalPermission: A global permission for all accounts.
 (Request) Set this parameter to true to make the resource public (if the parent parameter isAdditions) or to make the resource private (if the parent parameter isRemovals).
 (Response) If true, the resource is public. If false, the resource is private.
 
- 
- 
ProductCodes: The product codes associated with the OMI.
- 
RootDeviceName: The name of the root device.
- 
RootDeviceType: The type of root device used by the OMI (alwaysbsu).
- 
SecureBoot: Whether secure boot is activated or not.
- 
State: The state of the OMI (pending|available|failed).
- 
StateComment: Information about the change of state.- 
StateCode: The code of the change of state.
- 
StateMessage: A message explaining the change of state.
 
- 
- 
Tags: One or more tags associated with the OMI.- 
Key: The key of the tag, with a minimum of 1 character.
- 
Value: The value of the tag, between 0 and 255 characters.
 
- 
- 
TpmMandatory: If true, a virtual Trusted Platform Module (vTPM) is mandatory for VMs created from this OMI. If false, a vTPM is not mandatory.
 
- 
- 
ResponseContext: Information about the context of the response.- 
RequestId: The ID of the request.
 
- 
{
  "ResponseContext": {
    "RequestId": "0475ca1e-d0c5-441d-712a-da55a4175157"
  },
  "Image": {
    "TpmMandatory": false,
    "StateComment": {},
    "State": "pending",
    "RootDeviceType": "bsu",
    "RootDeviceName": "/dev/sda1",
    "ProductCodes": [
      "0001"
    ],
    "PermissionsToLaunch": {
      "GlobalPermission": false,
      "AccountIds": []
    },
    "AccountId": "123456789012",
    "Tags": [],
    "Description": "",
    "ImageId": "ami-12345678",
    "BlockDeviceMappings": [
      {
        "DeviceName": "/dev/sda1",
        "Bsu": {
          "VolumeType": "standard",
          "DeleteOnVmDeletion": true,
          "VolumeSize": 50,
          "SnapshotId": "snap-12345678"
        }
      }
    ],
    "BootModes": [
      "legacy"
    ],
    "SecureBoot": false,
    "ImageType": "machine",
    "CreationDate": "2010-10-01T12:34:56.789Z",
    "FileLocation": "123456789012/create-image-example",
    "Architecture": "x86_64",
    "ImageName": "create-image-example"
  }
}Creating an OMI from an Instance Using AWS CLI
| Before you begin: 
 | 
To create an OMI, use the create-image command following this syntax:
$ aws ec2 create-image \
    --profile YOUR_PROFILE \
    --instance-id i-12345678 \
    --name OMI_NAME \
    --description OMI_DESCRIPTION \
    --no-reboot \
    --block-device-mappings BLOCK_DEVICE_MAPPING \
    --endpoint https://fcu.eu-west-2.outscale.comThis command contains the following options that you need to specify:
- 
(optional) profile: The named profile you want to use, created when configuring AWS CLI. For more information, see Installing and Configuring AWS CLI.
- 
instance-id: The ID of the instance from which you want to create the OMI.
- 
name: The name of the OMI.This name must be unique and must contain between 3 and 128 characters. Allowed characters are a-z, A-Z, 0-9, spaces, and [_()/.-]. 
- 
(optional) description: A description for the OMI.This description can contain any Unicode character, with no length limit. 
- 
(optional) reboot|no-reboot: By default or if set toreboot, the instance is stopped before the creation of the OMI, and then is restarted. If set tono-reboot, the instance is not stopped before the creation of the OMI.
- 
(optional) block-device-mappings: One or more block device mappings. For more information, see Defining Block Device Mappings.
- 
endpoint: The endpoint corresponding to the Region you want to send the request to. For more information, see Installing and Configuring AWS CLI.
The create-image command returns the following element:
- 
ImageId: The ID of the newly created OMI.
{
    "ImageId": "ami-12345678"
}The new OMI is created from the specified instance.
Related Pages
Corresponding API Methods
AWS™ and Amazon Web Services™ are trademarks of Amazon Technologies, Inc or its affiliates in the United States and/or other countries.