9

botoのec2.run_instances(...、user_data = USER_DATA)を介してユーザーデータをUbuntu 12.04 LTS AMI(ami-a29943cbですが、他のいくつかを試しましたが、役に立ちませんでした)にロードしようとしています。同様に、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

この点に関して誰かアドバイスはありますか?user-data / cloud-initの目的を完全に誤解しているのでしょうか、それとも、利用しようとしているAMIでテクノロジーが壊れているだけなのですか?

4

2 に答える 2

14

エラーメッセージなしで何が起こったのかを知るのは難しいですが、あなたが見ることができるいくつかの場所があります:

  1. ファイル/var/log/cloud-init.logには通常、インスタンスのブートストラップ中に発生したエラー(botoインポートの失敗など)が含まれます。
  2. ディレクトリ/var/lib/cloud/instanceには、インスタンスにダウンロードされた生のスクリプトとユーザーデータが含まれます
  3. インスタンスを右クリックして、AWSコンソール内でUSER_DATAを表​​示/編集し、botoが正しく設定されているかどうかを確認できます。

それらの場所を見ると、明確にするのに役立つはずです。

Ubuntu12.04にはboto2.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で実際にアクセスできるかどうか疑問に思います。

于 2012-05-24T22:40:28.373 に答える
1

クイックチェックリスト:

1)インスタンスにSSHで接続します。
2)実行cat/var/log/cloud-init-output.logて、素敵なテキストファイルにダンプします。
3)以下の構造を含む複数のブロックが表示されます。

Dependencies Resolved

================================================================================
 Package                    Arch      Version               Repository     Size
================================================================================
Installing:


Transaction Summary
================================================================================
Install  X Package (+Y Dependent packages)

各ブロックはuser data、EC2インスタンスに提供したものに従って作成されます(すべてのスクリプトはに保存されます/var/lib/cloud/instance/scripts)。

Failed4)、、、、などのキーワードを検索ErrorWARNINGます /var/lib/cloud/instance/scripts/

たとえば、以下のエラーの場合:

/var/lib/cloud/instance/scripts/part-001: line 10: vncpasswd: command not found
cp: cannot stat '/lib/systemd/system/vncserver@.service': No such file or directory
sed: can't read /etc/systemd/system/vncserver@.service: No such file or directory
Failed to execute operation: No such file or directory
Failed to start vncserver@:1.service: Unit not found.
Loaded plugins: extras_suggestions, langpacks, priorities, update-motd
Cleaning repos: amzn2-core amzn2extra-docker amzn2extra-epel

(*)ユーザーデータスクリプトの実行中にエラーが発生したことを通知する一般的なエラーメッセージの終わり/var/log/cloud-init-output.logまたは含まれているものをすばやく確認することもできます。/var/log/cloud-init.log

/var/log/cloud-init-output.log上記のエラーの終わり:

Is this ok [y/d/N]: Exiting on user command
Your transaction was saved, rerun it with:
 yum load-transaction /tmp/yum_save_tx.2020-08-31.15-14.VpTvV1.yumtx
Aug 31 15:14:00 cloud-init[3532]: util.py[WARNING]: Failed running /var/lib/cloud/instance/scripts/part-001 [1]
Aug 31 15:14:00 cloud-init[3532]: cc_scripts_user.py[WARNING]: Failed to run module scripts-user (scripts in /var/lib/cloud/instance/scripts)
Aug 31 15:14:00 cloud-init[3532]: util.py[WARNING]: Running module scripts-user (<module 'cloudinit.config.cc_scripts_user' from '/usr/lib/python2.7/site-packages/cloudinit/config/cc_scripts_user.pyc'>) failed
Cloud-init v. 19.3-3.amzn2 finished at Mon, 31 Aug 2020 15:14:00 +0000. Datasource DataSourceEc2.  Up 87.44 seconds

そしての終わり/var/log/cloud-init.log

Aug 31 15:14:00 cloud-init[3532]: util.py[DEBUG]: Failed running /var/lib/cloud/instance/scripts/part-001 [1]
    Traceback (most recent call last):
      File "/usr/lib/python2.7/site-packages/cloudinit/util.py", line 910, in runparts
        subp(prefix + [exe_path], capture=False, shell=True)
      File "/usr/lib/python2.7/site-packages/cloudinit/util.py", line 2105, in subp
        cmd=args)
    ProcessExecutionError: Unexpected error while running command.
    Command: ['/var/lib/cloud/instance/scripts/part-001']
    Exit code: 1
    Reason: -
    Stdout: -
    Stderr: -
    cc_scripts_user.py[WARNING]: Failed to run module scripts-user (scripts in /var/lib/cloud/instance/scripts)
于 2020-08-31T16:39:52.660 に答える