Ubuntu的AMI不加载用户数据(Ubuntu AMI not loading user-data

2019-07-29 13:22发布

我试图将用户数据加载到一个Ubuntu 12.04 LTS AMI(AMI-a29943cb,但我已经尝试了其他几个人没有用),通过伯特的ec2.run_instances(...,USER_DATA = USER_DATA)。 同样,我曾与同时通过AWS控制台启动实例手动提供用户数据没有成功。 有没有结果或消息在/ var /日志/ 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

有没有人在这方面有什么建议吗? 难道我完全误解的用户数据/宗旨云init或在技术仅仅停留在AMI我想利用坏了吗?

Answer 1:

很难知道发生了什么没有一条错误信息,但也有一些地方,你可以看看:

  1. 该文件/var/log/cloud-init.log通常将包含实例引导过程中发生任何错误(例如博托导入失败)。
  2. 该目录/var/lib/cloud/instance包含下载到该实例的原始脚本和用户数据
  3. 您可以通过右键单击该实例,看看是否博托正确填充它查看/编辑USER_DATA的AWS控制台中。

看在那些地方应该帮助提供清晰。

我知道Ubuntu的12.04自带博托2.2.2:

root@vanilla-562c:/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 AMI not loading user-data