Pergunta

Como posso descobrir a instance id de uma instância EC2 de dentro da instância do EC2?

Foi útil?

Solução

Consulte a documentação EC2 sobre o assunto .

Executar:

wget -q -O - http://169.254.169.254/latest/meta-data/instance-id

Se você precisa de acesso programático para a identificação de instância partir de um script,

die() { status=$1; shift; echo "FATAL: $*"; exit $status; }
EC2_INSTANCE_ID="`wget -q -O - http://169.254.169.254/latest/meta-data/instance-id || die \"wget instance-id has failed: $?\"`"

Um exemplo de um uso mais avançado (recuperar exemplo ID, bem como zona de disponibilidade e região, etc.):

EC2_INSTANCE_ID="`wget -q -O - http://169.254.169.254/latest/meta-data/instance-id || die \"wget instance-id has failed: $?\"`"
test -n "$EC2_INSTANCE_ID" || die 'cannot obtain instance-id'
EC2_AVAIL_ZONE="`wget -q -O - http://169.254.169.254/latest/meta-data/placement/availability-zone || die \"wget availability-zone has failed: $?\"`"
test -n "$EC2_AVAIL_ZONE" || die 'cannot obtain availability-zone'
EC2_REGION="`echo \"$EC2_AVAIL_ZONE\" | sed -e 's:\([0-9][0-9]*\)[a-z]*\$:\\1:'`"

Você também pode usar curl vez de wget, dependendo do que estiver instalado em sua plataforma.

Outras dicas

Na Amazon Linux AMIs você pode fazer:

$ ec2-metadata -i
instance-id: i-1234567890abcdef0

Ou, no Ubuntu e alguns outros sabores de Linux, ec2metadata --instance-id (Este comando não pode ser instalado por padrão no Ubuntu, mas você pode adicioná-lo com sudo apt-get install cloud-utils)

Como o próprio nome sugere, você pode usar o comando para obter outros metadados útil também.

No Ubuntu você pode:

sudo apt-get install cloud-utils

E, em seguida, você pode:

EC2_INSTANCE_ID=$(ec2metadata --instance-id)

Você pode obter a maioria dos metadados associados à instância desta maneira:

ec2metadata --help
Syntax: /usr/bin/ec2metadata [options]

Query and display EC2 metadata.

If no options are provided, all options will be displayed

Options:
    -h --help               show this help

    --kernel-id             display the kernel id
    --ramdisk-id            display the ramdisk id
    --reservation-id        display the reservation id

    --ami-id                display the ami id
    --ami-launch-index      display the ami launch index
    --ami-manifest-path     display the ami manifest path
    --ancestor-ami-ids      display the ami ancestor id
    --product-codes         display the ami associated product codes
    --availability-zone     display the ami placement zone

    --instance-id           display the instance id
    --instance-type         display the instance type

    --local-hostname        display the local hostname
    --public-hostname       display the public hostname

    --local-ipv4            display the local ipv4 ip address
    --public-ipv4           display the public ipv4 ip address

    --block-device-mapping  display the block device id
    --security-groups       display the security groups

    --mac                   display the instance mac address
    --profile               display the instance profile
    --instance-action       display the instance-action

    --public-keys           display the openssh public keys
    --user-data             display the user data (not actually metadata)

Use o URL /dynamic/instance-identity/document se você também precisa de consulta mais do que apenas sua instância ID.

wget -q -O - http://169.254.169.254/latest/dynamic/instance-identity/document

Isto fará você JSON de dados como este -., Com apenas um único pedido

{
    "devpayProductCodes" : null,
    "privateIp" : "10.1.2.3",
    "region" : "us-east-1",
    "kernelId" : "aki-12345678",
    "ramdiskId" : null,
    "availabilityZone" : "us-east-1a",
    "accountId" : "123456789abc",
    "version" : "2010-08-31",
    "instanceId" : "i-12345678",
    "billingProducts" : null,
    "architecture" : "x86_64",
    "imageId" : "ami-12345678",
    "pendingTime" : "2014-01-23T45:01:23Z",
    "instanceType" : "m1.small"
}

