使用 Terraform 管理 OpenStack 集群

Terraform 是一种声明性语言,可以充当您正在处理的基础设施的蓝图。
1 位读者喜欢这篇文章。
What's new in OpenStack in 2016: A look at the Newton release

Opensource.com

在拥有 OpenStack 生产环境和家庭实验室一段时间后,我可以明确地说,从管理员和租户的角度来看,配置工作负载并对其进行管理非常重要。

Terraform 是一种开源基础设施即代码 (IaC) 软件工具,用于配置网络、服务器、云平台等。 Terraform 是一种声明性语言,可以充当您正在处理的基础设施的蓝图。 您可以使用 Git 管理它,并且它具有强大的 GitOps 用例。

本文介绍了使用 Terraform 管理 OpenStack 集群的基础知识。 我使用 Terraform 重建了 OpenStack 演示项目。

安装 Terraform

我使用 CentOS 作为跳板机,我在其中运行 Terraform。 根据官方文档,第一步是添加 Hashicorp 仓库

$ sudo dnf config-manager \
--add-repo https://rpm.releases.hashicorp.com/RHEL/hashicorp.repo

接下来,安装 Terraform

$ sudo dnf install terraform -y

验证安装

$ terraform –version

如果您看到返回版本号,则说明您已安装 Terraform。

为 OpenStack 提供商创建 Terraform 脚本

在 Terraform 中,您需要一个提供商。 提供商是一个转换器,Terraform 调用它将您的 .tf 文件转换为对您正在编排的平台的 API 调用。

提供商有三种类型:官方、合作伙伴和社区

  • 官方提供商由 Hashicorp 维护。
  • 合作伙伴提供商由与 Hashicorp 合作的技术公司维护。
  • 社区提供商由开源社区成员维护。

在这个链接中有一个很好的 OpenStack 社区提供商。 要使用此提供商,请创建一个 .tf 文件并将其命名为 main.tf

$ vi main.tf

将以下内容添加到 main.tf

terraform {
  required_version = ">= 0.14.0"
  required_providers {
    openstack = {
      source  = "terraform-provider-openstack/openstack"
      version = "1.49.0"
    }
  }
}

provider "openstack" {
  user_name   = “OS_USERNAME”
  tenant_name = “OS_TENANT”
  password    = “OS_PASSWORD”
  auth_url    = “OS_AUTH_URL”
  region      = “OS_REGION”
}

您需要更改 OS_USERNAMEOS_TENANTOS_PASSWORDOS_AUTH_URLOS_REGION 变量才能使其工作。

创建管理员 Terraform 文件

OpenStack 管理员文件侧重于配置外部网络、路由器、用户、镜像、租户配置文件和配额。

此示例配置了规格、连接到外部网络的路由器、测试镜像、租户配置文件和用户。

首先,为配置资源创建一个 AdminTF 目录

$ mkdir AdminTF

$ cd AdminTF

main.tf 中,添加以下内容

terraform {
  required_version = ">= 0.14.0"
  required_providers {
    openstack = {
      source  = "terraform-provider-openstack/openstack"
      version = "1.49.0"
    }
  }
}

provider "openstack" {
  user_name   = “OS_USERNAME”
  tenant_name = “admin”
  password    = “OS_PASSWORD”
  auth_url    = “OS_AUTH_URL”
  region      = “OS_REGION”
}

resource "openstack_compute_flavor_v2" "small-flavor" {
  name      = "small"
  ram       = "4096"
  vcpus     = "1"
  disk      = "0"
  flavor_id = "1"
  is_public = "true"
}

resource "openstack_compute_flavor_v2" "medium-flavor" {
  name      = "medium"
  ram       = "8192"
  vcpus     = "2"
  disk      = "0"
  flavor_id = "2"
  is_public = "true"
}

resource "openstack_compute_flavor_v2" "large-flavor" {
  name      = "large"
  ram       = "16384"
  vcpus     = "4"
  disk      = "0"
  flavor_id = "3"
  is_public = "true"
}

resource "openstack_compute_flavor_v2" "xlarge-flavor" {
  name      = "xlarge"
  ram       = "32768"
  vcpus     = "8"
  disk      = "0"
  flavor_id = "4"
  is_public = "true"
}

resource "openstack_networking_network_v2" "external-network" {
  name           = "external-network"
  admin_state_up = "true"
  external       = "true"
  segments {
    network_type     = "flat"
    physical_network = "physnet1"
  }
}

