2022-09-02 05:52:42 -04:00
# Create your cluster
Creating your cluster requires two steps:
1. Creating the necessary resources in your cloud environment
2. Bootstrapping the Constellation cluster and setting up a connection
See the [architecture ](../architecture/orchestration.md ) section for details on the inner workings of this process.
## The *create* step
This step creates the necessary resources for your cluster in your cloud environment.
### Prerequisites
Before creating your cluster you need to decide on
2022-09-13 09:12:05 -04:00
* the initial size of your cluster (the number of control-plane and worker nodes)
2022-09-02 05:52:42 -04:00
* the machine type of your nodes (depending on the availability in your cloud environment)
* whether to enable autoscaling for your cluster (automatically adding and removing nodes depending on resource demands)
You can find the currently supported machine types for your cloud environment in the [installation guide ](../architecture/orchestration.md ).
### Configuration
Constellation can generate a configuration file for your cloud provider:
2022-09-09 11:01:57 -04:00
< tabs groupId = "csp" >
2022-09-21 10:58:04 -04:00
< tabItem value = "azure" label = "Azure" >
2022-09-02 05:52:42 -04:00
```bash
constellation config generate azure
```
< / tabItem >
2022-09-21 10:58:04 -04:00
< tabItem value = "gcp" label = "GCP" >
2022-09-02 05:52:42 -04:00
```bash
constellation config generate gcp
```
< / tabItem >
< / tabs >
2022-09-13 07:09:29 -04:00
This creates the file `constellation-conf.yaml` in the current directory. You must edit it before you can execute the next steps.
2022-09-02 05:52:42 -04:00
Next, download the latest trusted measurements for your configured image.
```bash
constellation config fetch-measurements
```
2022-09-13 06:05:07 -04:00
For more details, see the [verification section ](../workflows/verify-cluster.md ).
2022-09-02 05:52:42 -04:00
### Create
The following command creates a cluster with one control-plane and two worker nodes:
```bash
2022-09-09 11:01:57 -04:00
constellation create --control-plane-nodes 1 --worker-nodes 2 -y
2022-09-02 05:52:42 -04:00
```
For details on the flags and a list of supported instance types, consult the command help via `constellation create -h` .
*create* will store your cluster's configuration to a file named [`constellation-state.json` ](../architecture/orchestration.md#installation-process ) in your current directory.
## The *init* step
The following command initializes and bootstraps your cluster:
```bash
constellation init
```
To enable autoscaling in your cluster, add the `--autoscale` flag:
```bash
constellation init --autoscale
```
2022-09-13 09:12:05 -04:00
Next, configure `kubectl` for your Constellation cluster:
2022-09-02 05:52:42 -04:00
```bash
export KUBECONFIG="$PWD/constellation-admin.conf"
kubectl get nodes -o wide
```
2022-09-13 09:12:05 -04:00
🏁 That's it. You've successfully created a Constellation cluster.