The Spectro Cloud Provider for Palette is available in the Terraform Registry. This repository contains the module and examples to create a Kubernetes Edge Cluster using Palette.
Assumptions
Addon profiles that will be used for the cluster creation have already been defined. This module will reference those resources rather than create them. Profiles can be created through the Cluster Profile Resource
Usage
Module Version
Required Terraform Version
<= 1.0.0
<= 1.2.9
>= 1.1.0
>= 1.3.0
See the Examples for usage of this module. This module is written for the Edge Native Deployment option.
This is a sample "main.tf" file. In this example, we are creating a 3-node Ubuntu-PXKE 1.24 cluster. This cluster has a basic profile for the Ubuntu Operating System, PXK-E (Palette Optimized Kubernetes for the Edge), a CNI, and a few other example profiles. These profiles were created ahead of time.
Additionally, with the "VIP" tag, we enable Kubevip for HA. The Edge Host is now looked up via the "tag" on the Edge Host. Multiple tags can be used for this purpose. See the example for usage with multiple pools. The Tag(s) should be added to the Edge Host before running the plan. This applies to virtual machines as well. For ease of use, we have provided a QRCode giving you the ability to easily copy the UID of the device.
QR Code
UID Copy
module"edge-demo-module" {
source="spectrocloud/edge/spectrocloud"version="1.5.0"# Store Number/Locationname="demo"# add tags to the cluster (optional) list(strings)cluster_tags=["origin:terraform"]
ssh_keys=[
"ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbm test2",
"ecdsa-sha2-nistp256 AAAAE2VjZHNhL test1"]
ntp_servers=[
"10.10.10.1",
"10.10.10.2"
]
# Cluster VIP to be used with KubeVIP If not using Overlay# cluster_vip = "10.10.100.5"# Overlay CIDR Rangeoverlay_cidr_range="100.64.128.0/18"# Node Pools for Clustermachine_pools=[
# Control Plane Node Pool
{
name ="control-plane"
control_plane =true
control_plane_as_worker =false
additional_labels = {
"region":"east"
}
edge_host = [
{
host_uid ="edge12345"
host_name ="edge1"
static_ip ="10.100.100.31"
subnet_mask ="255.255.255.0"
default_gateway ="10.100.100.1"
dns_servers = ["10.100.100.1","10.100.100.2"]
},
{
host_uid ="edge123456"
host_name ="edge2"
static_ip ="10.100.100.32"
subnet_mask ="255.255.255.0"
default_gateway ="10.100.100.1"
dns_servers = ["10.100.100.1","10.100.100.2"]
nic_name ="auto"
}
]
},
# Add additional node pools
{
name ="gpu"
control_plane =false
edge_host = [
{
host_uid ="123test"
static_ip ="2.2.2.2"
}
]
additional_labels = {
"type":"gpu",
"region":"east"
}
}
]
# Profiles to be added Profile should be an Edge-Native Infra or Full Profile with the OS, Kubernetes Distribution and CNI of choicecluster_profiles=[
{
name ="edge-profile"
tag ="1.30.5-ubuntu"
context ="project"
},
{
name ="edge-services"
tag ="1.0.0"
context ="project"
},
{
name ="edge-logging"
tag ="1.0.0"
context ="project"
}
]
# Cluster Geolocation (Optional)location={
latitude =40.442829
longitude =-79.950432
}
rbac_bindings=[
{
rbac_type ="ClusterRoleBinding"
rbac_role = {
name ="cluster-admin"
kind ="ClusterRole"
}
subjects = [
{
name ="k8s-admin"
rbac_type ="Group"
}
]
}
]
}
Optional - If used Latitude and Longitude represent the coordinates of the location you wish to assign to the cluster. https://www.latlong.net/ is one tool that can be used to find this.
object({ latitude = optional(number) longitude = optional(number) })