Skip to content

Commit b9f1dc9

Browse files
anjannathadrianriobo
authored andcommitted
doc: add doc for using the instance hw spec flags
this also updates the command help o/p in the existing docs so that it includes the `--cpus`, `--memory`, `--arch` and `--nested-virt` flags
1 parent 38a3710 commit b9f1dc9

File tree

8 files changed

+100
-40
lines changed

8 files changed

+100
-40
lines changed

docs/aws/fedora.md

+17-10
Original file line numberDiff line numberDiff line change
@@ -11,16 +11,23 @@ create
1111

1212
Usage:
1313
mapt aws fedora create [flags]
14-
1514
Flags:
16-
--airgap if this flag is set the host will be created as airgap machine. Access will done through a bastion
17-
--arch string architecture for the machine. Allowed x86_64 or arm64 (default "x86_64")
18-
--conn-details-output string path to export host connection information (host, username and privateKey)
19-
-h, --help help for create
20-
--spot if this flag is set the host will be created only on the region set by the AWS Env (AWS_DEFAULT_REGION)
21-
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
22-
--version string version for the Fedora Cloud OS (default "40")
23-
--vm-types strings set an specific set of vm-types. Note vm-type should match requested arch. Also if --spot flag is used set at least 3 types
15+
--airgap if this flag is set the host will be created as airgap machine. Access will done through a bastion
16+
--arch string architecture for the machine. Allowed x86_64 or arm64 (default "x86_64")
17+
--conn-details-output string path to export host connection information (host, username and privateKey)
18+
--cpus int32 Number of CPUs for the cloud instance (default 8)
19+
--ghactions-runner-labels strings List of labels separated by comma to be added to the self-hosted runner
20+
--ghactions-runner-name string Name for the Github Actions Runner
21+
--ghactions-runner-repo string Full URL of the repository where the Github Actions Runner should be registered
22+
--ghactions-runner-token string Token needed for registering the Github Actions Runner token
23+
-h, --help help for create
24+
--install-ghactions-runner Install and setup Github Actions runner in the instance
25+
--memory int32 Amount of RAM for the cloud instance in GiB (default 64)
26+
--nested-virt Use cloud instance that has nested virtualization support
27+
--spot if this flag is set the host will be created only on the region set by the AWS Env (AWS_DEFAULT_REGION)
28+
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
29+
--version string version for the Fedora Cloud OS (default "40")
30+
--vm-types strings set an specific set of vm-types and ignore any CPUs, Memory, Arch parameters set. Note vm-type should match requested arch. Also if --spot flag is used set at least 3 types.
2431

2532
Global Flags:
2633
--backed-url string backed for stack state. Can be a local path with format file:///path/subpath or s3 s3://existing-bucket
@@ -54,4 +61,4 @@ podman run -d --name mapt-rhel \
5461
--project-name mapt-fedora \
5562
--backed-url file:///workspace \
5663
--conn-details-output /workspace
57-
```
64+
```

docs/aws/rhel.md

+10-1
Original file line numberDiff line numberDiff line change
@@ -18,13 +18,22 @@ Flags:
1818
--airgap if this flag is set the host will be created as airgap machine. Access will done through a bastion
1919
--arch string architecture for the machine. Allowed x86_64 or arm64 (default "x86_64")
2020
--conn-details-output string path to export host connection information (host, username and privateKey)
21+
--cpus int32 Number of CPUs for the cloud instance (default 8)
22+
--ghactions-runner-labels strings List of labels separated by comma to be added to the self-hosted runner
23+
--ghactions-runner-name string Name for the Github Actions Runner
24+
--ghactions-runner-repo string Full URL of the repository where the Github Actions Runner should be registered
25+
--ghactions-runner-token string Token needed for registering the Github Actions Runner token
2126
-h, --help help for create
27+
--install-ghactions-runner Install and setup Github Actions runner in the instance
28+
--memory int32 Amount of RAM for the cloud instance in GiB (default 64)
29+
--nested-virt Use cloud instance that has nested virtualization support
2230
--rh-subscription-password string password to register the subscription
2331
--rh-subscription-username string username to register the subscription
2432
--snc if this flag is set the RHEL will be setup with SNC profile. Setting up all requirements to run https://github.com/crc-org/snc
2533
--spot if this flag is set the host will be created only on the region set by the AWS Env (AWS_DEFAULT_REGION)
2634
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
2735
--version string version for the RHEL OS (default "9.4")
36+
--vm-types strings set an specific set of vm-types and ignore any CPUs, Memory, Arch parameters set. Note vm-type should match requested arch. Also if --spot flag is used set at least 3 types.
2837

2938
Global Flags:
3039
--backed-url string backed for stack state. Can be a local path with format file:///path/subpath or s3 s3://existing-bucket
@@ -75,4 +84,4 @@ podman run -d --name mapt-rhel \
7584
--rh-subscription-password XXXX \
7685
--rh-subscription-username XXXXX \
7786
--conn-details-output /workspace
78-
```
87+
```

