TL;DR
--query pour restreindre à la dernière--filters sont susceptibles de différer selon le système d'exploitation, je vais donc les résumer.describe-images
Utilisez la commande describe-images de l'AWS CLI.
$ aws ec2 describe-images \
  --region [region] \
  --query '[query]' \
  --owners [owner] \
  --filters '[condition]' \
  --output [output]
L'intérieur de «[]» est modifié selon les conditions. Cette fois, nous irons plus bas.
--region … ap-northeast-1--query … reverse(sort_by(Images, &CreationDate))[0]--owners… Modifié en fonction de l'AMI à rechercher--filters… Modifié en fonction de l'AMI à rechercher--output … tablePour les «propriétaires», choisissez «amazon», «aws-marketplace »et« microsoft ». S'il n'est pas spécifié, la recherche sera effectuée sur toutes les AMI que vous pouvez utiliser.
--owners (list)
Filters the images by the owner. Specify an AWS account ID, self (owner is the sender of the request), or an AWS owner alias (valid values are amazon | aws-marketplace | microsoft ). Omitting this option returns all images for which you have launch permissions, regardless of ownership.
Par exemple.
$ aws ec2 describe-images \
  --region ap-northeast-1 \
  --query 'reverse(sort_by(Images, &CreationDate))[:1]' \
  --owners amazon \
  --filters 'Name=name,Values=amzn2-ami-hvm-2.0.*-x86_64-gp2' \
  --output table
----------------------------------------------------------------------------
|                              DescribeImages                              |
+---------------------+----------------------------------------------------+
|  Architecture       |  x86_64                                            |
|  CreationDate       |  2019-12-18T01:33:12.000Z                          |
|  Description        |  Amazon Linux 2 AMI 2.0.20191217.0 x86_64 HVM gp2  |
|  EnaSupport         |  True                                              |
|  Hypervisor         |  xen                                               |
|  ImageId            |  ami-011facbea5ec0363b                             |
|  ImageLocation      |  amazon/amzn2-ami-hvm-2.0.20191217.0-x86_64-gp2    |
|  ImageOwnerAlias    |  amazon                                            |
|  ImageType          |  machine                                           |
|  Name               |  amzn2-ami-hvm-2.0.20191217.0-x86_64-gp2           |
|  OwnerId            |  137112412989                                      |
|  Public             |  True                                              |
|  RootDeviceName     |  /dev/xvda                                         |
|  RootDeviceType     |  ebs                                               |
|  SriovNetSupport    |  simple                                            |
|  State              |  available                                         |
|  VirtualizationType |  hvm                                               |
+---------------------+----------------------------------------------------+
||                           BlockDeviceMappings                          ||
|+------------------------------------+-----------------------------------+|
||  DeviceName                        |  /dev/xvda                        ||
|+------------------------------------+-----------------------------------+|
|||                                  Ebs                                 |||
||+--------------------------------+-------------------------------------+||
|||  DeleteOnTermination           |  True                               |||
|||  Encrypted                     |  False                              |||
|||  SnapshotId                    |  snap-0ffc2bf377f23be03             |||
|||  VolumeSize                    |  8                                  |||
|||  VolumeType                    |  gp2                                |||
||+--------------------------------+-------------------------------------+||
Au fait, si vous ne voulez que l'ID AMI, vous pouvez définir --query sur reverse (sort_by (Images, & CreationDate)) [0]. [ImageId].
Ensuite, à partir d'ici, j'écrirai la méthode de recherche pour chaque OS.
Avec --filters, spécifiez les informations dans l'AMI ( Nom) et ce qu'il faut rechercher (Values).
Au fait, il semble que «*» et «?» Peuvent être utilisés comme caractères génériques pour «--filters».
You can also use wildcards with the filter values. An asterisk (*) matches zero or more characters, and a question mark (?) matches zero or one character.
Listing and Filtering Using the CLI and API
Amazon Linux 2
Affinez par «nom». ʻOwners est ʻamazon.
$ aws ec2 describe-images \
  --region ap-northeast-1 \
  --query 'reverse(sort_by(Images, &CreationDate))[:1]' \
  --owners amazon \
  --filters 'Name=name,Values=amzn2-ami-hvm-2.0.*-x86_64-gp2' \
  --output table
Amazon Linux
Comme avec Amazon Linux 2, affinez par «nom». ʻOwners est ʻamazon.
$ aws ec2 describe-images \
  --region ap-northeast-1 \
  --query 'reverse(sort_by(Images, &CreationDate))[:1]' \
  --owners amazon \
  --filters 'Name=name,Values=amzn-ami-hvm-*-x86_64-gp2' \
  --output table
CentOS 7
Utilisez product-code pour affiner comme décrit dans le Wiki CentOS. «Propriétaires» est «un marché de lois».
$ aws ec2 describe-images \
  --query 'reverse(sort_by(Images, &CreationDate))[:1]' \
  --owners aws-marketplace \
  --filters 'Name=product-code,Values=aw0evgkw8e5c1q413zgy5pjce' \
  --output table
Ubuntu Server 18.04 LTS
Affinez par «nom». «Propriétaires» est «099720109477».
$ aws ec2 describe-images \
  --region ap-northeast-1 \
  --owners 099720109477 \
  --query 'reverse(sort_by(Images, &CreationDate))[:1]' \
  --filters 'Name=name,Values=ubuntu/images/hvm-ssd/ubuntu-bionic-18.04-amd64-server-*' \
  --output table
        Recommended Posts