Я создаю шаблон облачной информации, который создает некоторые ресурсы в качестве экземпляра EC2, autoscaling group
и launchConfiguration
. По userData
свойству launchConfiguration
ресурса, я попытался установить Cloudwatch agent
следующим образом:Не удается установить агент облачной погоды по облачной информации на Amazon ECS-оптимизированный AMI
"UserData":{ "Fn::Base64" : {
"Fn::Join" : ["", [
"#!/bin/bash -xe\n",
"yum -y install aws-cfn-bootstrap\n",
"/opt/aws/bin/cfn-init -v",
" --stack ", { "Ref": "AWS::StackName" },
" --resource LaunchCongig",
" --region ", { "Ref" : "AWS::Region" },"\n",
"yum -y install wget\n",
"# Get the CloudWatch Logs agent\n",
"wget https://s3.amazonaws.com/aws-cloudwatch/downloads/latest/awslogs-agent-setup.py\n",
"# Install the CloudWatch Logs agent\n",
"python ./awslogs-agent-setup.py -n -r ", { "Ref" : "AWS::Region" }, " -c /etc/cwlogs.cfg || error_exit 'Failed to run CloudWatch Logs agent setup'\n",
"service awslogs start"
]]}
После SSH в случае, я проверил файл /var/log/cloud-init-output.log
, чтобы увидеть, если все в порядке, но вот то, что я получил :
+ wget https://s3.amazonaws.com/aws-cloudwatch/downloads/latest/awslogs-agent-setup.py
--2017-02-17 14:36:10-- https://s3.amazonaws.com/aws-cloudwatch/downloads/latest/awslogs-agent-setup.py
Resolving s3.amazonaws.com (s3.amazonaws.com)... 52.216.226.59
Connecting to s3.amazonaws.com (s3.amazonaws.com)|52.216.226.59|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 47998 (47K) [text/x-python]
Saving to: ‘awslogs-agent-setup.py’
0K .......... .......... .......... .......... ...... 100% 196K=0.2s
2017-02-17 14:36:10 (196 KB/s) - ‘awslogs-agent-setup.py’ saved [47998/47998]
+ python ./awslogs-agent-setup.py -n -r eu-west-1 -c /etc/cwlogs.cfg
Step 1 of 5: Installing pip ...Traceback (most recent call last):
File "./awslogs-agent-setup.py", line 1144, in <module>
main()
File "./awslogs-agent-setup.py", line 1140, in main
setup.setup_artifacts()
File "./awslogs-agent-setup.py", line 693, in setup_artifacts
self.install_pip()
File "./awslogs-agent-setup.py", line 600, in install_pip
fail("Could not install pip. Please try again or see " + AGENT_SETUP_LOG_FILE + " for more details")
TypeError: fail() takes exactly 2 arguments (1 given)
+ error_exit 'Failed to run CloudWatch Logs agent setup'
/var/lib/cloud/instance/scripts/part-001: line 8: error_exit: command not found
Feb 17 14:36:12 cloud-init[2798]: util.py[WARNING]: Failed running /var/lib/cloud/instance/scripts/part-001 [127]
Feb 17 14:36:12 cloud-init[2798]: cc_scripts_user.py[WARNING]: Failed to run module scripts-user (scripts in /var/lib/cloud/instance/scripts)
Feb 17 14:36:12 cloud-init[2798]: util.py[WARNING]: Running module scripts-user (<module 'cloudinit.config.cc_scripts_user' from '/usr/lib/python2.7/dist-packages/cloudinit/config/cc_scripts_user.pyc'>) failed
Cloud-init v. 0.7.6 finished at Fri, 17 Feb 2017 14:36:12 +0000. Datasource DataSourceEc2. Up 85.78 seconds
Что не так в этом скрипте? Есть ли другой способ установить агент? Спасибо.
EDIT:
я понял, что это потому, что, возможно, пакет python-pip
не получил установлен таким образом, я добавил это к userData
:
"yum -y install python-pip\n",
После этого я снова играл шаблон и странно, я получил ту же ошибку.
Я usinh Amazon ECS-optimized AMI
в CloudFormation :: Init; Я сделал это так: '{" Ref ":" ClusterName "},"/", {" Ref ":" ContainerInstances "}' Я еще не тестировал, но это то же самое, что делать с помощью userData? – Somar
Не могли бы вы рассказать мне, как поставить этот скрипт в UserData? – Somar
Поскольку вы используете CloudFormation, я думаю, что использование «CloudFormation :: Init» для ссылки на эти поля, вероятно, является лучшим выбором и проще в управлении. Этот пример из документации предназначен для полной настройки только из пользовательских данных, если вы запускаете экземпляр непосредственно из консоли, например. Я придерживаюсь того, что у вас уже есть, и просто использую детали в документации в качестве ссылки для сравнения - возможно, добавьте 'chkconfig awslogs on', чтобы убедиться, что служба всегда запускается даже после перезагрузки экземпляра. – wjordan