Azure Aks群集-每个代理的额外磁盘存储

时间:2019-10-22 16:53:38

标签: azure kubernetes azure-aks glusterfs

是否可以通过Terraform配置AKS集群并在每个VM中包含将包含附加存储的代理?

当前基于SMB协议的PV / PVC有点开玩笑,我的计划是使用rook或glusterfs,但是我想通过Terraform来配置群集,在该群集中我的每个节点也将处理适当数量的存储,而不是创建单独的常规节点来处理它们。

最好的问候。

2 个答案:

答案 0 :(得分:1)

恐怕您无法通过Terraform在AKS中实现这一目标。 AKS是一项托管服务,因此您无法在其中执行许多个人操作。

根据您的要求,建议您使用aks-engine,您可以自己管理集群,甚至可以管理主节点。您可以在diskSizesGB中使用属性agentPoolProfiles。此处的说明:

  

描述最多4个附加磁盘大小的阵列。有效的磁盘大小值在1到1024之间。

clusterdefinitions中的更多详细信息。您还可以查看diskSizesGB here的示例。

答案 1 :(得分:0)

使用aks-engine只是为了拥有更多存储空间,这对我来说是浪费资源, 我终于找到了一种完全通过terraform方式为每个aks节点添加额外存储的方法:

resource "azurerm_subnet" "subnet" {
  name                = "aks-subnet-${var.name}"
  resource_group_name = "${azurerm_resource_group.rg.name}"
  # Uncomment this line if you use terraform < 0.12
  network_security_group_id = "${azurerm_network_security_group.sg.id}"
  address_prefix            = "10.1.0.0/24"
  virtual_network_name      = "${azurerm_virtual_network.network.name}"
}

resource "azurerm_kubernetes_cluster" "cluster" {
  ...
  agent_pool_profile {
    ...
    count           = "${var.kubernetes_agent_count}"
    vnet_subnet_id  = "${azurerm_subnet.subnet.id}"
  }
}

# Find all agent node ids by extracting it's name from subnet assigned to cluster:
data "azurerm_virtual_machine" "aks-node" {
  # This resource represent each node created for aks cluster.
  count = "${var.kubernetes_agent_count}"
  name  = distinct([for x in azurerm_subnet.subnet.ip_configurations : replace(element(split("/", x), 8), "/nic-/", "")])[count.index]

  resource_group_name = azurerm_kubernetes_cluster.cluster.node_resource_group
  depends_on = [
    azurerm_kubernetes_cluster.cluster
  ]
}

# Create disk resource in size of aks nodes:
resource "azurerm_managed_disk" "aks-extra-disk" {
  count                = "${var.kubernetes_agent_count}"
  name                 = "${azurerm_kubernetes_cluster.cluster.name}-disk-${count.index}"
  location             = "${azurerm_kubernetes_cluster.cluster.location}"
  resource_group_name  = "${azurerm_kubernetes_cluster.cluster.resource_group_name}"
  storage_account_type = "Standard_LRS"
  create_option        = "Empty"
  disk_size_gb         = 10
}

# Attach our disks to each agents:
resource "azurerm_virtual_machine_data_disk_attachment" "aks-disk-attachment" {
  count              = "${var.kubernetes_agent_count}"
  managed_disk_id    = "${azurerm_managed_disk.aks-extra-disk[count.index].id}"
  virtual_machine_id = "${data.azurerm_virtual_machine.aks-node[count.index].id}"
  lun                = "10"
  caching            = "ReadWrite"
}