Para .NET Pessoas:

string instanceId = new StreamReader(
      HttpWebRequest.Create("http://169.254.169.254/latest/meta-data/instance-id")
      .GetResponse().GetResponseStream())
    .ReadToEnd();

na AWS Linux:

ec2-metadata --instance-id | cut -d " " -f 2

Output:

i-33400429

Usando nas variáveis:

ec2InstanceId=$(ec2-metadata --instance-id | cut -d " " -f 2);
ls "log/${ec2InstanceId}/";

Para Python:

import boto.utils
region=boto.utils.get_instance_metadata()['local-hostname'].split('.')[1]

que se resume ao one-liner:

python -c "import boto.utils; print boto.utils.get_instance_metadata()['local-hostname'].split('.')[1]"

Em vez de local_hostname você também pode usar public_hostname, ou:

boto.utils.get_instance_metadata()['placement']['availability-zone'][:-1]

Para PowerShell pessoas:

(New-Object System.Net.WebClient).DownloadString("http://169.254.169.254/latest/meta-data/instance-id")

este pós -. Note que o endereço IP na URL dado é constante (o que me confuso no início), mas os dados retornados é específico para a instância

Uma solução mais contemporânea.

De Amazon Linux o comando ec2-metadados estiver instalado.

Do terminal

ec2-metadata -help

Vamos dar-lhe as opções disponíveis

ec2-metadata -i

retornará

instance-id: yourid

Apenas Tipo:

ec2metadata --instance-id

Para todas as máquinas EC2, a instância-id pode ser encontrado no arquivo:

    /var/lib/cloud/data/instance-id

Você também pode obter instância ID, executando o seguinte comando:

    ec2metadata --instance-id

Você pode tentar o seguinte:

