Я пытаюсь создать Windows AMI (пользовательский образ AWS) с Packer. Есть ли способ использовать WinRM в macOS или мне нужно создать образ на компьютере с Windows?
Мы используем сочетание серверов Ubuntu и Windows, и большинство из них — серверы Ubuntu. Я хотел бы построить все это на моем макбуке. В производстве мы используем Jenkins.
Образ предназначен для запуска IIS и Sitecore.
мне нужно установить
- ИИС
- Сайткор
- Filebeat
Пример кода:
resource "aws_key_pair" "mykey" {
key_name = "mykey"
public_key = "${file("${var.PATH_TO_PUBLIC_KEY}")}"
}
resource "aws_instance" "win-example" {
security_groups = [ "${aws_security_group.windows-admin.id}" ]
subnet_id = "subnet-730c9c16"
ami = "ami-40003a26"
instance_type = "t2.micro"
associate_public_ip_address = true
key_name = "${aws_key_pair.mykey.key_name}"
tags {
Name = "win-example"
}
user_data = <<EOF
<powershell>
net user ${var.INSTANCE_USERNAME} ${var.INSTANCE_PASSWORD} /add
net localgroup administrators ${var.INSTANCE_USERNAME} /add
winrm quickconfig -q
winrm set winrm/config/winrs '@{MaxMemoryPerShellMB="300"}'
winrm set winrm/config '@{MaxTimeoutms="1800000"}'
winrm set winrm/config/service '@{AllowUnencrypted="true"}'
winrm set winrm/config/service/auth '@{Basic="true"}'
netsh advfirewall firewall add rule name="WinRM 5985" protocol=TCP dir=in localport=5985 action=allow
netsh advfirewall firewall add rule name="WinRM 5986" protocol=TCP dir=in localport=5986 action=allow
net stop winrm
sc.exe config winrm start=auto
net start winrm
</powershell>
EOF
provisioner "file" {
source = "test.txt"
destination = "C:/test.txt"
connection {
type = "winrm"
user = "${var.INSTANCE_USERNAME}"
password = "${var.INSTANCE_PASSWORD}"
insecure = true
timeout = "10m"
}
}
connection {
type = "winrm"
user = "${var.INSTANCE_USERNAME}"
password = "${var.INSTANCE_PASSWORD}"
insecure = true
timeout = "10m"
}
}
терраформ сообщает об ошибке:
Error applying plan:
1 error(s) occurred:
* aws_instance.win-example: 1 error(s) occurred:
* unknown error Post http://54.229.229.22:5985/wsman: dial tcp 54.229.229.22:5985: getsockopt: operation timed out
Сценарий powershell запускается, и пользователь создается, но файл «test.txt» не копируется на сервер.