Skip to content

Instantly share code, notes, and snippets.

@f4rx
Last active November 28, 2019 10:17
Show Gist options
  • Save f4rx/50ecc03571f54e0fc645a362a934184f to your computer and use it in GitHub Desktop.
Save f4rx/50ecc03571f54e0fc645a362a934184f to your computer and use it in GitHub Desktop.
3_terraform app.tf
###################################
# Get image ID
###################################
data "openstack_images_image_v2" "image_app" {
most_recent = true
visibility = "private"
tag = "app"
}
###################################
# Create port
###################################
resource "openstack_networking_port_v2" "port_app" {
name = "node-app"
network_id = "${openstack_networking_network_v2.network_1.id}"
fixed_ip {
subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}"
}
}
###################################
# Create Volume/Disk
###################################
resource "openstack_blockstorage_volume_v3" "volume_app" {
name = "volume-for-node"
size = "${var.hdd_size}"
image_id = "${data.openstack_images_image_v2.image_app.id}"
volume_type = "${var.volume_type}"
availability_zone = "${var.az_zone}"
enable_online_resize = true
lifecycle {
ignore_changes = ["image_id"]
}
}
###################################
# Create floating IP
###################################
resource "openstack_networking_floatingip_v2" "floatingip_app" {
pool = "external-network"
}
###################################
# Link floating IP to internal IP
###################################
resource "openstack_networking_floatingip_associate_v2" "association_1" {
port_id = "${openstack_networking_port_v2.port_app.id}"
floating_ip = "${openstack_networking_floatingip_v2.floatingip_app.address}"
}
###################################
# Create Server
###################################
resource "openstack_compute_instance_v2" "instance_app" {
name = "app"
flavor_id = "${data.openstack_compute_flavor_v2.flavor_1.id}"
key_pair = "${openstack_compute_keypair_v2.terraform_key.id}"
availability_zone = "${var.az_zone}"
network {
port = "${openstack_networking_port_v2.port_app.id}"
}
block_device {
uuid = "${openstack_blockstorage_volume_v3.volume_app.id}"
source_type = "volume"
destination_type = "volume"
boot_index = 0
}
vendor_options {
ignore_resize_confirmation = true
}
provisioner "file" {
content = <<-EOT
docker run -d --net=host --name consul \
-e CONSUL_BIND_INTERFACE=eth0 \
-e 'CONSUL_ALLOW_PRIVILEGED_PORTS=' \
consul:1.6 \
agent -dns-port=53 \
-recursor=8.8.8.8 \
-retry-join "provider=os tag_key=consul tag_value=server auth_url=https://api.selvpc.ru/identity/v3 password=${var.user_password} user_name=${var.user_name} project_id=${var.project_id} domain_name=${var.domain_name} region=${var.region}"
# '"
EOT
destination = "/tmp/run_consul.sh"
connection {
type = "ssh"
host = "${openstack_networking_floatingip_v2.floatingip_app.address}"
user = "root"
private_key = "${file("~/.ssh/id_rsa")}"
# agent = true
}
}
provisioner "remote-exec" {
inline = [
"chmod +x /tmp/run_consul.sh",
"/tmp/run_consul.sh",
]
connection {
type = "ssh"
host = "${openstack_networking_floatingip_v2.floatingip_app.address}"
user = "root"
private_key = "${file("~/.ssh/id_rsa")}"
# agent = true
}
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment