Input manifest API reference¶
Manifest¶
Manifest is a definition of the user's infrastructure. It contains cloud provider specification, nodepool specification, Kubernetes and loadbalancer clusters.
name
Name of the manifest. Must be unique across all manifests of the Claudie instance.
providers
Providers
Defines all your cloud provider configuration that will be used while infrastructure provisioning.
nodepools
Nodepools
Describes nodepools used for either kubernetes clusters or loadbalancer cluster defined in this manifest.
kubernetes
Kubernetes
List of Kubernetes cluster this manifest will manage.
loadBalancers
Loadbalancer
List of loadbalancer clusters the Kubernetes clusters may use.
Providers¶
Contains configurations for supported cloud providers. At least one provider needs to be defined.
gcp
GCP
List of configuration options for Google Cloud. This field is optional.
hetzner
Hetzner
List of configuration options for Hetzner Cloud . This field is optional.
oci
OCI
List of configuration options for Oracle Cloud Infrastructure. This field is optional.
aws
AWS
List of configuration options for Amazon Web Services. This field is optional.
azure
Azure
List of configuration options for Azure. This field is optional.
cloudflare
Cloudflare
List of Cloudflare configuration for Cloudflare. This field is optional.
hetznerdns
HetznerDNS
List of HetznerDNS configuration for HetznerDNS. This field is optional.
Support for more cloud providers is in the roadmap.
Cloudflare¶
Collection of data defining Cloudflare provider configuration.
To find out how to configure Cloudflare follow the instructions here
name
Name of the provider. Used as a reference further in the input manifest. Should be unique for each provider spec across all the providers.
apiToken
Credentials for the provider (API token).
HetznerDNS¶
Collection of data defining HetznerDNS provider configuration.
To find out how to configure HetznerDNS follow the instructions here
name
Name of the provider. Used as a reference further in the input manifest. Should be unique for each provider spec across all the providers.
apiToken
Credentials for the provider (API token).
GCP¶
Collection of data defining GCP cloud provider configuration.
To find out how to configure GCP provider and service account, follow the instructions here.
name
Name of the provider. Used as a reference further in the input manifest. Should be unique for each provider spec across all the cloud providers.
credentials
Credentials for the provider. Stringified JSON service account key.
gcpProject
Project id of an already existing GCP project where the infrastructure is to be created.
Hetzner¶
Collection of data defining Hetzner cloud provider configuration.
To find out how to configure Hetzner provider and service account, follow the instructions here.
name
Name of the provider spec. Used as a reference further in the input manifest. Should be unique for each provider spec across all the cloud providers.
credentials
Credentials for the provider (API token).
OCI¶
Collection of data defining OCI cloud provider configuration.
To find out how to configure OCI provider and service account, follow the instructions here.
name
Name of the provider spec. Used as a reference further in the input manifest. Should be unique for each provider spec across all the cloud providers.
privateKey
Private key used to authenticate to the OCI.
keyFingerprint
Fingerprint of the user-supplied private key.
tenancyOcid
OCID of the tenancy where privateKey
is added as an API key
userOcid
OCID of the user in the supplied tenancy
compartmentOcid
OCID of the compartment where VMs/VCNs/... will be created
AWS¶
Collection of data defining AWS cloud provider configuration.
To find out how to configure AWS provider and service account, follow the instructions here.
name
Name of the provider spec. Used as a reference further in the input manifest. Should be unique for each provider spec across all the cloud providers.
accessKey
Access key ID for your AWS account.
secretKey
Secret key for the Access key specified above.
Azure¶
Collection of data defining Azure cloud provider configuration.
To find out how to configure Azure provider and service account, follow the instructions here.
name
Name of the provider spec. Used as a reference further in the input manifest. Should be unique for each provider spec across all the cloud providers.
subscriptionId
Subscription ID of your subscription in Azure.
tenantId
Tenant ID of your tenancy in Azure.
clientId
Client ID of your client. The Claudie is design to use a service principal with appropriate permissions.
clientSecret
Client secret generated for your client.
Nodepools¶
Collection of static and dynamic nodepool specification, to be referenced in the kubernetes
or loadBalancer
clusters.
dynamic
Dynamic
List of dynamically to-be-created nodepools of not yet existing machines, used for Kubernetes or loadbalancer clusters.
These are only blueprints, and will only be created per reference in kubernetes
or loadBalancer
clusters. E.g. if the nodepool isn't used, it won't even be created. Or if the same nodepool is used in two different clusters, it will be created twice.
In OOP analogy, a dynamic nodepool would be a class that would get instantiated N >= 0
times depending on which clusters reference it.
static
[WORK IN PROGRESS]
List of static nodepools of already existing machines, not created by of Claudie, used for Kubernetes or loadbalancer clusters. Typically, these would be on-premises machines.
Dynamic¶
Dynamic nodepools are defined for cloud provider machines that Claudie is expected to create.
name
Name of the nodepool. Each nodepool will have a random hash appended to the name, so the whole name will be of format <name>-<hash>
.
provideSpec
Provider spec
Collection of provider data to be used while creating the nodepool.
count
Number of the nodes in the nodepool. Mutually exclusive with autoscaler
.
serverType
Type of the machines in the nodepool.
Currently, only AMD64 machines are supported.
image
OS image of the machine.
Currently, only Ubuntu 22.04 AMD64 images are supported.
storageDiskSize
Size of the storage disk on the nodes in the nodepool in GB
. The OS disk is created automatically with predefined size of 100GB
for kubernetes nodes and 50GB
for Loadbalancer nodes.
Default value is 50
, minimum value is 50
. Value is used only for compute nodes.
This field is optional, however, if compute nodepool does not define it, default value is used for creation of storage disk. Control nodepools and Loadbalancer nodepools ignore this field.
autoscaler
Autoscaler Configuration
Autoscaler configuration for this nodepool. Mutually exclusive with count
.
Provider Spec¶
Provider spec is an additional specification built on top of the data from any of the provider instance. Here are provider configuration examples for each individual provider: aws, azure, gcp, cloudflare, hetzner and oci.
name
Name of the provider instance specified in providers
region
Region of the nodepool.
zone
Zone of the nodepool.
Autoscaler Configuration¶
Autoscaler configuration on per nodepool basis. Defines the number of nodes, autoscaler will scale up or down specific nodepool.
min
Minimum number of nodes in nodepool.
max
Maximum number of nodes in nodepool.
Kubernetes¶
Defines Kubernetes clusters.
clusters
Cluster-k8s
List of Kubernetes clusters Claudie will create.
Cluster-k8s¶
Collection of data used to define a Kubernetes cluster.
name
Name of the Kubernetes cluster. Each cluster will have a random hash appended to the name, so the whole name will be of format <name>-<hash>
.
version
Kubernetes version of the cluster.
Version should be defined in format vX.Y
. In terms of supported versions of Kubernetes, Claudie follows kubeone
releases and their supported versions. The current kubeone
version used in Claudie is 1.5
. To see the list of supported versions, please refer to kubeone
documentation.
network
Network range for the VPN of the cluster. The value should be defined in format A.B.C.D/mask
.
pools
List of nodepool names this cluster will use. Remember that nodepools defined in nodepools are only "blueprints". The actual nodepool will be created once referenced here.
LoadBalancer¶
Defines loadbalancer clusters.
roles
Role
List of roles loadbalancers use to forward the traffic. Single role can be used in multiple loadbalancer clusters.
clusters
Cluster-lb
List of loadbalancer clusters used in the Kubernetes clusters defined under clusters.
Role¶
Role defines a concrete loadbalancer configuration. Single loadbalancer can have multiple roles.
name
Name of the role. Used as a reference in clusters.
protocol
Protocol of the rule. Allowed values are:
Value | Description |
---|---|
tcp |
Role will use TCP protocol |
udp |
Role will use UDP protocol |
port
Port of the incoming traffic on the loadbalancer.
targetPort
Port where loadbalancer forwards the traffic.
target
Defines a target group of nodes. Allowed values are:
Value | Description |
---|---|
k8sAllNodes |
All nodes in the cluster |
k8sControlNodes |
Only control/master nodes in cluster |
k8sComputeNodes |
Only compute/worker nodes in cluster |
Cluster-lb¶
Collection of data used to define a loadbalancer cluster.
name
Name of the loadbalancer.
roles
List of roles the loadbalancer uses.
dns
DNS
Specification of the loadbalancer's DNS record.
targetedK8s
Name of the Kubernetes cluster targetted by this loadbalancer.
pools
List of nodepool names this loadbalancer will use. Remember, that nodepools defined in nodepools are only "blueprints". The actual nodepool will be created once referenced here.
DNS¶
Collection of data Claudie uses to create a DNS record for the loadbalancer.
dnsZone
DNS zone inside of which the records will be created. GCP/AWS/OCI/Azure/Cloudflare/Hetzner DNS zone is accepted
provider
Name of provider to be used for creating an A record entry in defined DNS zone.
hostname
Custom hostname for your A record. If left empty, the hostname will be a random hash.