Вопрос по python, ubuntu, amazon-ec2 – Ubuntu AMI не загружает пользовательские данные

8

Я пытаюсь загрузить пользовательские данные в Ubuntu 12.04 LTS AMI (ami-a29943cb, но я пробовал несколько других безрезультатно) через boto ec2.run_instances (..., user_data = USER_DATA). Точно так же я не добился успеха при ручной подаче пользовательских данных при запуске экземпляров через консоль AWS. Нет результатов или сообщений в / var / logs / syslog ни для одного из методов, которые я пробовал.

USER_DATA выглядит примерно так, читается как строка из файла:

#!/usr/bin/env python

import boto

AWS_BOOTSTRAP_BUCKET  = ''
AWS_ACCESS_KEY_ID     = ''
AWS_SECRET_ACCESS_KEY = ''

# Pull processing script from S3.
print 'Bootstrapping started.....'
print 'Connecting to S3...'
s3     = boto.connect_s3(AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY)
bucket = s3.get_bucket(AWS_BOOTSTRAP_BUCKET)
print 'Downloading bootstrap file...'
key    = bucket.get_key('xxx')
key.get_contents_to_filename('xxx')

print 'Importing Bootstrap file...'
import xxx
xxx.process()

# Shut down the EC2 instance running this process.
print 'Shutting down this instance...'
import socket
desired_hostname = socket.gethostname()
ec2 = boto.connect_ec2(AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY)
reservations = ec2.get_all_instances()
for reservation in reservations:
    for instance in reservation.instances:
        if desired_hostname in instance.private_dns_name:
            instance.terminate()

Кроме того, я попытался загрузить файл в общедоступную корзину S3 и загрузить его таким образом, еще раз безрезультатно:

#include
https://s3.amazonaws.com/bucket/file.py

У кого-нибудь есть какие-либо советы на этот счет? Полностью ли я неправильно понимаю назначение пользовательских данных / облачного запуска или технология просто сломана в AMI, который я пытаюсь использовать?

Вы пробовали это?Tip: If you add set -x at the top of a bash script, then it will output every command executed. If you add set -e to the script, then the user-data script will exit on the first command which does not succeed. These help you quickly identify where problems might have started. source Daan

Ваш Ответ

1   ответ
12

Трудно понять, что произошло без сообщения об ошибке, но есть несколько мест, которые вы можете посмотреть:

  1. The file /var/log/cloud-init.log will usually contain any errors (e.g. boto import failure) that occurred during instance bootstrapping.
  2. The directory /var/lib/cloud/instance will contain the raw scripts and user-data downloaded to the instance
  3. You can View/Edit USER_DATA inside the AWS console by right-clicking the instance, to see if boto populated it correctly.

Поиск в этих местах должен помочь обеспечить ясность.

Я знаю, Ubuntu 12.04 поставляется с Boto 2.2.2:

[email protected]:/var/lib/cloud/instance# python
Python 2.7.3 (default, Apr 20 2012, 22:44:07) 
[GCC 4.6.3] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import boto
>>> boto.__version__
'2.2.2'

... но мне интересно, действительно ли он доступен в вашей PYTHONPATH во время выполнения.

В моем случае на Ubuntu 16 LTS /var/log/cloud-init-output.log дал мне дополнительную информацию, чтобы решить мою проблему с пользовательскими данными, выполняющими сценарии загрузки.
Спасибо за замечательный совет. Это наверняка будет бесценным для будущих разработчиков. Моя проблема заключалась в том, что Ubuntu AMI по какой-то причине не загружал никаких пользовательских данных. Однако AMI Amazon загрузили данные правильно. kfr2
Я склонен в сторону Ubuntu по сравнению с дистрибутивами на основе Redhat, такими как Amazon AMI (лучшие пакеты, наследие Debian и т. Д.), Но каждому свое. Важно то, что у вас это работает! :)

Похожие вопросы