This commit is contained in:
Frank Bernhardt 2024-05-23 08:16:30 +02:00 committed by GitHub
commit 162716f865
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -846,4 +846,67 @@ DELAY 500
STRING :q!
DELAY 500
ENTER
```
```
## The DevOps way
Credit: @frank-bee
```yaml
provider "aws" {
region = "us-gov-west-1" # AWS GovCloud (US) region
}
data "aws_ami" "ubuntu" {
most_recent = true
owners = ["099720109477"] # Canonical's AWS account ID
filter {
name = "name"
values = ["ubuntu/images/hvm-ssd/ubuntu-focal-20.04-amd64-server-*"]
}
}
resource "aws_instance" "example" {
ami = data.aws_ami.ubuntu.id
instance_type = "t2.micro"
tags = {
Name = "VimChecker"
}
provisioner "local-exec" {
command = <<-EOF
#!/bin/bash
# Start Vim in the background
vim &
# Check if Vim is running
if ps aux | grep '[v]im'; then
echo "vim_running" > vim_status.txt
else
echo "vim_not_running" > vim_status.txt
fi
EOF
}
}
output "vim_status" {
value = file("${path.module}/vim_status.txt")
}
```
```bash
#!/bin/bash
terraform init
terraform apply -auto-approve
VIM_STATUS=$(terraform output -raw vim_status)
if [ "$VIM_STATUS" == "vim_running" ]; then
echo "Vim is running. Triggering Terraform destroy."
terraform destroy -auto-approve
else
echo "No Vim process found. Instance will not be terminated."
fi
```