docs/aws/windows.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -76,4 +76,4 @@ podman run -d --name mapt-rhel \
7676
--project-name mapt-windows \
7777
--backed-url file:///workspace \
7878
--conn-details-output /workspace
79-
```
79+
```

docs/azure/fedora.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,7 @@ Flags:
3333
--spot-eviction-tolerance string if spot is enable we can define the minimum tolerance level of eviction. Allowed value are: lowest, low, medium, high or highest (default "lowest")
3434
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
3535
--username string username for general user. SSH accessible + rdp with generated password (default "rhqp")
36-
--version string linux version. Version should be formated as X.Y (Major.minor)
36+
--version string linux version. Version should be formated as X.Y (Major.minor) (default "40.0")
3737
--vmsize strings set specific size for the VM and ignore any CPUs, Memory and Arch parameters set. Type requires to allow nested virtualization
3838

3939
Global Flags:

docs/azure/rhel.md

+21-11
Original file line numberDiff line numberDiff line change
@@ -22,18 +22,28 @@ create
2222

2323
Usage:
2424
mapt azure rhel create [flags]
25-
2625
Flags:
27-
--arch string architecture for the machine. Allowed x86_64 or arm64 (default "x86_64")
28-
--conn-details-output string path to export host connection information (host, username and privateKey)
29-
-h, --help help for create
30-
--location string If spot is passed location will be calculated based on spot results. Otherwise localtion will be used to create resources. (default "West US")
31-
--spot if spot is set the spot prices across all regions will be cheked and machine will be started on best spot option (price / eviction)
32-
--spot-eviction-tolerance string if spot is enable we can define the minimum tolerance level of eviction. Allowed value are: lowest, low, medium, high or highest (default "lowest")
33-
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
34-
--username string username for general user. SSH accessible + rdp with generated password (default "rhqp")
35-
--version string linux version. Version should be formmated as X.Y (Major.minor) (default "9.4")
36-
--vmsize string size for the VM. Type requires to allow nested virtualization (default "Standard_D8as_v5")
26+
--arch string architecture for the machine. Allowed x86_64 or arm64 (default "x86_64")
27+
--conn-details-output string path to export host connection information (host, username and privateKey)
28+
--cpus int32 Number of CPUs for the cloud instance (default 8)
29+
--ghactions-runner-labels strings List of labels separated by comma to be added to the self-hosted runner
30+
--ghactions-runner-name string Name for the Github Actions Runner
31+
--ghactions-runner-repo string Full URL of the repository where the Github Actions Runner should be registered
32+
--ghactions-runner-token string Token needed for registering the Github Actions Runner token
33+
-h, --help help for create
34+
--install-ghactions-runner Install and setup Github Actions runner in the instance
35+
--location string If spot is passed location will be calculated based on spot results. Otherwise localtion will be used to create resources. (default "West US")
36+
--memory int32 Amount of RAM for the cloud instance in GiB (default 64)
37+
--nested-virt Use cloud instance that has nested virtualization support
38+
--rh-subscription-password string password to register the subscription
39+
--rh-subscription-username string username to register the subscription
40+
--snc if this flag is set the RHEL will be setup with SNC profile. Setting up all requirements to run https://github.com/crc-org/snc
41+
--spot if spot is set the spot prices across all regions will be cheked and machine will be started on best spot option (price / eviction)
42+
--spot-eviction-tolerance string if spot is enable we can define the minimum tolerance level of eviction. Allowed value are: lowest, low, medium, high or highest (default "lowest")
43+
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
44+
--username string username for general user. SSH accessible + rdp with generated password (default "rhqp")
45+
--version string linux version. Version should be formated as X.Y (Major.minor) (default "9.4")
46+
--vmsize strings set specific size for the VM and ignore any CPUs, Memory and Arch parameters set. Type requires to allow nested virtualization
3747

3848
Global Flags:
3949
--backed-url string backed for stack state. Can be a local path with format file:///path/subpath or s3 s3://existing-bucket

docs/azure/ubuntu.md

+6-3
Original file line numberDiff line numberDiff line change
@@ -22,17 +22,20 @@ create
2222

2323
Usage:
2424
mapt azure ubuntu create [flags]
25-
2625
Flags:
26+
--arch string architecture for the machine. Allowed x86_64 or arm64 (default "x86_64")
2727
--conn-details-output string path to export host connection information (host, username and privateKey)
28+
--cpus int32 Number of CPUs for the cloud instance (default 8)
2829
-h, --help help for create
2930
--location string If spot is passed location will be calculated based on spot results. Otherwise localtion will be used to create resources. (default "West US")
31+
--memory int32 Amount of RAM for the cloud instance in GiB (default 64)
32+
--nested-virt Use cloud instance that has nested virtualization support
3033
--spot if spot is set the spot prices across all regions will be cheked and machine will be started on best spot option (price / eviction)
3134
--spot-eviction-tolerance string if spot is enable we can define the minimum tolerance level of eviction. Allowed value are: lowest, low, medium, high or highest (default "lowest")
3235
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
3336
--username string username for general user. SSH accessible + rdp with generated password (default "rhqp")
34-
--version string ubunutu version. Tore info at https://documentation.ubuntu.com/azure/en/latest/azure-how-to/instances/find-ubuntu-images (default "24_04")
35-
--vmsize string size for the VM. Type requires to allow nested virtualization (default "Standard_D8as_v5")
37+
--version string linux version. Version should be formated as X.Y (Major.minor) (default "24.04")
38+
--vmsize strings set specific size for the VM and ignore any CPUs, Memory and Arch parameters set. Type requires to allow nested virtualization
3639

