AWS で terraform を使用してパペット マスター/スレーブ セットアップをセットアップしようとしています。私は 2 つの EC2 インスタンスを持っています。1 つはマスター、2 番目はスレーブです。
スクリプトを setup.tf として記述しました
provider "aws"{
region="us-east-1"
access_key="XXXX"
secret_key="XXXX"
}
resource "aws_security_group" "default"{
name="terraform-sg"
description="Created by terraform"
ingress {
from_port = 0
to_port = 0
protocol = "-1"
cidr_blocks = ["0.0.0.0/0"]
}
egress{
from_port = 0
to_port = 65535
protocol = "tcp"
cidr_blocks = ["0.0.0.0/0"]
}
}
resource "aws_instance" "puppet_master"{
connection={
user="ubuntu"
key_file="/home/vaibhav/Downloads/puppet_elk.pem"
}
instance_type="t2.micro"
ami="ami-fce3c696"
key_name = "puppet_elk"
security_groups= ["${aws_security_group.default.name}"]
tags{
Name="master"
}
provisioner "file" {
source = "./scripts/puppet-master.sh"
destination = "~/puppet-master.sh"
}
provisioner "remote-exec" {
inline = [
"chmod +x ~/puppet-master.sh",
"~/puppet-master.sh puppet"
]
}
}
resource "aws_instance" "puppet_node"{
depends_on = ["aws_instance.puppet_master"]
connection={
user="ubuntu"
key_file="/home/vaibhav/Downloads/puppet_elk.pem"
}
instance_type="t2.micro"
ami="ami-fce3c696"
key_name = "puppet_elk"
security_groups= ["${aws_security_group.default.name}"]
tags{
Name="node"
}
provisioner "file" {
source = "./scripts/puppet-node.sh"
destination = "~/puppet-node.sh"
}
provisioner "remote-exec" {
inline = [
"chmod +x ~/puppet-node.sh",
"~/puppet-node.sh node1"
]
}
パペットマスターとスレーブのインストールに使用しているスクリプトは次のとおりです。
#!/bin/bash
if [ $# -eq 0 ]
then
echo "No hostname supplied"
exit
fi
env=$1
echo $env
hostname=`hostname`
myipaddress=$(ifconfig eth0 | awk '/inet addr/{print substr($2,6)}')
sudo apt-get update -y
sudo apt-get upgrade -y
sudo wget http://apt.puppetlabs.com/puppetlabs-release-trusty.deb
sudo dpkg -i puppetlabs-release-trusty.deb
sudo apt-get update -y
sudo apt-get -y install puppetmaster
sudo sed -i "s/$hostname/$env/g" /etc/hostname
sudo sed -i "s/no/yes/g" /etc/default/puppetmaster
sudo echo "127.0.0.1 puppet.example.net puppet" >> /etc/hosts
sudo echo "$myipaddress puppet.example.net puppet" >> /etc/hosts
sudo reboot
スレーブの場合:
#!/bin/bash
if [ $# -eq 0 ]
then
echo "No hostname supplied"
exit
fi
env=$1
echo $env
hostname=`hostname`
sudo apt-get update -y
sudo apt-get upgrade -y
sudo wget http://apt.puppetlabs.com/puppetlabs-trusty.deb
sudo dpkg -i puppetlabs-release-trusty.deb
sudo apt-get update -y
sudo pt-get -y install puppet
sudo ed -i "s/$hostname/$env/g" /etc/hostname
sudo sed -i "s/no/yes/g" /etc/default/puppet
# replace IP with the variable
#masterip=${aws_instance.puppet-node.private_ip}
sudo echo "${aws_instance.puppet_master.private_ip} puppet.example.net puppet" >> /etc/hosts
sudo echo "${aws_instance.puppet_master.private_ip} puppet" >> /etc/hosts
sudo puppet agent --enable
sudo puppet agent --waitforcert 60
sudo reboot
このスクリプトを実行すると、スレーブ シェル スクリプトで補間のエラーが発生します。
{aws_instance.puppet_master.private_ip} : 不正な補間
マスターIPが必要なパペットでマスタースレーブをセットアップするため、この補間文字列の代わりにマスタープライベートIPを置き換えたいです。
これに対する回避策はありますか?