resource "openstack_networking_subnet_v2" "external-subnet" {
  name            = "external-subnet"
  network_id      = openstack_networking_network_v2.external-network.id
  cidr            = "10.0.0.0/8"
  gateway_ip      = "10.0.0.1"
  dns_nameservers = ["10.0.0.254", "10.0.0.253"]
  allocation_pool {
    start = "10.0.0.1"
    end   = "10.0.254.254"
  }
}

resource "openstack_networking_router_v2" "external-router" {
  name                = "external-router"
  admin_state_up      = true
  external_network_id = openstack_networking_network_v2.external-network.id
}

resource "openstack_images_image_v2" "cirros" {
  name             = "cirros"
  image_source_url = "https://download.cirros-cloud.net/0.6.1/cirros-0.6.1-x86_64-disk.img"
  container_format = "bare"
  disk_format      = "qcow2"

  properties = {
    key = "value"
  }
}

resource "openstack_identity_project_v3" "demo-project" {
  name = "Demo"
}

resource "openstack_identity_user_v3" "demo-user" {
  name               = "demo-user"
  default_project_id = openstack_identity_project_v3.demo-project.id
  password = "demo"
}

创建租户 Terraform 文件

作为租户,您通常创建虚拟机。 您还为虚拟机创建网络和安全组。

此示例使用上面由管理员文件创建的用户。

首先,为租户相关配置创建一个 TenantTF 目录

$ mkdir TenantTF
$ cd TenantTF

main.tf 中,添加以下内容

terraform {
  required_version = ">= 0.14.0"
  required_providers {
    openstack = {
      source  = "terraform-provider-openstack/openstack"
      version = "1.49.0"
    }
  }
}

provider "openstack" {
  user_name   = “demo-user”
  tenant_name = “demo”
  password    = “demo”
  auth_url    = “OS_AUTH_URL”
  region      = “OS_REGION”
}

resource "openstack_compute_keypair_v2" "demo-keypair" {
  name       = "demo-key"
  public_key = "ssh-rsa ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ"
}


resource "openstack_networking_network_v2" "demo-network" {
  name           = "demo-network"
  admin_state_up = "true"
}

resource "openstack_networking_subnet_v2" "demo-subnet" {
  network_id = openstack_networking_network_v2.demo-network.id
  name       = "demo-subnet"
  cidr       = "192.168.26.0/24"
}

resource "openstack_networking_router_interface_v2" "demo-router-interface" {
  router_id = “XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX”
  subnet_id = openstack_networking_subnet_v2.demo-subnet.id
}

resource "openstack_compute_instance_v2" "demo-instance" {
  name            = "demo"
  image_id        = "YYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYY"
  flavor_id       = "3"
  key_pair        = "demo-key"
  security_groups = ["default"]

  metadata = {
    this = "that"
  }

  network {
    name = "demo-network"
  }
}

初始化您的 Terraform

创建 Terraform 文件后,您需要初始化 Terraform。

对于管理员

$ cd AdminTF

$ terraform init

$ terraform fmt

对于租户

$ cd TenantTF

$ terraform init

$ terraform fmt

命令解释

  • terraform init 从注册表下载提供商,以便在此项目中使用。
  • terraform fmt 格式化文件以在仓库中使用。

创建 Terraform 计划

接下来,创建一个计划,以便您查看将创建哪些资源。

对于管理员

$ cd AdminTF

$ terraform validate

$ terraform plan

对于租户

$ cd TenantTF

$ terraform validate

$ terraform plan

命令解释

  • terraform validate 验证 .tf 语法是否正确。
  • terraform plan 在缓存中创建一个计划文件,其中可以跟踪所有托管资源的创建和销毁。

应用您的第一个 TF

要部署资源,请使用 terraform apply 命令。 此命令应用计划文件中的所有资源状态。

对于管理员

$ cd AdminTF

$ terraform apply

对于租户

$ cd TenantTF

$ terraform apply

下一步

之前,我写了一篇关于在 Raspberry Pi 上部署最小 OpenStack 集群的文章。 您可以了解如何进行更详细的 Terraform 和 Ansible 配置,并使用 GitLab 实施一些 CI/CD。

AJ Canlas
AJ Canlas 是 Micro-D International 菲律宾分公司的高级解决方案咨询经理,他负责公共云和私有云基础设施及项目,他的主要优势在于 Linux、OpenStack、Ansible 自动化和容器化。

评论已关闭。

© . All rights reserved.