3740
Global Flags:
3841
--backed-url string backed for stack state. Can be a local path with format file:///path/subpath or s3 s3://existing-bucket

docs/azure/windows.md

+20-13
Original file line numberDiff line numberDiff line change
@@ -35,20 +35,27 @@ create
3535

3636
Usage:
3737
mapt azure windows create [flags]
38-
3938
Flags:
40-
--admin-username string username for admin user. Only rdp accessible within generated password (default "rhqpadmin")
41-
--conn-details-output string path to export host connection information (host, username and privateKey)
42-
-h, --help help for create
43-
--location string If spot is passed location will be calculated based on spot results. Otherwise localtion will be used to create resources. (default "West US")
44-
--profile strings comma seperated list of profiles to apply on the target machine. Profiles available: crc
45-
--spot if spot is set the spot prices across all regions will be cheked and machine will be started on best spot option (price / eviction)
46-
--spot-eviction-tolerance string if spot is enable we can define the minimum tolerance level of eviction. Allowed value are: lowest, low, medium, high or highest (default "lowest")
47-
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
48-
--username string username for general user. SSH accessible + rdp with generated password (default "rhqp")
49-
--vmsize string size for the VM. Type requires to allow nested virtualization (default "Standard_D8s_v5")
50-
--windows-featurepack string windows feature pack (default "23h2-pro")
51-
--windows-version string Major version for windows desktop 10 or 11 (default "11")
39+
--admin-username string username for admin user. Only rdp accessible within generated password (default "rhqpadmin")
40+
--conn-details-output string path to export host connection information (host, username and privateKey)
41+
--cpus int32 Number of CPUs for the cloud instance (default 8)
42+
--ghactions-runner-labels strings List of labels separated by comma to be added to the self-hosted runner
43+
--ghactions-runner-name string Name for the Github Actions Runner
44+
--ghactions-runner-repo string Full URL of the repository where the Github Actions Runner should be registered
45+
--ghactions-runner-token string Token needed for registering the Github Actions Runner token
46+
-h, --help help for create
47+
--install-ghactions-runner Install and setup Github Actions runner in the instance
48+
--location string If spot is passed location will be calculated based on spot results. Otherwise localtion will be used to create resources. (default "West US")
49+
--memory int32 Amount of RAM for the cloud instance in GiB (default 64)
50+
--nested-virt Use cloud instance that has nested virtualization support
51+
--profile strings comma seperated list of profiles to apply on the target machine. Profiles available: crc
52+
--spot if spot is set the spot prices across all regions will be cheked and machine will be started on best spot option (price / eviction)
53+
--spot-eviction-tolerance string if spot is enable we can define the minimum tolerance level of eviction. Allowed value are: lowest, low, medium, high or highest (default "lowest")
54+
--tags stringToString tags to add on each resource (--tags name1=value1,name2=value2) (default [])
55+
--username string username for general user. SSH accessible + rdp with generated password (default "rhqp")
56+
--vmsize strings set specific size for the VM and ignore any CPUs, Memory and Arch parameters set. Type requires to allow nested virtualization
57+
--windows-featurepack string windows feature pack (default "23h2-pro")
58+
--windows-version string Major version for windows desktop 10 or 11 (default "11")
5259

5360
Global Flags:
5461
--backed-url string backed for stack state. Can be a local path with format file:///path/subpath or s3 s3://existing-bucket

docs/instance-selection.md

+24
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
# Instance Selection based on hardware specification
2+
3+
## Overview
4+
5+
With `mapt` users can select the type of instance to create on the cloud provider by providing its specification, i.e CPUs count, CPU architecture, Memory size
6+
and support for nested virtualization.
7+
8+
There are flags `--cpus`, `--memory`, `--arch` and `--nested-virt` for most of the `mapt <provider> <profile | os> create` with exception of `mac` and `windows` OS for AWS
9+
and `aks` profile for Azure.
10+
11+
The flags also have sensible default values, if an instance type satisfying the requested hardware specs is not offered by the provider, it'll use the default
12+
values to create a machine.
13+
14+
## Creating a fedora VM on AWS with user provided specs
15+
16+
As an example we can use the `--cpus`, `--arch` and `--memory` flags with the `mapt aws fedora create` command to create an arm machine with 8 cpus and 64GB of RAM:
17+
```
18+
$ mapt aws fedora create --spot \
19+
--arch arm64 \
20+
--cpus 8 --memory 64 \
21+
--project-name aws-mapt-fedora-test \
22+
--backed-url file:///home/mapt/workspace \
23+
--conn-details-output /tmp/fedora
24+
```

0 commit comments

Comments
 (0)