Como obter o ID de instância a partir de uma instância do EC2?
-
05-07-2019 - |
Pergunta
Como posso descobrir a instance id
de uma instância EC2 de dentro da instância do EC2?
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
#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.
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