#!/bin/bash
aws_instance=$(wget -q -O- http://169.254.169.254/latest/meta-data/instance-id)
aws_region=$(wget -q -O- http://169.254.169.254/latest/meta-data/hostname)
aws_region=${aws_region#*.}
aws_region=${aws_region%%.*}
aws_zone=`ec2-describe-instances $aws_instance --region $aws_region`
aws_zone=`expr match "$aws_zone" ".*\($aws_region[a-z]\)"`

Para Ruby:

require 'rubygems'
require 'aws-sdk'
require 'net/http'

metadata_endpoint = 'http://169.254.169.254/latest/meta-data/'
instance_id = Net::HTTP.get( URI.parse( metadata_endpoint + 'instance-id' ) )

ec2 = AWS::EC2.new()
instance = ec2.instances[instance_id]

A C # .NET classe que escrevi para EC2 metadados a partir da API http. I vai construí-la com a funcionalidade conforme necessário. Você pode correr com ele se você gosta dela.

using Amazon;
using System.Net;

namespace AT.AWS
{
    public static class HttpMetaDataAPI
    {
        public static bool TryGetPublicIP(out string publicIP)
        {
            return TryGetMetaData("public-ipv4", out publicIP);
        }
        public static bool TryGetPrivateIP(out string privateIP)
        {
            return TryGetMetaData("local-ipv4", out privateIP);
        }
        public static bool TryGetAvailabilityZone(out string availabilityZone)
        {
            return TryGetMetaData("placement/availability-zone", out availabilityZone);
        }

        /// <summary>
        /// Gets the url of a given AWS service, according to the name of the required service and the AWS Region that this machine is in
        /// </summary>
        /// <param name="serviceName">The service we are seeking (such as ec2, rds etc)</param>
        /// <remarks>Each AWS service has a different endpoint url for each region</remarks>
        /// <returns>True if the operation was succesful, otherwise false</returns>
        public static bool TryGetServiceEndpointUrl(string serviceName, out string serviceEndpointStringUrl)
        {
            // start by figuring out what region this instance is in.
            RegionEndpoint endpoint;
            if (TryGetRegionEndpoint(out endpoint))
            {
                // now that we know the region, we can get details about the requested service in that region
                var details = endpoint.GetEndpointForService(serviceName);
                serviceEndpointStringUrl = (details.HTTPS ? "https://" : "http://") + details.Hostname;
                return true;
            }
            // satisfy the compiler by assigning a value to serviceEndpointStringUrl
            serviceEndpointStringUrl = null;
            return false;
        }
        public static bool TryGetRegionEndpoint(out RegionEndpoint endpoint)
        {
            // we can get figure out the region end point from the availability zone
            // that this instance is in, so we start by getting the availability zone:
            string availabilityZone;
            if (TryGetAvailabilityZone(out availabilityZone))
            {
                // name of the availability zone is <nameOfRegionEndpoint>[a|b|c etc]
                // so just take the name of the availability zone and chop off the last letter
                var nameOfRegionEndpoint = availabilityZone.Substring(0, availabilityZone.Length - 1);
                endpoint = RegionEndpoint.GetBySystemName(nameOfRegionEndpoint);
                return true;
            }
            // satisfy the compiler by assigning a value to endpoint
            endpoint = RegionEndpoint.USWest2;
            return false;
        }
        /// <summary>
        /// Downloads instance metadata
        /// </summary>
        /// <returns>True if the operation was successful, false otherwise</returns>
        /// <remarks>The operation will be unsuccessful if the machine running this code is not an AWS EC2 machine.</remarks>
        static bool TryGetMetaData(string name, out string result)
        {
            result = null;
            try { result = new WebClient().DownloadString("http://169.254.169.254/latest/meta-data/" + name); return true; }
            catch { return false; }
        }

/************************************************************
 * MetaData keys.
 *   Use these keys to write more functions as you need them
 * **********************************************************
ami-id
ami-launch-index
ami-manifest-path
block-device-mapping/
hostname
instance-action
instance-id
instance-type
local-hostname
local-ipv4
mac
metrics/
network/
placement/
profile
public-hostname
public-ipv4
public-keys/
reservation-id
security-groups
*************************************************************/
    }
}

O mais recente Java SDK tem EC2MetadataUtils:

Em Java:

import com.amazonaws.util.EC2MetadataUtils;
String myId = EC2MetadataUtils.getInstanceId();

Em Scala:

import com.amazonaws.util.EC2MetadataUtils
val myid = EC2MetadataUtils.getInstanceId

Para C ++ (usando curl):

    #include <curl/curl.h>

    //// cURL to string
    size_t curl_to_str(void *contents, size_t size, size_t nmemb, void *userp) {
        ((std::string*)userp)->append((char*)contents, size * nmemb);
        return size * nmemb;
    };

    //// Read Instance-id 
    curl_global_init(CURL_GLOBAL_ALL); // Initialize cURL
    CURL *curl; // cURL handler
    CURLcode res_code; // Result
    string response;
    curl = curl_easy_init(); // Initialize handler
    curl_easy_setopt(curl, CURLOPT_URL, "http://169.254.169.254/latest/meta-data/instance-id");
    curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, curl_to_str);
    curl_easy_setopt(curl, CURLOPT_WRITEDATA, &response);
    res_code = curl_easy_perform(curl); // Perform cURL
    if (res_code != CURLE_OK) { }; // Error
    curl_easy_cleanup(curl); // Cleanup handler
    curl_global_cleanup(); // Cleanup cURL

Se você deseja obter a lista de todos disponíveis instância id usando python aqui está o código:

import boto3

ec2=boto3.client('ec2')
instance_information = ec2.describe_instances()

for reservation in instance_information['Reservations']:
   for instance in reservation['Instances']:
      print(instance['InstanceId'])

FWIW eu escrevi um sistema de arquivos FUSE para fornecer acesso ao serviço de metadados EC2: https://bitbucket.org/dgc / ec2mdfs . Eu corro este em todas as AMIs personalizados; permite-me usar esta expressão: cat / ec2 / meta-dados / ami-id

Em Go você pode usar o goamz pacote .

import (
    "github.com/mitchellh/goamz/aws"
    "log"
)

func getId() (id string) {
    idBytes, err := aws.GetMetaData("instance-id")
    if err != nil {
        log.Fatalf("Error getting instance-id: %v.", err)
    }

    id = string(idBytes)

    return id
}

Aqui está a fonte GetMetadata.

Basta verificar o link simbólico var/lib/cloud/instance, ele deve apontar para /var/lib/cloud/instances/{instance-id} onde {instance_id} é a instância-id.

Você pode apenas fazer uma solicitação HTTP para obter qualquer Metadados passando os seus parâmetros de metadados.

curl http://169.254.169.254/latest/meta-data/instance-id

ou

wget -q -O - http://169.254.169.254/latest/meta-data/instance-id

Você não será cobrado para solicitações HTTP para obter metadados e Userdata.

Else

Você pode usar o EC2 instância de metadados ferramenta de consulta que é um script simples que usa curl para consulta a instância EC2 metadados a partir de uma instância do EC2 em execução conforme mencionado na documentação.

Baixe a ferramenta:

$ wget http://s3.amazonaws.com/ec2metadata/ec2-metadata

comando agora correm para obter os dados necessários.

$ec2metadata -i

Consulte:

http://docs.aws.amazon .com / AWSEC2 / latest / UserGuide / ec2-instance-metadata.html

https://aws.amazon.com/items/1825?externalID=1825

feliz em ajudar ..:)

Na questão que você mencionou o usuário como root, uma coisa que eu devo mencionar é que a identificação de instância não é dependente do usuário.

Para Node desenvolvedores,

var meta  = new AWS.MetadataService();

meta.request("/latest/meta-data/instance-id", function(err, data){
    console.log(data);
});

abordagem alternativa para PHP:

$instance = json_decode(file_get_contents('http://169.254.169.254/latest/dynamic/instance-identity/document'),true);
$id = $instance['instanceId'];
print_r($instance);

Isso irá fornecer uma série de dados sobre a instância, todos muito bem embalados em uma matriz, sem dependências externas. Como é um pedido que nunca falhava ou atrasada para mim ele deve ser seguro fazê-lo dessa maneira, caso contrário eu iria para onda ()

Para PHP:

$instance = json_decode(file_get_contents('http://169.254.169.254/latest/dynamic/instance-identity/document));
$id = $instance['instanceId'];

Editar per @ John

Executar este:

curl http://169.254.169.254/latest/meta-data/

Você será capaz de ver diferentes tipos de atributos que são fornecidos por aws.

Use este link para ver mais

Todos os meta-dados relacionados com EC2 recurso pode ser acessado pela própria instância EC2 com a ajuda do seguinte comando a ser executado:

CURL:

http://169.254.169.254/<api-version>/meta-data/<metadata-requested>

Para o seu caso: " solicitado-metadados " deve ser instance-id , " api-version " é geralmente mais recente que pode ser usado.

Nota adicional:. Você também pode obter informações relacionadas a seguir atribui EC2 usando o comando acima

ami-id, ami-lançamento-índice, ami-manifesta-caminho, bloco do dispositivo de mapeamento /, nome de anfitrião, eu sou/, instância-ação, instance-id, exemplo do tipo, locais-hostname, Local-ipv4, Mac, Métricas/, rede/, colocação /, perfil, público-hostname, público-ipv4, -chaves públicas /, reserva-id, segurança-grupos, serviços /,

Para mais informações siga este link: https : //docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-instance-metadata.html

Para obter o uso instância de metadados

wget -q -O - http://169.254.169.254/latest/meta-data/instance-id

Para uma instância do Windows:

(wget http://169.254.169.254/latest/meta-data/instance-id).Content

ou

(ConvertFrom-Json (wget http://169.254.169.254/latest/dynamic/instance-identity/document).Content).instanceId

Para AWS Elastic Beanstalk eb CLI executar eb tags --list

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top