API Documentation
In this section you will find links to the API documentation of metal-stack components.
diff --git a/previews/PR155/apidocs/apidocs/index.html b/previews/PR155/apidocs/apidocs/index.html new file mode 100644 index 0000000000..b0b6b8334b --- /dev/null +++ b/previews/PR155/apidocs/apidocs/index.html @@ -0,0 +1,2 @@ + +
In this section you will find links to the API documentation of metal-stack components.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Our public-facing APIs are built on swagger, which allows you generating API clients in all sorts of programming languages.
For the metal-api we officially support the following client libraries:
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
This document describes the way we want to contribute code to the projects of metal-stack, which are hosted on github.com/metal-stack.
The document is meant to be understood as a general guideline for contributions, but not as burden to be placed on a developer. Use your best judgment when contributing code. Try to be as clean and precise as possible when writing code and try to make your code as maintainable and understandable as possible for other people.
Even if it should go without saying, we live an open culture of discussion, in which everybody is welcome to participate. We treat every contribution with respect and objectiveness with the general aim to write software of quality.
If you want, feel free to propose changes to this document in a pull request.
Open a Github issue in the project you would like to contribute. Within the issue, your idea can be discussed. It is also possible to directly create a pull request when the set of changes is relatively small.
The process described here has several goals:
This section contains language-agnostic topics that all metal-stack projects are trying to follow.
The code base is owned by the entire team and every member is allowed to contribute changes to any of the projects. This is considered as collective code ownership[1].
As a matter of fact, there are persons in a project, which already have experience with the sources. These are defined directly in the repository's CODEOWNERS file. If you want to merge changes into the master branch, it is advisable to include code owners into the proecess of discussion and merging.
One major ambition of metal-stack is to follow the idea of microservices. This way, we want to achieve that we can
We are generally open to write code in any language that fits best to the function of the software. However, we encourage golang to be the main language of metal-stack as we think that it makes development faster when not establishing too many different languages in our architecture. Reason for this is that we are striving for consistent behavior of the microservices, similar to what has been described for the Twelve-Factor App (see https://12factor.net/). We help enforcing unified behavior by allowing a small layer of shared code for every programming language. We will refer to this shared code as "libraries" for the rest of this document.
Artifacts are always produced by a CI process (Github Actions).
Docker images are published on the Github Container Registry of the metal-stack organization.
Binary artifacts or OS images can be uploaded to images.metal-stack.io
if necessary.
When building Docker images, please consider our build tool docker-make or the specific docker-make action respectively.
We are currently making use of Swagger when we exposing traditional REST APIs for end-users. This helps us with being technology-agnostic as we can generate clients in almost any language using go-swagger. Swagger additionally simplifies the documentation of our APIs.
Most APIs though are not required to be user-facing but are of technical nature. These are preferred to be implemented using grpc.
Artifacts are versioned by tagging the respective repository with a tag starting with the letter v
. After the letter, there stands a valid semantic version.
In order to make it easier for others to understand a project, we document general information and usage instructions in a README.md
in any project.
In addition to that, we document a microservice in the docs repository. The documentation should contain the reasoning why this service exists and why it was being implemented the way it was being implemented. The aim of this procedure is to reduce the time for contributors to comprehend architectural decisions that were made during the process of writing the software and to clarify the general purpose of this service in the entire context of the software.
This chapter describes general guidelines on how to develop and contribute code for a certain programming language.
Development follows the official guide to:
metal-stack maintains several libraries that you should utilize in your project in order unify common behavior. Some of these projects are:
From the server-side you should ensure that you are returning the common error json struct in case of an error as defined in the metal-lib/httperrors
. Ensure you are using go-restful >= v2.9.1
and go-restful-openapi >= v0.13.1
(allows default responses with error codes other than 200).
We want to share knowledge and keep things simple. If things cannot kept simple we want enable everybody to understand them by:
<THE WHAT> to <THE TO>
").Development follows the official guide to:
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
We face the situation that we argue for running bare metal on premise because this way the customers can control where and how their software and data are processed and stored. On the other hand, we have currently decided that our metal-api control plane components run on a kubernetes cluster (in our case on a cluster provided by one of the available hyperscalers).
Running the control plane on Kubernetes has the following benefits:
Using a kubernetes as a service offering from one of the hyperscalers, enables us to focus on using kubernetes instead of maintaining it as well.
It would be much saner if metal-stack has no, or only minimal dependencies to external services. Imagine a metal-stack deployment in a plant, it would be optimal if we only have to deliver a single rack with servers and networking gear installed and wired, plug that rack to the power supply and a internet uplink and its ready to go.
Have a second plant which you want to be part of all your plants? Just tell both that they are part of something bigger and metal-api knows of two partitions.
We can think of two different solutions to this vision:
As we can see, the first approach does not really address the problem, therefore i will describe solution #2 in more details.
Every distributed system suffer from handling state in a scalable, fast and correct way. To start how to cope with the state, we first must identify which state can be seen as partition local only and which state must be synchronous for read, and synchronous for writes across partitions.
Affected states:
Now we can see that the most critical state to held and synchronize are the IPAM data, because these entities must be guaranteed to be synchronously updated, while being updated frequently.
Datastores:
We use three different types of datastores to persist the states of the metal application.
These are the easy part, all of our services which are stateless can be scaled up and down without any impact on functionality. Even the stateful services like masterdata and metal-api rely fully on the underlying datastore and can therefore also be scaled up and down to meet scalability requirements.
Albeit, most of these services need to be placed behind a loadbalancer which does the L4/L7 balancing across the started/available replicas of the service for the clients talking to it. This is actually provided by kubernetes with either service type loadbalancer or type clusterip.
One exception is the metal-console
service which must have the partition in it´s dns name now, because there is no direct network connectivity between the management networks of the partitions. See "Network Setup)
In order to replicate certain data which must be available across all partitions we can use on of the existing open source databases which enable such kind of setup. There are a few avaible out there, the following uncomplete list will highlight the pro´s and cons of each.
RethinkDB
We already store most of our data in RethinkDB and it gives already the ability to synchronize the data in a distributed manner with different guarantees for consistency and latency. This is described here: Scaling, Sharding and replication. But because rethinkdb has a rough history and unsure future with the last release took more than a year, we in the team already thought that we eventually must move away from rethinkdb in the future.
Postgresql
Postgres does not have a multi datacenter with replication in both directions, it just can make the remote instance store the same data.
CockroachDB
Is a Postgresql compatible database enginge on the wire. CockroachDB gives you both, ACID and geo replication with writes allowed from all connected members. It is even possible to configure Follow the Workload and Geo Partitioning and Replication.
If we migrate all metal-api entities to be stored the same way we store masterdata, we could use cockroachdb to store all metal entities in one ore more databases spread across all partitions and still ensure consistency and high availability.
A simple setup how this would look like is shown here.
go-ipam was modified in a example PR here: https://github.com/metal-pod/go-ipam/pull/17
In order to make the metal-api accessible for api users like cloud-api
or metalctl
as easy at it is today, some effort has to be taken. One possible approach would be to use a external loadbalancer which spread the requests evenly to all metal-api endpoints in all partitions. Because all data are accessible from all partitions, a api request going to partition A with a request to create a machine in partition B, will still work. If on the other hand partition B is not in a connected state because the interconnection between both partitions is broken, then of course the request will fail.
IMPORTANT The NSQ Message to inform metal-core
must end in the correct partition
To provide such a external loadbalancer we have several opportunities:
Another setup would place a small gateway behind the metal-api address, which forwards to the metal-api in the partition where the request must be executed. This gateway, metal-api-router
must inspect the payload, extract the desired partition, and forward the request without any modifications to the metal-api endpoint in this partition. This can be done for all requests, or if we want to optimize, only for write accesses.
In order to have the impact to the overall security concept as minimal as possible i would not modify the current network setup. The only modifications which has to be made are:
A simple setup how this would look like is shown here, this does not work though because of the forementioned NSQ issue.
Therefore we need the metal-api-router
:
The deployment of our components will substantially differ in a partition compared to a the deployment we have actually. Deploying it in kubernetes in the partition would be very difficult to achieve because we have no sane way to deploy kubernetes on physical machines without a underlying API. I would therefore suggest to deploy our components in the same way we do that for the services running on the management server. Use systemd to start docker containers.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
As writing this proposal, metal-stack only supports Cumulus on Broadcom ASICs. Unfortunately, after the acquisition of Cumulus Networks by Nvidia, Broadcom decided to cut its relationship with Cumulus, and therefore Cumulus 4.2 is the last version that supports Broadcom ASICs. Since trashing the existing hardware is not a solution, adding support for a different network operating system is necessary.
One of the remaining big players is SONiC, which Microsoft created to scale the network of Azure. It's an open-source project and is now part of the Linux Foundation.
For a general introduction to SONiC, please follow the (https://github.com/sonic-net/SONiC/wiki/Architecture) official documentation.
On a cold start, the content of /etc/sonic/config_db.json
will be loaded into the Redis database CONFIG_DB
, and both contain the switch's configuration except the BGP unnumbered configuration, which still has to be configured directly by the frr configuration files. The SONiC community is working to remove this exception, but no release date is known.
Frr runs inside a container, and a shell script configured it on the container startup. For BGP unnumbered, we must set the configuration variable docker_routing_config_mode
to split
to prevent SONiC from overwriting our configuration files created by metal-core
. But by using the split mode, the integrated configuration mode of frr is deactivated, and we have to write our BGP configuration to the daemon-specific files bgp.conf
, staticd.conf
, and zebra.conf
instead to frr.conf
.
elif [ "$CONFIG_TYPE" == "split" ]; then
+ echo "no service integrated-vtysh-config" > /etc/frr/vtysh.conf
+ rm -f /etc/frr/frr.conf
Reference: https://github.com/Azure/sonic-buildimage/blob/202205/dockers/docker-fpm-frr/docker_init.sh#L69
Adding support for the integrated configuration mode, we must at least adjust the startup shell script and the supervisor configuration:
{% if DEVICE_METADATA.localhost.docker_routing_config_mode is defined and DEVICE_METADATA.localhost.docker_routing_config_mode == "unified" %}
+[program:vtysh_b]
+command=/usr/bin/vtysh -b
Reference: https://github.com/Azure/sonic-buildimage/blob/202|205/dockers/docker-fpm-frr/frr/supervisord/supervisord.conf.j2#L157
For the Non-BGP configuration we have to write it into the Redis database directly or via one of the following interfaces:
config replace <file>
Directly writing into the Redis database isn't a stable interface, and we must determine the create, delete, and update operations on our own. The last point is also valid for the Mgmt Framework and the SONiC restapi. Furthermore, the Mgmt Framework doesn't start anymore for several months, and a potential fix is still not merged. And the SONiC restapi isn't enabled by default, and we must build and maintain our own SONiC images.
Using config replace
would reduce the complexity in the metal-core
codebase because we don't have to determine the actual changes between the running and the desired configuration. The approach's drawbacks are using a version of SONiC that contains the PR Yang support for VXLAN, and we must provide the whole new startup configuration to prevent unwanted deconfiguration.
{
+ "LOOPBACK_INTERFACE": {
+ "Loopback0": {},
+ "Loopback0|<loopback address/32>": {}
+ },
+ "VXLAN_TUNNEL": {
+ "vtep": {
+ "src_ip": "<loopback address>"
+ }
+ }
+}
{
+ "PORT": {
+ "Ethernet0": {
+ "mtu": "9000"
+ }
+ }
+}
{
+ "VLAN": {
+ "Vlan4000": {
+ "vlanid": "4000"
+ }
+ },
+ "VLAN_INTERFACE": {
+ "Vlan4000": {},
+ "Vlan4000|<metal core cidr>": {}
+ },
+ "VLAN_MEMBER": {
+ "Vlan4000|<interface>": {
+ "tagging_mode": "untagged"
+ }
+ },
+ "VXLAN_TUNNEL_MAP": {
+ "vtep|map_104000_Vlan4000": {
+ "vlan": "Vlan4000",
+ "vni": "104000"
+ }
+ }
+}
{
+ "INTERFACE": {
+ "Ethernet0": {
+ "vrf_name": "vrf104001"
+ }
+ },
+ "VLAN": {
+ "Vlan4001": {
+ "vlanid": "4001"
+ }
+ },
+ "VLAN_INTERFACE": {
+ "Vlan4001": {
+ "vrf_name": "vrf104001"
+ }
+ },
+ "VRF": {
+ "vrf104001": {
+ "vni": "104001"
+ }
+ },
+ "VXLAN_TUNNEL_MAP": {
+ "vtep|map_104001_Vlan4001": {
+ "vlan": "Vlan4001",
+ "vni": "104001"
+ }
+ }
+}
The DHCP relay container only starts if DEVICE_METADATA.localhost.type
is equal to ToRRouter
.
SONiC always uses the local port subtype for LLDP and sets it to some freely configurable alias field of the interface.
# Get the port alias. If None or empty string, use port name instead
+port_alias = port_table_dict.get("alias")
+if not port_alias:
+ self.log_info("Unable to retrieve port alias for port '{}'. Using port name instead.".format(port_name))
+ port_alias = port_name
+
+lldpcli_cmd = "lldpcli configure ports {0} lldp portidsubtype local {1}".format(port_name, port_alias)
Reference: https://github.com/Azure/sonic-buildimage/blob/202205/dockers/docker-lldp/lldpmgrd#L153
The mgmt interface is eth0
. To configure a static IP address and activate the Mgmt VRF, use:
{
+ "MGMT_INTERFACE": {
+ "eth0|<mgmt cidr>": {
+ "gwaddr": "<mgmt gateway>"
+ }
+ },
+ "MGMT_VRF_CONFIG": {
+ "vrf_global": {
+ "mgmtVrfEnabled": "true"
+ }
+ }
+}
IP forwarding is deactivated on eth0
, and no IP Masquerade is configured.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Currently no logs of the ownership of resources like machines, networks, ips and volumes are generated or kept. Though due to legal requirements data centers are required to keep track of this ownership over time to prevent liability issues when opening the platform for external users.
In this proposal we want to introduce a flexible and low-maintenance approach for auditing on top of Meilisearch.
In general our auditing logs will be collected by a request interceptor or middleware. Every request and response will be processed and eventually logged to Meilisearch. Meilisearch will be configured to regularly create chunks of the auditing logs. These finished chunks will be backed up to a S3 compatible storage with a read-only option enabled.
Of course sensitve data like session keys or passwords will be redacted before logging. We want to track relevant requests and responses. If auditing the request fails, the request itself will be aborted and will not be processed further. The requests and responses that will be audited will be annotated with a correlation id.
Transferring the meilisearch auditing data chunks to the S3 compatible storage will be done by a sidecar cronjob that is executed periodically. To avoid data manipulation the S3 compatible storage will be configured to be read-only.
To reduce the amount of unnecessary logs we want to introduce a whitelist of resources and operations on those that should be logged. Other requests will be passed directly to the next middleware or web service without any further processing.
As we are only interested in mutating endpoints, we ignore all GET
requests. The whitelist includes all POST
, PUT
, PATCH
and DELETE
endpoints of the HTTP middleware except for the following (non-manipulating) route suffixes:
/find
/notify
/try
and /match
/capacity
/from-hardware
Regarding GRPC audit trails, they are not so interesting because only internal clients are using this API. However, we can log the trails of the Boot
service, which can be interesting to revise the machine lifecycle.
We want our data to be chunked in Meilisearch. To accomplish this, we rotate the index identifier on a scheduled basis. The index identifiers will be derived from the current date and time.
To keep things simple, we only support hourly, daily and monthly rotation. The eventually prefixed index names will only include relevant parts of date and time like 2021-01
, 2021-01-01
or 2021-01-01_13
.
The metal-api will only write to the current index and switches to the new index on rotation. The metal-api will never read or update data in any indices.
As Meilisearch will be filled with data over time, we want to move completed chunks to a S3 compatible storage. This will be done by a sidecar cronjob that is executed periodically. Note that the periods of the index rotation and the cronjob execution don't have to match.
When the backup process gets started, it initiates a Meilisearch dump of the whole database across all indices. Once the returned task is finished, the dump must be copied from a Meilisearch volume to the S3 compatible storage. After a successful copy, the dump can be deleted.
Now we want to remove all indices from Meilisearch, except the most recent one. For this, we get all indices, sort them and delete each index except the most recent one to avoid data loss.
For the actual implementation, we can build upon backup-restore-sidecar. But due to the index rotation and the fact, that older indices need to be deleted, this probably does not fit into the mentioned sidecar.
The dumps of chunks should automatically deleted after a certain amount of time, once we are either no longer allowed or required to keep them. The default retention time will be 6 months. Ideally already uploaded chunks should be read-only to prevent data manipulation.
A candidate for the S3 compatible storage is Google Cloud Storage, which allows to configure automatic expiration of objects through a lifecycle rule.
Instead of using Meilisearch we investigated using an immutable database like immudb. But immudb does not support chunking of data and due to its immutable nature, we will never be able to free up space of expired data. Even if we are legally allowed or required to delete data, we will not be able to do so with immudb.
In another variant of the Meilisearch approach the metal-api would also be responsible for copying chunks to the S3 compatible storage and deleting old indices. But separating the concerns allows completely different implementations for every deployment stage.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Currently, when creating a machine through the metal-api, the machine is placed randomly inside a partition. This algorithm does not consider spreading machines across different racks and different chassis. This may lead to the situation that a group of machines (that for example form a cluster) can end up being placed in the same rack and the same chassis.
Spreading a group of machines across racks can enhance availability for scenarios like a rack loosing power or a chassis meltdown.
So, instead of just randomly deciding the placement of a machine candidate, we want to propose a placement strategy that attempts to spread machine candidates across the racks inside a partition.
Machines in the project are spread across all available racks evenly within a partition (best effort). For this, an additional request to the datastore has to be made in order to find allocated machines within the project in the partition.
The algorithm will then figure out the least occupied racks and elect a machine candidate randomly from those racks.
The user can optionally pass placement tags which will be considered for spreading the machines as well (this will for example allow spreading by a cluster id tag inside the same project).
// service/v1/machine.go
+
+type MachineAllocation struct {
+ // existing fields are omitted for readability
+ PlacementTags []string `json:"placement_tags" description:"by default machines are spread across the racks inside a partition for every project. if placement tags are provided, the machine candidate has an additional anti-affinity to other machines having the same tags"`
+}
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
marp: true theme: metal-stack paginate: true footer: Gerrit Schwerthelm – x-cellent technologies GmbH — metal-stack Training backgroundImage: url("https://metal-stack.io/images/shape/banner.png") –- <!– _class: cover lead –>
<!– _class: cover lead –>
<!– _class: lead _backgroundColor: #1f1f1f _backgroundImage: _footer: "" –>
<!– _class: lead _backgroundColor: #1f1f1f _backgroundImage: _footer: "" –>
<style>section { font-size: 30px; }</style>
<!– _class: cover lead –>
<!– _class: lead _backgroundColor: #1f1f1f _backgroundImage: _footer: "" –>
<style>section { font-size: 30px; }</style>
MEP-12: Rack Spreading
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
In the current metal-api only machine installations are possible, performing a machine upgrade is only possible by creating a new machine and delete the old one. This has the drawback that in case a lot of data is stored on the local disks, a full restore of the original data must be performed.
To prevent this, we will introduce a new metal-api endpoint to reinstall the machine with a new image, without actually deleting the data stored on the additional hard disks.
Storage is a difficult task to get right and reliable. A short analysis of our different storage requirements lead to 3 different scenarios.
rolling
updates. Therefore a additional osupdatestrategy
has to be implemented for metal and other providers in gardener to be able to leverage the metal reinstall on the same machineID approach.If reinstall is implemented, we should focus on the same technology for all scenarios and put ceph via rook.io into the kubernetes clusters as additional StorageClass. It has to be checked whether to use the raw disk or a PV as the underlay block device where ceph stores its data.
The API will get an new endpoint "reinstall" this endpoint takes two arguments:
No other aspects of the machine can be modified during the re-installation. All data stored in the existing allocation will be preserved, only the image will be modified. Once this endpoint was called, the machine will get a reboot
signal with the boot order set to PXE instead of HDD and the network interfaces on the leaf are set to PXE as well. Then the normal installation process starts:
reinstall: true
, wipe disk is only executed for the root disk, all other disks are untouched./install.sh
is executedWe can see that the allocation
requires one additional parameter: reinstall
and metal-hammer must check for already existing allocation at an earlier stage.
Components which requires modifications (first guess):
reinstall
flag set/etc/metal
directory!/machine/reinstall
Reinstall bool
to data model of allocation
Reinstall
after reinstallation to prevent endless reinstallation loopreinstall
reinstall
OSUpgradeStrategy
reinstall
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
In the past we decided to treat the metal-api as a "low-level API", i.e. the API does not know anything about projects and tenants. A user with editor access can for example assign machines to every project he desires, he can see all the machines available and control them. Even though we always wanted to keep open the possibility to just offer bare metal machines to the end-user, the ultimate objective has always been to create an API for Kubernetes clusters. Hence, we tried to keep the metal-api code base as small as possible and we added resource scoping to a "higher-level API", the cloud-api, a component that is not open-source. From there, a user would be able to only see his own clusters and IP addresses.
The implication is that the metal-api has no multi-tenancy without another layer on top of it that implements resource scoping. One can say that we treat clusters as first-class citizens. In regard of clusters we fulfill the objective that we had from the very beginning: provide a multi-tenant API for Kubernetes clusters to the end-users.
However, as time passed by, things changed: The metal-stack is becoming an open-source product and we already have promising adopters of our product, who are willing to contribute to metal-stack. This is a serious chance of making our product better and more successful. It turns out that the decision we made was sufficient for us, but for others it is not.
For example, users who want to combine the Metal Stack with Gardener, may not want to hide all of the Gardener's functionality behind the cloud-api in the way we do. They want to use the much more powerful Gardener Dashboard instead. The Gardener itself does not need the cloud-api either. It is a cluster-api by itself. It only needs to utilize our "low-level API" and actually expects this API to have multi-tenancy as otherwise every logged in user can create / destroy clusters in every existing project from the Gardener dashboard.
This makes obvious that, with our decision, we placed an unnecessary obstacle in the way of our adopters: They now need to implement an own layer between the Gardener and the metal-api to provide multi-tenancy. From the Gardener-perspective we strongly differ from other cloud providers in this aspect and it is a matter of time when this will become an issue. When we encourage adopters to implement such interfaces on their own we also partly lose control of our product, we increase divergence.
As the cloud-api is not part of the Metal Stack, the promise of multi-tenancy is only true for our network layer. Without the cloud-api to enable multi-tenancy, the network isolation is currently useless for end-users. Users of the Metal Stack can not self-manage machines, networks and ips without compromising the environment and thus, there is no self-service. We lose a valuable selling point when adopters can not immediately make use of our leading edge network isolation where we put so much effort to.
If a third-party uses Gardener and our metal-api had multi-tenancy, we would be able to allow a third-party to create clusters with workers in our own partitions. At the moment, this is not possible because the Gardener needs to know the HMAC secrets to create worker nodes, which would compromise our environment. If a thirdy-party knows our HMAC we lose control over the machines of our own tenants.
One could think about solving the multi-tenancy issue by adding machine endpoints to the cloud-api. Gardener would then not consume the metal-api anymore but only the cloud-api.
This approach would not be ideal. We only want to offer a minimum viable product to adopters. The Gardener does not need a cluster-api as provided by the cloud-api. We want to treat additions on top of the basic stack as enterprise products.
The cloud-api contains billing endpoints, which are a perfect example for an optional addition of the Metal Stack. For basic usage of the Metal Stack a user does not need billing. Still, billing functionality can be interesting for some enterprises, who are like us, selling the infrastructure to third-parties.
Multi-tenancy in the metal-api also has the potential to limit the damage that a provider administrator can cause by mistake. If an administrator has to acquire project permissions on machine-level we can effectively reduce the damage he can make to this single project.
Another example would be the automatic provisioning of a Gitlab CI runner used for integration testing (a use case that we have where we do not require the cloud-api). This can easily be done in automated manner with Ansible and the Metal dynamic inventory + modules. However, with Ansible, mistakes in the automation can be made very quickly and if Ansible would only see machines of a dedicated project, this would also reduce damage it can make.
It is likely that there are more similar use-cases like that to come (maybe even for the storage solution?).
Also the surface for our Gardener components (metal-ccm, gardener-extension-provider-metal, machine-controller-manager) would be reduced to project scopes.
For these reasons the decision we made is very likely to have a negative impact on the adoption-rate of the Metal Stack and we should think about treating machines, networks and ips as first-class citizens as well. This makes us closer to the offer of hyperscalers. As mentioned in the beginning, all the time we tried to keep the possibility open to just offer bare metal machines. Let's continue with decision by adding multi-tenancy to the metal-api.
Just as implemented by the cloud-api, resource scoping needs to be added to almost every endpoint of the metal-api:
For all of this we need enhance the database queries with a filter for projects that a user has access to. As we already use a client to the masterdata-api in the metal-api, we can extract project memberships of a logged in user from there.
We do not only need kaas-...
permissions in the LDAP but also maas-
. This way we can differentiate between permissions for the cloud-api and permissions for the metal-api.
We need to provide the possibility for users to obtain access tokens to use for technical purposes (CI, third-party tooling like Gardener, ...).
We do not have this functionality yet, but it would also become a necessity for the cloud-api at some point in the future.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
For special purpose machines that serve shared services with performance critical workloads to all machines of a partition (like persistent storage) it would be good to have kind of a "shared network" that is easily accessible. They do not necessarily need another firewall. This would avoid having two firewalls in the datapath between a machine in a private network and the machines of a shared service.
noauto
and a specific IPAlternative 1: If we implemented shared networks by extending functions around plain, private networks we would not have to manage another CIDR (mini point) and it would be possible to create a k8s cluster with a private network, mark the network as shared
and produce shared services from this k8s cluster.
Alternative 2: If shared networks are implemented as first class networks we could customize the VRF and also accomplish an other goal of our roadmap: being able to create machines directly in an external network.
Together with @majst01 and @Gerrit91 we decided to continue to implement Alternative 1.
Firewalls that access shared networks need to:
nat=true
.nat=true
was set on the shared VRF, the original machine ips are visible in both communication directions.Machines contained in a shared network can access the internet with different scenarios:
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
To fulfill higher levels of security measures the standard metal-stack approach with a single firewall in front of a set of machines might be insufficient. There are cases where two physically distinct firewalls in front of application workload are mandatory. In traditional network terms this is known as DMZ approach.
For Kubernetes workloads it makes sense to use the front cluster for ingress, WAF purposes and as outgoing proxy. The clusters may be used for application workload.
A DMZ network with publicly reachable internet prefix will look like this in the metal-api:
---
+description: DMZ-Network
+destinationprefixes:
+- 0.0.0.0/0
+id: dmz
+labels:
+ network.metal-stack.io/default-external: ""
+name: DMZ-Network
+parentnetworkid: null
+partitionid: ""
+prefixes:
+- 212.90.30.128/25
+privatesuper: false
+projectid: ""
+vrf: 104007
+vrfshared: false
+nat: true
+shared: false
+underlay: false
The firewall of the DMZ will intersect its private network for attached machines, the DMZ network and the public internet.
The firewall of application workloads intersects its private network for attached machines and the DMZ network.
This is currently supported by the metal-networker and needs no further changes!
A DMZ network with private IPs will look like this in the metal-api:
---
+description: DMZ-Network
+destinationprefixes:
+- 0.0.0.0/0
+id: dmz
+labels:
+ network.metal-stack.io/default-external: ""
+name: DMZ-Network
+parentnetworkid: tenant-super-network-fra-equ01
+partitionid: fra-equ01
+prefixes:
+- 10.90.30.128/25
+privatesuper: false
+projectid: ""
+vrf: 4711
+vrfshared: false
+nat: true
+shared: true # it's usable from multiple projects
+underlay: false
The firewall of the DMZ will intersect its private network for attached machines, the DMZ network and the public internet.
The firewall of application workloads intersects its private network for attached machines and the DMZ network.
metal-networker
and metal-ccm
assume that there is only one network providing the default-routemetal-networker
needs tometal-api
: destination prefixes of private networks need to be configurable (allocateNetwork
)gardener-extension-provider-metal
: needs to be able to delete DMZ clusters (but skip the network deletion part)We decided to follow the second approach with private DMZ networks.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
The current implementation uses a hard coded filesystem layout depending on the specified size and image. This is done in the metal-hammer. This worked well in the past because we had a small amount of sizes and images. But we reached a point where this is to restricted for all use cases we have to fulfill. It also forces us to modify the metal-hammer source code to support a new filesystem layout.
This proposal tries to address this issue by introducing a filesystem layout struct in the metal-api which is then configurable per machine allocation. The original behavior of automatic filesystem layout decision must still be present, because there must be no API change for existing API consumers. It should be a additional feature during machine allocation.
The API will get a new endpoint filesystemlayouts
to create/update/delete a set of available filesystemlayouts
.
In order to keep the actual machine allocation api compatible, there must be no difference while allocating a machine. To achieve this every filesystemlayout
defines constraints which specifies for which combination of sizes
and images
this layout should be used by default. The specified constraints over all filesystemlayouts
therefore must be collision free, to be more specific, there must be exactly one layout outcome for every possible combination of sizes
and images
.
The size
constraint must be a list of the exact size ids, the image
constraint must be a map of os to semver compatible version constraint. For example:
debian: ">= 10.20210101"
or debian: "< 10.20210101"
The general form of a image
constraint is a map from os
to versionconstraint
where:
os
must match the first part of the image without the version. versionconstraint
must be the comparator, a space and the version, or simply *
to match all versions of this os
. The comparator must be one of: "=", "!=", ">", "<", ">=", "=>", "<=", "=<", "~", "~>", "^"
It must also be possible to have a filesystemlayout
in development or for other special purposes, which can be specified during the machine allocation. To have such a layout, both constraints sizes
and images
must be empty list.
The current reinstall implementation the metal-hammer detects during the installation on which disk the OS was installed and reports back to the metal-api the Report struct which has two properties primarydisk
and ospartition
. Both fields are not required anymore because the logic is now shifted to the filesystemlayout
definition. If Disk.WipeOnReinstall
is set to true, this disk will be wiped, default is false and is preserved.
These machines are a bit special compared to our c1-*
machines because they have rotating hard disks for the mass storage purpose. The downside is that the on board SATA-DOM has the same naming as the HDDs and can not be specified as the first /dev/sda disk because all HDDs are also /dev/sd* disks. Therefore we had a special SATA-DOM detection algorithm inside metal-hammer which simply checks for the smallest /dev/sd disk and took this to install the OS.
This is not possible with the current approach, but we figured out that the SATA-DOM is always /dev/sde
. So we can create a special filesystemlayout
where the installations is made on this disk.
It is only possible to create a filesystem on top of a block device. The creation of a block device can be done on multiple ways, depending on the requirements regarding performance, space and redundancy of the filesystem. It also depends on the disks available on the server.
The current approach implements the following hierarchies:
// FilesystemLayout to be created on the given machine
+type FilesystemLayout struct {
+ // ID unique layout identifier
+ ID string
+ // Description is human readable
+ Description string
+ // Filesystems to create on the server
+ Filesystems []Filesystem
+ // Disks to configure in the server with their partitions
+ Disks []Disk
+ // Raid if not empty, create raid arrays out of the individual disks, to place filesystems onto
+ Raid []Raid
+ // VolumeGroups to create
+ VolumeGroups []VolumeGroup
+ // LogicalVolumes to create on top of VolumeGroups
+ LogicalVolumes []LogicalVolume
+ // Constraints which must match to select this Layout
+ Constraints FilesystemLayoutConstraints
+}
+
+type FilesystemLayoutConstraints struct {
+ // Sizes defines the list of sizes this layout applies to
+ Sizes []string
+ // Images defines a map from os to versionconstraint
+ // the combination of os and versionconstraint per size must be conflict free over all filesystemlayouts
+ Images map[string]string
+}
+
+type RaidLevel string
+type Format string
+type GPTType string
+
+// Filesystem defines a single filesystem to be mounted
+type Filesystem struct {
+ // Path defines the mountpoint, if nil, it will not be mounted
+ Path *string
+ // Device where the filesystem is created on, must be the full device path seen by the OS
+ Device string
+ // Format is the type of filesystem should be created
+ Format Format
+ // Label is optional enhances readability
+ Label *string
+ // MountOptions which might be required
+ MountOptions []string
+ // CreateOptions during filesystem creation
+ CreateOptions []string
+}
+
+// Disk represents a single block device visible from the OS, required
+type Disk struct {
+ // Device is the full device path
+ Device string
+ // Partitions to create on this device
+ Partitions []Partition
+ // WipeOnReinstall, if set to true the whole disk will be erased if reinstall happens
+ // during fresh install all disks are wiped
+ WipeOnReinstall bool
+}
+
+// Raid is optional, if given the devices must match.
+// TODO inherit GPTType from underlay device ?
+type Raid struct {
+ // ArryName of the raid device, most often this will be /dev/md0 and so forth
+ ArryName string
+ // Devices the devices to form a raid device
+ Devices []Device
+ // Level the raidlevel to use, can be one of 0,1,5,10
+ // TODO what should be support
+ Level RaidLevel
+ // CreateOptions required during raid creation, example: --metadata=1.0 for uefi boot partition
+ CreateOptions []string
+ // Spares defaults to 0
+ Spares int
+}
+
+
+// VolumeGroup is optional, if given the devices must match.
+type VolumeGroup struct {
+ // Name of the volumegroup without the /dev prefix
+ Name string
+ // Devices the devices to form a volumegroup device
+ Devices []string
+ // Tags to attach to the volumegroup
+ Tags []string
+}
+
+// LogicalVolume is a block devices created with lvm on top of a volumegroup
+type LogicalVolume struct {
+ // Name the name of the logical volume, without /dev prefix, will be accessible at /dev/vgname/lvname
+ Name string
+ // VolumeGroup the name of the volumegroup
+ VolumeGroup string
+ // Size of this LV in mebibytes (MiB)
+ Size uint64
+ // LVMType can be either striped or raid1
+ LVMType LVMType
+}
+
+// Partition is a single partition on a device, only GPT partition types are supported
+type Partition struct {
+ // Number of this partition, will be added to the device once partitioned
+ Number int
+ // Label to enhance readability
+ Label *string
+ // Size given in MebiBytes (MiB)
+ // if "0" is given the rest of the device will be used, this requires Number to be the highest in this partition
+ Size string
+ // GPTType defines the GPT partition type
+ GPTType *GPTType
+}
+
+const (
+ // VFAT is used for the UEFI boot partition
+ VFAT = Format("vfat")
+ // EXT3 is usually only used for /boot
+ EXT3 = Format("ext3")
+ // EXT4 is the default fs
+ EXT4 = Format("ext4")
+ // SWAP is for the swap partition
+ SWAP = Format("swap")
+ // None
+ NONE = Format("none")
+
+ // GPTBoot EFI Boot Partition
+ GPTBoot = GPTType("ef00")
+ // GPTLinux Linux Partition
+ GPTLinux = GPTType("8300")
+ // GPTLinuxRaid Linux Raid Partition
+ GPTLinuxRaid = GPTType("fd00")
+ // GPTLinux Linux Partition
+ GPTLinuxLVM = GPTType("8e00")
+
+ // LVMTypeLinear append across all physical volumes
+ LVMTypeLinear = LVMType("linear")
+ // LVMTypeStriped stripe across all physical volumes
+ LVMTypeStriped = LVMType("striped")
+ // LVMTypeStripe mirror with raid across all physical volumes
+ LVMTypeRaid1 = LVMType("raid1")
+)
Example metalctl
outputs:
$ metalctl filesystemlayouts ls
+ID DESCRIPTION SIZES IMAGES
+default default fs layout c1-large-x86, c1-xlarge-x86 debian >=10, ubuntu >=20.04, centos >=7
+ceph fs layout for ceph s2-large-x86, s2-xlarge-x86 debian >=10, ubuntu >=20.04
+firewall firewall fs layout c1-large-x86, c1-xlarge-x86 firewall >=2
+storage storage fs layout s3-large-x86 centos >=7
+s3 storage fs layout s2-xlarge-x86 debian >=10, ubuntu >=20.04, >=firewall-2
+default-devel devel fs layout
The default
layout reflects what is actually implemented in metal-hammer to guarantee backward compatibility.
---
+id: default
+constraints:
+ sizes:
+ - c1-large-x86
+ - c1-xlarge-x86
+ images:
+ debian: ">=10"
+ ubuntu: ">=20.04"
+ centos: ">=7"
+filesystems:
+ - path: "/boot/efi"
+ device: "/dev/sda1"
+ format: "vfat"
+ options: "-F 32"
+ label: "efi" # required to be compatible with old images
+ - path: "/"
+ device: "/dev/sda2"
+ format: "ext4"
+ label: "root" # required to be compatible with old images
+ - path: "/var/lib"
+ device: "/dev/sda3"
+ format: "ext4"
+ label: "varlib" # required to be compatible with old images
+ - path: "/tmp"
+ device: "tmpfs"
+ format: "tmpfs"
+ mountoptions: ["defaults","noatime","nosuid","nodev","noexec","mode=1777","size=512M"]
+disks:
+ - device: "/dev/sda"
+ wipe: true
+ partitions:
+ - number: 1
+ label: "efi"
+ size: 500
+ type: GPTBoot
+ - number: 2
+ label: "root"
+ size: 5000
+ type: GPTLinux
+ - number: 3
+ label: "varlib"
+ size: 0 # to end of partition
+ type: GPTLinux
The firewall
layout reuses the built in nvme disk to store the logs, which is way faster and larger than what the sata-dom ssd provides.
---
+id: firewall
+constraints:
+ sizes:
+ - c1-large-x86
+ - c1-xlarge-x86
+ images:
+ firewall: ">=2"
+filesystems:
+ - path: "/boot/efi"
+ device: "/dev/sda1"
+ format: "vfat"
+ options: "-F 32"
+ - path: "/"
+ device: "/dev/sda2"
+ format: "ext4"
+ - path: "/var"
+ device: "/dev/nvme0n1p1"
+ format: "ext4"
+disks:
+ - device: "/dev/sda"
+ wipe: true
+ partitions:
+ - number: 1
+ label: "efi"
+ size: 500
+ type: GPTBoot
+ - number: 2
+ label: "root"
+ size: 5000
+ type: GPTLinux
+ - device: "/dev/nvme0n1"
+ wipe: true
+ partitions:
+ - number: 1
+ label: "var"
+ size: 0
+ type: GPTLinux
The storage
layout will be used for the storage servers, which must have mirrored boot disks.
---
+id: storage
+constraints:
+ sizes:
+ - s3-large-x86
+ images:
+ centos: ">=7"
+filesystems:
+ - path: "/boot/efi"
+ device: "/dev/md1"
+ format: "vfat"
+ options: "-F32"
+ - path: "/"
+ device: "/dev/md2"
+ format: "ext4"
+disks:
+ - device: "/dev/sda"
+ wipe: true
+ partitions:
+ - number: 1
+ label: "efi"
+ size: 500
+ type: GPTLinuxRaid
+ - number: 2
+ label: "root"
+ size: 5000
+ type: GPTLinuxRaid
+ - device: "/dev/sdb"
+ wipe: true
+ partitions:
+ - number: 1
+ label: "efi"
+ size: 500
+ type: GPTLinuxRaid
+ - number: 2
+ label: "root"
+ size: 5000
+ type: GPTLinuxRaid
+raid:
+ - name: "/dev/md1"
+ level: 1
+ devices:
+ - "/dev/sda1"
+ - "/dev/sdb1"
+ options: "--metadata=1.0"
+ - name: "/dev/md2"
+ level: 1
+ devices:
+ - "/dev/sda2"
+ - "/dev/sdb2"
+ options: "--metadata=1.0"
The s3-storage
layout matches the special situation on the s2-xlarge machines.
---
+id: s3-storage
+constraints:
+ sizes:
+ - c1-large-x86
+ - s2-xlarge-x86
+ images:
+ debian: ">=10"
+ ubuntu: ">=20.04"
+ centos: ">=7"
+filesystems:
+ - path: "/boot/efi"
+ device: "/dev/sde1"
+ format: "vfat"
+ options: "-F 32"
+ - path: "/"
+ device: "/dev/sde2"
+ format: "ext4"
+ - path: "/var/lib"
+ device: "/dev/sde3"
+ format: "ext4"
+disks:
+ - device: "/dev/sde"
+ wipe: true
+ partitions:
+ - number: 1
+ label: "efi"
+ size: 500
+ type: GPTBoot
+ - number: 2
+ label: "root"
+ size: 5000
+ type: GPTLinux
+ - number: 3
+ label: "varlib"
+ size: 0 # to end of partition
+ type: GPTLinux
A sample lvm
layout which puts /var/lib
as stripe on the nvme device
---
+id: lvm
+description: "lvm layout"
+constraints:
+ size:
+ - s2-xlarge-x86
+ images:
+ debian: ">=10"
+ ubuntu: ">=20.04"
+ centos: ">=7"
+filesystems:
+ - path: "/boot/efi"
+ device: "/dev/sda1"
+ format: "vfat"
+ createoptions:
+ - "-F 32"
+ label: "efi"
+ - path: "/"
+ device: "/dev/sda2"
+ format: "ext4"
+ label: "root"
+ - path: "/var/lib"
+ device: "/dev/vg00/varlib"
+ format: "ext4"
+ label: "varlib"
+ - path: "/tmp"
+ device: "tmpfs"
+ format: "tmpfs"
+ mountoptions: ["defaults","noatime","nosuid","nodev","noexec","mode=1777","size=512M"]
+volumegroups:
+ - name: "vg00"
+ devices:
+ - "/dev/nvmne0n1"
+ - "/dev/nvmne0n2"
+logicalvolumes:
+ - name: "varlib"
+ volumegroup: "vg00"
+ size: 200
+ lvmtype: "striped"
+disks:
+ - device: "/dev/sda"
+ wipeonreinstall: true
+ partitions:
+ - number: 1
+ label: "efi"
+ size: 500
+ gpttype: "ef00"
+ - number: 2
+ label: "root"
+ size: 5000
+ gpttype: "8300"
+ - device: "/dev/nvmne0n1"
+ wipeonreinstall: false
+ - device: "/dev/nvmne0n2"
+ wipeonreinstall: false
filesystemlayouts
filesystemlayout
during allocation
with validation if given filesystemlayout
is possible on given size.allocation.filesystemlayout
in the response, based on either the specified filesystemlayout
or the calculated one.filesystemlayouts
validation for:filesystemlayouts
filesystemlayouts
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Our metal-stack partitions typically have open ports for metal-stack native services, these are:
These open ports are potential security risks. For example, while SSH access is possible only with private key it's still vulnerable to DoS attack.
Therefore, we want to get rid off these open ports to reduce the attack surface to the data center.
As a next step, we can also consider joining the management servers to the VPN mesh, which would replace typical WireGuard setups for operators to enter resources inside the partition.
Simplified drawing showing old vs. new architecture.
There's few concerns when using WireGuard for implementing VPN:
wireguard-go
. One of the options is to inject Tailscale client into metalctl
. And make it available as metalctl vpn
or similar command. It should be possible to do as tailscale
node is already available as open sourced Go pkg. That would allow us to control, what version of Tailscale users are using and in case of any critical changes to enforce them to update metalctl
to use VPN functionality.wg-dynamic
project to cover this problem.metal-roles
will be responsible for deployment of headscale
server(via new headscale
role). It also should provide sufficient config to metal-api
so it establishes connection with headscale
gRPC server.
metalctl
commandsmetalctl
will be responsible for client-side implementation of this MEP. Specifically, it's by using metalctl
user expected to connect to firewalls.
metalctl vpn
– section for VPN related commands:metalctl vpn get key [vpn name] --namespace [namespace name]
– returns auth key to be used with tailscale
client for establishing connection.Extend metalctl firewall
:
metalctl firewall ssh [ID]
– connect to firewall via SSH.Extend metalctl machine
:
metalctl machine ssh [ID]
– connect to machine via SSH.metalctl
will be able to connect to firewall and machines by running tailscale
in container.
Updates to metal-api
should be made, so that it's able to add firewalls to VPNs. There should be one Tailscale namespace per project. So if multiple firewalls are created in single project, they will join the same namespace.
Two new flags should be introduced to connect metal-api
to headscale
gRPC server:
headscale-addr
– specifies address of Headscale grpc API.headscale-api-key
– specifies temporary API key to connect to Headscale. It should be replaced and then rotated by metal-api
.If metal-api
initialized with headscale
connection it should automatically join all created firewalls to VPN.
Add new endpoint, that will be used by metalctl
to connect to VPN:
/v1/vpn GET
– requests auth key from headscale
server.metal-hammer
acts as an intermediary for machine configuration between metal-api
and machine's image. Specifically it writes to /etc/metal/install.yaml
file, data from which later will be used by image's install.sh
file.
To implement VPN support we have to add authentication key and VPN server address to install.yaml
file. This key will be used to join machine to a VPN.
Images install.sh
script have to be updated to work with authentication key and VPN server address, provided in install.yaml
file. If this key is present, machine should connect to VPN.
metal-networker
also have to know if VPN was configured. In that case we need to disable public access to SSH and allow all(?) traffic from WireGuard interface.
firewall-controller
have to monitor changes in Firewall
resource and keep tailscaled
version up-to-date.
Update Firewall
resource to include desired/actual tailscale
version:
Firewall:
+ Spec:
+ tailscale:
+ Version: Minimal version
+ ...
+ Status:
+ ...
+ VPN:
+ Status: Boolean field
+ tailscale:
+ Version: Actual version
+ ...
TODO
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
This section contains proposals which address substantial modifications to metal-stack.
Every proposal has a short name which starts with MEP followed by an incremental, unique number. Proposals should be raised as pull requests in the docs repository and can be discussed in Github issues.
The list of proposal and their current state is listed in the table below.
Possible states are:
In Discussion
Accepted
Declined
In Progress
Completed
Aborted
Once a proposal was accepted, an issue should be raised and the implementation should be done in a separate PR.
Name | Description | State |
---|---|---|
MEP-1 | Distributed Control Plane Deployment | In Discussion |
MEP-2 | Two Factor Authentication | Aborted |
MEP-3 | Machine Re-Installation to preserve local data | Completed |
MEP-4 | Multi-tenancy for the metal-api | In Discussion |
MEP-5 | Shared Networks | Completed |
MEP-6 | DMZ Networks | Completed |
MEP-8 | Configurable Filesystemlayout | Completed |
MEP-9 | No Open Ports To the Data Center | Completed |
MEP-10 | SONiC Support | Completed |
MEP-11 | Auditing of metal-stack resources | Completed |
MEP-12 | Rack Spreading | Completed |
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
A roadmap with short-, mid- and long-term planning will be available soon. For now, there is only a backlog.
Available soon.
Available soon.
Available soon.
The backlog contains ideas of what could become part of the roadmap in the future. The list is ordered alphabetically. Therefore, the order does not express the importance or weight of a backlog item.
We incorporate community feedback into the roadmap. If you think that important points are missing in the backlog, please share your ideas with us. We have a Slack channel. Please check out metal-stack.io for contact information.
By no means this list is a promise of what is being worked on in the near future. It is just a summary of ideas that was agreed on to be "nice to have". It is up to the investors, maintainers and the community to choose topics from this list and to implement them or to remove them from the list.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Please check out the contributing section in our docs.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
CSI DRIVER LVM utilizes local storage of Kubernetes nodes to provide persistent storage for pods.
It automatically creates hostPath based persistent volumes on the nodes.
Underneath it creates a LVM logical volume on the local disks. A comma-separated list of grok pattern, which disks to use must be specified.
This CSI driver is derived from csi-driver-host-path and csi-lvm
For the special case of block volumes, the filesystem-expansion has to be performed by the app using the block device
Helm charts for installation are located in a separate repository called helm-charts. If you would like to contribute to the helm chart, please raise an issue or pull request there.
You have to set the devicePattern for your hardware to specify which disks should be used to create the volume group.
helm install --repo https://helm.metal-stack.io mytest helm/csi-driver-lvm --set lvm.devicePattern='/dev/nvme[0-9]n[0-9]'
Now you can use one of following storageClasses:
csi-driver-lvm-linear
csi-driver-lvm-mirror
csi-driver-lvm-striped
To get the previous old and now deprecated csi-lvm-sc-linear
, ... storageclasses, set helm-chart value compat03x=true
.
If you want to migrate your existing PVC to / from csi-driver-lvm, you can use korb.
kubectl apply -f examples/csi-pvc-raw.yaml
+kubectl apply -f examples/csi-pod-raw.yaml
+
+
+kubectl apply -f examples/csi-pvc.yaml
+kubectl apply -f examples/csi-app.yaml
+
+kubectl delete -f examples/csi-pod-raw.yaml
+kubectl delete -f examples/csi-pvc-raw.yaml
+
+kubectl delete -f examples/csi-app.yaml
+kubectl delete -f examples/csi-pvc.yaml
In order to run the integration tests locally, you need to create to loop devices on your host machine. Make sure the loop device mount paths are not used on your system (default path is /dev/loop10{0,1}
).
You can create these loop devices like this:
for i in 100 101; do fallocate -l 1G loop${i}.img ; sudo losetup /dev/loop${i} loop${i}.img; done
+sudo losetup -a
+# use this for recreation or cleanup
+# for i in 100 101; do sudo losetup -d /dev/loop${i}; rm -f loop${i}.img; done
You can then run the tests against a kind cluster, running:
make test
To recreate or cleanup the kind cluster:
make test-cleanup
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Please check out the contributing section in our docs.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
kubebuilder init --domain metal-stack.io
+kubebuilder create api --group firewall --version v1 --kind Network
export KUBEBUILDER_ASSETS=/usr/local/kubebuilder/bin # path-to-kubebuilder/bin
+make test
# make binary
+make
+
+# start the controller
+bin/firewall-controller --hosts-file ./hosts --enable-signature-check=false --enable-IDS=false
+
+# install kind (k8s in docker)
+
+# create a local kind cluster
+kind create cluster
+
+# deploy manifests
+k apply -f deploy
+
+# watch results
+k describe -n firewall firewall
+cat nftables.v4
+cat hosts
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
This controller is installed on a bare-metal firewall in front of several kubernetes worker nodes and responsible to reconcile a ClusterwideNetworkPolicy
to nftables rules to control access to and from the kubernetes cluster. It allows also to control the traffic rate going through, to limit network resources for restricted usage scenarios. Nftable and node metrics are exposed with the nftables-exporter
and node-exporter
, the ips are visible as service and endpoint from the kubernetes cluster.
Additional an IDS is managed on the firewall to detect known network anomalies. suricata is used for this purpose. Right now, only basic statistics about the amount of scanned packets is reported. In a future release, access to all alarms will be provided.
For every Service
of type LoadBalancer
in the cluster, the corresponding ingress rules will be automatically generated.
If loadBalancerSourceRanges
is not specified, incomig traffic to this service will be allowed for any source ip adresses.
Firewall Controller is configured with 2 CRDs: firewalls.metal-stack.io
and clusterwidenetworkpolicies.metal-stack.io
. Both are namespaced and must reside in the firewall
namespace. The firewalls
CRD is typically written from the gardener-extension-provider-metal, the clusterwidenetworkpolicy
should be provided by the deployment of your application.
Example Firewall CRD:
apiVersion: metal-stack.io/v1
+kind: Firewall
+metadata:
+ namespace: firewall
+ name: firewall
+spec:
+ # Interval of reconcilation if nftables rules and network traffic accounting
+ interval: 10s
+ # Ratelimits specify on which physical interface, which maximum rate of traffic is allowed
+ ratelimits:
+ # The name of the interface visible with ip link show
+ - interface: vrf104009
+ # The maximum rate in MBits/s
+ rate: 10
+ # Internalprefixes defines a list of prefixes where the traffic going to, or comming from is considered internal, e.g. not leaving into external networks
+ # given the archictecture picture above this would be:
+ internalprefixes:
+ - "1.2.3.0/24
+ - "172.17.0.0/16"
+ - "10.0.0.0/8"
Example ClusterwideNetworkPolicy:
apiVersion: metal-stack.io/v1
+kind: ClusterwideNetworkPolicy
+metadata:
+ namespace: firewall
+ name: clusterwidenetworkpolicy-sample
+spec:
+ egress:
+ - to:
+ - cidr: 1.1.0.0/24
+ except:
+ - 1.1.1.0/16
+ - cidr: 8.8.8.8/32
+ ports:
+ - protocol: UDP
+ port: 53
+ - protocol: TCP
+ port: 53
Once the firewall-controller is running, it will report several statistics to the Firewall CRD Status: This can be inspected by running:
kubectl describe -n firewall firewall
The output would look like:
Status:
+ Last Run: 2020-06-17T13:18:58Z
+ Stats:
+ # Network traffic in bytes separated into external and internal in/out/total
+ Devices:
+ External:
+ In: 91696
+ Out: 34600
+ Total: 0
+ Internal:
+ In: 0
+ Out: 0
+ Total: 2678671
+ # IDS Statistics by interface
+ Idsstats:
+ vrf104009:
+ Drop: 1992
+ Invalidchecksums: 0
+ Packets: 4997276
+ # nftable rule statistics by rule name
+ Rules:
+ Accept:
+ BGP unnumbered:
+ Counter:
+ Bytes: 0
+ Packets: 0
+ SSH incoming connections:
+ Counter:
+ Bytes: 936
+ Packets: 16
+ accept established connections:
+ Counter:
+ Bytes: 21211168
+ Packets: 39785
+ accept icmp:
+ Counter:
+ Bytes: 0
+ Packets: 0
+ accept traffic for k8s service kube-system/vpn-shoot:
+ Counter:
+ Bytes: 360
+ Packets: 6
+ Drop:
+ drop invalid packets:
+ Counter:
+ Bytes: 52
+ Packets: 1
+ drop invalid packets from forwarding to prevent malicious activity:
+ Counter:
+ Bytes: 0
+ Packets: 0
+ drop invalid packets to prevent malicious activity:
+ Counter:
+ Bytes: 0
+ Packets: 0
+ drop packets with invalid ct state:
+ Counter:
+ Bytes: 0
+ Packets: 0
+ drop ping floods:
+ Counter:
+ Bytes: 0
+ Packets: 0
+ Other:
+ block bgp forward to machines:
+ Counter:
+ Bytes: 0
+ Packets: 0
+ count and log dropped packets:
+ Counter:
+ Bytes: 2528
+ Packets: 51
+ snat (networkid: internet):
+ Counter:
+ Bytes: 36960
+ Packets: 486
There are two exporters running on the firewall to report essential metrics from this machine:
Both exporters are exposed as services:
kubectl get svc -n firewall
+NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
+nftables-exporter ClusterIP None <none> 9630/TCP 13h
+node-exporter ClusterIP None <none> 9100/TCP 13h
These services are in front of virtual endpoints:
kubectl get ep -n firewall
+NAME ENDPOINTS AGE
+nftables-exporter 10.3.164.1:9630 13h
+node-exporter 10.3.164.1:9100 13h
You can scrape these services in you prometheus installation to get the metrics.
To check you can run:
curl nftables-exporter.firewall.svc.cluster.local:9630/metrics
+curl node-exporter.firewall.svc.cluster.local:9100/metrics
It is also possible to tail for the dropped packets with the following command (install stern from stern ):
stern -n firewall drop
The output will look like:
+droptailer-6d556bd988-4g8gp droptailer 2020-06-17 13:23:27 +0000 UTC {"DPT":"4000","DST":"1.2.3.4","ID":"54321","IN":"vrf104009","LEN":"40","MAC":"ca:41:f9:80:fa:89:aa:bb:0e:62:8c:a6:08:00","OUT":"vlan179","PREC":"0x00","PROTO":"TCP","RES":"0x00","SPT":"38464","SRC":"2.3.4.5","SYN":"","TOS":"0x00","TTL":"236","URGP":"0","WINDOW":"65535","timestamp":"2020-06-17 13:23:27 +0000 UTC"}
+droptailer-6d556bd988-4g8gp droptailer 2020-06-17 13:23:34 +0000 UTC {"DPT":"2362","DST":"1.2.3.4","ID":"44545","IN":"vrf104009","LEN":"40","MAC":"ca:41:f9:80:fa:89:aa:bb:0e:62:8c:a6:08:00","OUT":"","PREC":"0x00","PROTO":"TCP","RES":"0x00","SPT":"40194","SRC":"2.3.4.5","SYN":"","TOS":"0x00","TTL":"242","URGP":"0","WINDOW":"1024","timestamp":"2020-06-17 13:23:34 +0000 UTC"}
+droptailer-6d556bd988-4g8gp droptailer 2020-06-17 13:23:30 +0000 UTC {"DPT":"650","DST":"1.2.3.4","ID":"12399","IN":"vrf104009","LEN":"40","MAC":"ca:41:f9:80:fa:89:aa:bb:0e:62:8c:a6:08:00","OUT":"vlan179","PREC":"0x00","PROTO":"TCP","RES":"0x00","SPT":"40194","SRC":"2.3.4.5","SYN":"","TOS":"0x00","TTL":"241","URGP":"0","WINDOW":"1024","timestamp":"2020-06-17 13:23:30 +0000 UTC"}
+droptailer-6d556bd988-4g8gp droptailer 2020-06-17 13:23:34 +0000 UTC {"DPT":"2362","DST":"1.2.3.4","ID":"44545","IN":"vrf104009","LEN":"40","MAC":"ca:41:f9:80:fa:89:aa:bb:0e:62:8c:a6:08:00","OUT":"","PREC":"0x00","PROTO":"TCP","RES":"0x00","SPT":"40194","SRC":"2.3.4.5","SYN":"","TOS":"0x00","TTL":"242","URGP":"0","WINDOW":"1024","timestamp":"2020-06-17 13:23:34 +0000 UTC"}
+droptailer-6d556bd988-4g8gp droptailer 2020-06-17 13:23:10 +0000 UTC {"DPT":"63351","DST":"1.2.3.4","ID":"11855","IN":"vrf104009","LEN":"40","MAC":"ca:41:f9:80:fa:89:aa:bb:0e:62:8c:a6:08:00","OUT":"vlan179","PREC":"0x00","PROTO":"TCP","RES":"0x00","SPT":"54589","SRC":"2.3.4.5","SYN":"","TOS":"0x00","TTL":"245","URGP":"0","WINDOW":"1024","timestamp":"2020-06-17 13:23:10 +0000 UTC"}
+droptailer-6d556bd988-4g8gp droptailer 2020-06-17 13:23:51 +0000 UTC {"DPT":"8002","DST":"1.2.3.4","ID":"17539","IN":"vrf104009","LEN":"40","MAC":"ca:41:f9:80:fa:89:aa:bb:0e:62:8c:a6:08:00","OUT":"","PREC":"0x00","PROTO":"TCP","RES":"0x00","SPT":"47615","SRC":"2.3.4.5","SYN":"","TOS":"0x08","TTL":"239","URGP":"0","WINDOW":"1024","timestamp":"2020-06-17 13:23:51 +0000 UTC"}
You can forward the droptailer logs to any log aggregation infrastructure you have in place.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Please check out the contributing section in our docs.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
metalctl is the command line client to access the metal-api.
Download locations:
curl -LO https://github.com/metal-stack/metalctl/releases/latest/download/metalctl-linux-amd64
+chmod +x metalctl-linux-amd64
+sudo mv metalctl-linux-amd64 /usr/local/bin/metalctl
For x86 based Macs:
curl -LO https://github.com/metal-stack/metalctl/releases/latest/download/metalctl-darwin-amd64
+chmod +x metalctl-darwin-amd64
+sudo mv metalctl-darwin-amd64 /usr/local/bin/metalctl
For Apple Silicon (M1) based Macs:
curl -LO https://github.com/metal-stack/metalctl/releases/latest/download/metalctl-darwin-arm64
+chmod +x metalctl-darwin-arm64
+sudo mv metalctl-darwin-arm64 /usr/local/bin/metalctl
curl -LO https://github.com/metal-stack/metalctl/releases/latest/download/metalctl-windows-amd64
+copy metalctl-windows-amd64 metalctl.exe
In order to keep your local metalctl
installation up to date, you can update the binary like this:
metalctl update check
+latest version:v0.8.3 from:2020-08-13T11:55:14Z
+local version:v0.8.2 from:2020-08-12T09:27:39Z
+metalctl is not up to date
+
+metalctl update do
+# a download with progress bar starts and replaces the binary. If the binary has root permissions please execute
+sudo metalctl update do
+# instead
make
+sudo ln -sf $(pwd)/bin/metalctl /usr/local/bin/metalctl
Set up auto-completion for metalctl
, e.g. add to your ~/.bashrc
:
source <(metalctl completion bash)
Set up metalctl
config, by first creating the config folder (mkdir -p ~/.metalctl
), then set the values according to your installation in ~/.metalctl/config.yaml
:
---
+current: prod
+contexts:
+ prod:
+ url: https://api.metal-stack.io/metal
+ issuer_url: https://dex.metal-stack.io/dex
+ client_id: metal_client
+ client_secret: 456
+ hmac: YOUR_HMAC
Optional you can specify issuer_type: generic
if you use other issuers as Dex, e.g. Keycloak (this will request scopes openid,profile,email
):
contexts:
+ prod:
+ url: https://api.metal-stack.io/metal
+ issuer_url: https://keycloak.somedomain.io
+ issuer_type: generic
+ client_id: my-client-id
+ client_secret: my-secret
If you must specify special scopes for your issuer, you can use custom_scopes
:
contexts:
+ prod:
+ url: https://api.metal-stack.io/metal
+ issuer_url: https://keycloak.somedomain.io
+ custom_scopes: roles,openid,profile,email
+ client_id: my-client-id
+ client_secret: my-secret
Full documentation is generated out of the cobra command implementation with:
metalctl markdown
generated markdown is here and here
For MacOS users, running the tests might throw an error because tests are utilizing go-mpatch in order to manipulate the time.Now
function. The patch allows testing with fixed timestamps.
Instead, MacOS users can utilize the make test-in-docker
target to execute the tests.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
a cli to manage entities in the metal-stack api
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ -h, --help help for metalctl
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage audit trace entities
show audit traces of the api. feature must be enabled on server-side.
-h, --help help for audit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the audit trace
metalctl audit describe <id> [flags]
-h, --help help for describe
+ --phase string phase of the audit trace. One of [request, response, single, error, opened, closed] (default "response")
+ --prettify-body attempts to interpret the body as json and prettifies it
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all audit traces
metalctl audit list [flags]
--component string component of the audit trace.
+ --detail string detail of the audit trace. An HTTP method, unary or stream
+ --error string error of the audit trace.
+ --forwarded-for string forwarded for of the audit trace.
+ --from string start of range of the audit traces. e.g. 1h, 10m, 2006-01-02 15:04:05 (default "1h")
+ -h, --help help for list
+ --limit int limit the number of audit traces. (default 100)
+ --path string api path of the audit trace.
+ --phase string phase of the audit trace. One of [request, response, single, error, opened, closed]
+ -q, --query string filters audit trace body payloads for the given text.
+ --remote-addr string remote address of the audit trace.
+ --request-id string request id of the audit trace.
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: path|tenant|timestamp|user
+ --status-code int32 HTTP status code of the audit trace.
+ --tenant string tenant of the audit trace.
+ --to string end of range of the audit traces. e.g. 1h, 10m, 2006-01-02 15:04:05
+ --type string type of the audit trace. One of [http, grpc, event].
+ --user string user of the audit trace.
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Generate the autocompletion script for the specified shell
Generate the autocompletion script for metalctl for the specified shell. See each sub-command's help for details on how to use the generated script.
-h, --help help for completion
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Generate the autocompletion script for bash
Generate the autocompletion script for the bash shell.
This script depends on the 'bash-completion' package. If it is not installed already, you can install it via your OS's package manager.
To load completions in your current shell session:
source <(metalctl completion bash)
To load completions for every new session, execute once:
metalctl completion bash > /etc/bash_completion.d/metalctl
metalctl completion bash > $(brew --prefix)/etc/bash_completion.d/metalctl
You will need to start a new shell for this setup to take effect.
metalctl completion bash
-h, --help help for bash
+ --no-descriptions disable completion descriptions
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Generate the autocompletion script for fish
Generate the autocompletion script for the fish shell.
To load completions in your current shell session:
metalctl completion fish | source
To load completions for every new session, execute once:
metalctl completion fish > ~/.config/fish/completions/metalctl.fish
You will need to start a new shell for this setup to take effect.
metalctl completion fish [flags]
-h, --help help for fish
+ --no-descriptions disable completion descriptions
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Generate the autocompletion script for powershell
Generate the autocompletion script for powershell.
To load completions in your current shell session:
metalctl completion powershell | Out-String | Invoke-Expression
To load completions for every new session, add the output of the above command to your powershell profile.
metalctl completion powershell [flags]
-h, --help help for powershell
+ --no-descriptions disable completion descriptions
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Generate the autocompletion script for zsh
Generate the autocompletion script for the zsh shell.
If shell completion is not already enabled in your environment you will need to enable it. You can execute the following once:
echo "autoload -U compinit; compinit" >> ~/.zshrc
To load completions in your current shell session:
source <(metalctl completion zsh)
To load completions for every new session, execute once:
metalctl completion zsh > "${fpath[1]}/_metalctl"
metalctl completion zsh > $(brew --prefix)/share/zsh/site-functions/_metalctl
You will need to start a new shell for this setup to take effect.
metalctl completion zsh [flags]
-h, --help help for zsh
+ --no-descriptions disable completion descriptions
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage metalctl context
context defines the backend to which metalctl talks to. You can switch back and forth with "-"
metalctl context <name> [flags]
+~/.metalctl/config.yaml
+---
+current: prod
+contexts:
+ prod:
+ url: https://api.metal-stack.io/metal
+ issuer_url: https://dex.metal-stack.io/dex
+ client_id: metal_client
+ client_secret: 456
+ dev:
+ url: https://api.metal-stack.dev/metal
+ issuer_url: https://dex.metal-stack.dev/dex
+ client_id: metal_client
+ client_secret: 123
+...
+
-h, --help help for context
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
only show the default context name
metalctl context short [flags]
-h, --help help for short
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage filesystemlayout entities
a filesystemlayout is a specification how the disks in a machine are partitioned, formatted and mounted.
-h, --help help for filesystemlayout
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more filesystemlayouts from a given file
metalctl filesystemlayout apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl filesystemlayout describe filesystemlayout-1 -o yaml > filesystemlayout.yaml
+ $ vi filesystemlayout.yaml
+ $ # either via stdin
+ $ cat filesystemlayout.yaml | metalctl filesystemlayout apply -f -
+ $ # or via file
+ $ metalctl filesystemlayout apply -f filesystemlayout.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the filesystemlayout
metalctl filesystemlayout create [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl filesystemlayout describe filesystemlayout-1 -o yaml > filesystemlayout.yaml
+ $ vi filesystemlayout.yaml
+ $ # either via stdin
+ $ cat filesystemlayout.yaml | metalctl filesystemlayout create -f -
+ $ # or via file
+ $ metalctl filesystemlayout create -f filesystemlayout.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the filesystemlayout
metalctl filesystemlayout delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl filesystemlayout describe filesystemlayout-1 -o yaml > filesystemlayout.yaml
+ $ vi filesystemlayout.yaml
+ $ # either via stdin
+ $ cat filesystemlayout.yaml | metalctl filesystemlayout delete <id> -f -
+ $ # or via file
+ $ metalctl filesystemlayout delete <id> -f filesystemlayout.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the filesystemlayout
metalctl filesystemlayout describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the filesystemlayout through an editor and update
metalctl filesystemlayout edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all filesystemlayouts
metalctl filesystemlayout list [flags]
-h, --help help for list
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
check if a machine satisfies all disk requirements of a given filesystemlayout
metalctl filesystemlayout match [flags]
--filesystemlayout string filesystemlayout id to check against [required]
+ -h, --help help for match
+ --machine string machine id to check for match [required]
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
try to detect a filesystem by given size and image
metalctl filesystemlayout try [flags]
-h, --help help for try
+ --image string image to try
+ --size string size to try
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the filesystemlayout
metalctl filesystemlayout update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl filesystemlayout describe filesystemlayout-1 -o yaml > filesystemlayout.yaml
+ $ vi filesystemlayout.yaml
+ $ # either via stdin
+ $ cat filesystemlayout.yaml | metalctl filesystemlayout update -f -
+ $ # or via file
+ $ metalctl filesystemlayout update -f filesystemlayout.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage firewall entities
firewalls are used to establish network connectivity between metal-stack networks. firewalls are similar to machines but are managed by the provider. almost every command of the machine command subset works on firewalls, too.
-h, --help help for firewall
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the firewall
metalctl firewall create [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -d, --description string Description of the firewall to create. [optional]
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl firewall describe firewall-1 -o yaml > firewall.yaml
+ $ vi firewall.yaml
+ $ # either via stdin
+ $ cat firewall.yaml | metalctl firewall create -f -
+ $ # or via file
+ $ metalctl firewall create -f firewall.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ --filesystemlayout string Filesystemlayout to use during machine installation. [optional]
+ -h, --help help for create
+ -H, --hostname string Hostname of the firewall. [required]
+ -I, --id string ID of a specific firewall to allocate, if given, size and partition are ignored. Need to be set to reserved (--reserve) state before.
+ -i, --image string OS Image to install. [required]
+ --ips strings Sets the firewall's IP address. Usage: [--ips[=IPV4-ADDRESS[,IPV4-ADDRESS]...]]...
+ IPV4-ADDRESS specifies the IPv4 address to add.
+ It can only be used in conjunction with --networks.
+ -n, --name string Name of the firewall. [optional]
+ --networks strings Adds network(s). Usage: --networks NETWORK[:MODE][,NETWORK[:MODE]]... [--networks NETWORK[:MODE][,
+ NETWORK[:MODE]]...]...
+ NETWORK specifies the id of an existing network.
+ MODE can be omitted or one of:
+ auto IP address is automatically acquired from the given network
+ noauto No automatic IP address acquisition
+ -S, --partition string partition/datacenter where the firewall is created. [required, except for reserved machines]
+ -P, --project string Project where the firewall should belong to. [required]
+ -s, --size string Size of the firewall. [required, except for reserved machines]
+ --skip-security-prompts skips security prompt for bulk operations
+ -p, --sshpublickey string SSH public key for access via ssh and console. [optional]
+ Can be either the public key as string, or pointing to the public key file to use e.g.: "@~/.ssh/id_rsa.pub".
+ If ~/.ssh/[id_ed25519.pub | id_rsa.pub | id_dsa.pub] is present it will be picked as default, matching the first one in this order.
+ --tags strings tags to add to the firewall, use it like: --tags "tag1,tag2" or --tags "tag3".
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
+ --userdata string cloud-init.io compatible userdata. [optional]
+ Can be either the userdata as string, or pointing to the userdata file to use e.g.: "@/tmp/userdata.cfg".
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the firewall
metalctl firewall describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all firewalls
metalctl firewall list [flags]
-h, --help help for list
+ --hostname string allocation hostname to filter [optional]
+ --id string ID to filter [optional]
+ --image string allocation image to filter [optional]
+ --mac string mac to filter [optional]
+ --name string allocation name to filter [optional]
+ --partition string partition to filter [optional]
+ --project string allocation project to filter [optional]
+ --size string size to filter [optional]
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: age|event|id|image|liveliness|partition|project|size|when
+ --tags strings tags to filter, use it like: --tags "tag1,tag2" or --tags "tag3".
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
SSH to a firewall
SSH to a firewall via VPN.
metalctl firewall ssh <firewall ID> [flags]
-h, --help help for ssh
+ -i, --identity string specify identity file to SSH to the firewall like: -i path/to/id_rsa (default "~/.ssh/id_rsa")
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage firmwares
list, upload and remove firmwares.
-h, --help help for firmware
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
delete a firmware
deletes the specified firmware.
metalctl firmware delete [flags]
--board string the board type (required)
+ -h, --help help for delete
+ --kind string the firmware kind [bmc|bios] (required)
+ --revision string the firmware revision (required)
+ --vendor string the vendor (required)
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list firmwares
lists all available firmwares matching the given criteria.
metalctl firmware list [flags]
--board string the board type
+ -h, --help help for list
+ --kind string the firmware kind [bmc|bios]
+ --machineid string the machine id (ignores vendor and board flags)
+ --vendor string the vendor
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
upload a firmware
-h, --help help for upload
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
upload a BIOS firmware
the given BIOS firmware file will be uploaded and tagged as given revision.
metalctl firmware upload bios <file> [flags]
--board string the board type (required)
+ -h, --help help for bios
+ --revision string the BIOS firmware revision (required)
+ --vendor string the vendor (required)
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
upload a BMC firmware
the given BMC firmware file will be uploaded and tagged as given revision.
metalctl firmware upload bmc <file> [flags]
--board string the board type (required)
+ -h, --help help for bmc
+ --revision string the BMC firmware revision (required)
+ --vendor string the vendor (required)
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
shows the server health
metalctl health [flags]
-h, --help help for health
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage image entities
os images available to be installed on machines.
-h, --help help for image
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more images from a given file
metalctl image apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl image describe image-1 -o yaml > image.yaml
+ $ vi image.yaml
+ $ # either via stdin
+ $ cat image.yaml | metalctl image apply -f -
+ $ # or via file
+ $ metalctl image apply -f image.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the image
metalctl image create [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -d, --description string Description of the image.
+ --features strings features of the image, can be one of machine|firewall
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl image describe image-1 -o yaml > image.yaml
+ $ vi image.yaml
+ $ # either via stdin
+ $ cat image.yaml | metalctl image create -f -
+ $ # or via file
+ $ metalctl image create -f image.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --id string ID of the image.
+ -n, --name string Name of the image.
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
+ --url string url of the image.
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the image
metalctl image delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl image describe image-1 -o yaml > image.yaml
+ $ vi image.yaml
+ $ # either via stdin
+ $ cat image.yaml | metalctl image delete <id> -f -
+ $ # or via file
+ $ metalctl image delete <id> -f image.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the image
metalctl image describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the image through an editor and update
metalctl image edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all images
metalctl image list [flags]
--classification string Classification of this image.
+ --features string Features of this image.
+ -h, --help help for list
+ --id string ID of the image.
+ --name string Name of the image.
+ --os string OS derivate of this image.
+ --show-usage show from how many allocated machines every image is used
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: classification|description|expiration|id|name
+ --version string Version of this image.
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the image
metalctl image update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl image describe image-1 -o yaml > image.yaml
+ $ vi image.yaml
+ $ # either via stdin
+ $ cat image.yaml | metalctl image update -f -
+ $ # or via file
+ $ metalctl image update -f image.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
login user and receive token
login and receive token that will be used to authenticate commands.
metalctl login [flags]
-h, --help help for login
+ --print-only If true, the token is printed to stdout
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
logout user from OIDC SSO session
metalctl logout [flags]
-h, --help help for logout
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage machine entities
a machine is a bare metal server provisioned through metal-stack that is intended to run user workload.
-h, --help help for machine
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more machines from a given file
metalctl machine apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl machine describe machine-1 -o yaml > machine.yaml
+ $ vi machine.yaml
+ $ # either via stdin
+ $ cat machine.yaml | metalctl machine apply -f -
+ $ # or via file
+ $ metalctl machine apply -f machine.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
console access to a machine
console access to a machine, machine must be created with a ssh public key, authentication is done with your private key. In case the machine did not register properly a direct ipmi console access is available via the –ipmi flag. This is only for administrative access.
metalctl machine console <machine ID> [flags]
-h, --help help for console
+ --ipmi use ipmitool with direct network access (admin only).
+ --ipmipassword string overwrite ipmi password (admin only).
+ --ipmiuser string overwrite ipmi user (admin only).
+ -p, --sshidentity string SSH key file, if not given the default ssh key will be used if present [optional].
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
fetch the consolepassword for a machine
metalctl machine consolepassword <machine ID> [flags]
-h, --help help for consolepassword
+ --reason string a short description why access to the consolepassword is required
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the machine
metalctl machine create [flags]
machine create can be done in two different ways:
+
+- default with automatic allocation:
+
+ metalctl machine create \
+ --hostname worker01 \
+ --name worker \
+ --image ubuntu-18.04 \ # query available with: metalctl image list
+ --size t1-small-x86 \ # query available with: metalctl size list
+ --partition test \ # query available with: metalctl partition list
+ --project cluster01 \
+ --sshpublickey "@~/.ssh/id_rsa.pub"
+
+- for metal administration with reserved machines:
+
+ reserve a machine you want to allocate:
+
+ metalctl machine reserve 00000000-0000-0000-0000-0cc47ae54694 --description "blocked for maintenance"
+
+ allocate this machine:
+
+ metalctl machine create \
+ --hostname worker01 \
+ --name worker \
+ --image ubuntu-18.04 \ # query available with: metalctl image list
+ --project cluster01 \
+ --sshpublickey "@~/.ssh/id_rsa.pub" \
+ --id 00000000-0000-0000-0000-0cc47ae54694
+
+after you do not want to use this machine exclusive, remove the reservation:
+
+metalctl machine reserve 00000000-0000-0000-0000-0cc47ae54694 --remove
+
+Once created the machine installation can not be modified anymore.
+
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -d, --description string Description of the machine to create. [optional]
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl machine describe machine-1 -o yaml > machine.yaml
+ $ vi machine.yaml
+ $ # either via stdin
+ $ cat machine.yaml | metalctl machine create -f -
+ $ # or via file
+ $ metalctl machine create -f machine.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ --filesystemlayout string Filesystemlayout to use during machine installation. [optional]
+ -h, --help help for create
+ -H, --hostname string Hostname of the machine. [required]
+ -I, --id string ID of a specific machine to allocate, if given, size and partition are ignored. Need to be set to reserved (--reserve) state before.
+ -i, --image string OS Image to install. [required]
+ --ips strings Sets the machine's IP address. Usage: [--ips[=IPV4-ADDRESS[,IPV4-ADDRESS]...]]...
+ IPV4-ADDRESS specifies the IPv4 address to add.
+ It can only be used in conjunction with --networks.
+ -n, --name string Name of the machine. [optional]
+ --networks strings Adds a network. Usage: [--networks NETWORK[:MODE][,NETWORK[:MODE]]...]...
+ NETWORK specifies the name or id of an existing network.
+ MODE cane be omitted or one of:
+ auto IP address is automatically acquired from the given network
+ noauto IP address for the given network must be provided via --ips
+ -S, --partition string partition/datacenter where the machine is created. [required, except for reserved machines]
+ -P, --project string Project where the machine should belong to. [required]
+ -s, --size string Size of the machine. [required, except for reserved machines]
+ --skip-security-prompts skips security prompt for bulk operations
+ -p, --sshpublickey string SSH public key for access via ssh and console. [optional]
+ Can be either the public key as string, or pointing to the public key file to use e.g.: "@~/.ssh/id_rsa.pub".
+ If ~/.ssh/[id_ed25519.pub | id_rsa.pub | id_dsa.pub] is present it will be picked as default, matching the first one in this order.
+ --tags strings tags to add to the machine, use it like: --tags "tag1,tag2" or --tags "tag3".
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
+ --userdata string cloud-init.io compatible userdata. [optional]
+ Can be either the userdata as string, or pointing to the userdata file to use e.g.: "@/tmp/userdata.cfg".
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the machine
delete a machine and destroy all data stored on the local disks. Once destroyed it is back for usage by other projects. A destroyed machine can not restored anymore
metalctl machine delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl machine describe machine-1 -o yaml > machine.yaml
+ $ vi machine.yaml
+ $ # either via stdin
+ $ cat machine.yaml | metalctl machine delete <id> -f -
+ $ # or via file
+ $ metalctl machine delete <id> -f machine.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --remove-from-database remove given machine from the database, is only required for maintenance reasons [optional] (admin only).
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the machine
metalctl machine describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the machine through an editor and update
metalctl machine edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage machine chassis identify LED power
-h, --help help for identify
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
power off the machine chassis identify LED
set the machine chassis identify LED to off state
metalctl machine identify off <machine ID> [flags]
-d, --description string description of the reason for chassis identify LED turn-off. (default "Triggered by metalctl")
+ -h, --help help for off
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
power on the machine chassis identify LED
set the machine chassis identify LED to on state
metalctl machine identify on <machine ID> [flags]
-d, --description string description of the reason for chassis identify LED turn-on.
+ -h, --help help for on
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
display ipmi details of the machine, if no machine ID is given all ipmi addresses are returned.
display ipmi details of the machine, if no machine ID is given all ipmi addresses are returned.
Meaning of the emojis:
🚧 Machine is reserved. Reserved machines are not considered for random allocation until the reservation flag is removed. 🔒 Machine is locked. Locked machines can not be deleted until the lock is removed. 💀 Machine is dead. The metal-api does not receive any events from this machine. ❗ Machine has a last event error. The machine has recently encountered an error during the provisioning lifecycle. ❓ Machine is in unknown condition. The metal-api does not receive phoned home events anymore or has never booted successfully. ⭕ Machine is in a provisioning crash loop. Flag can be reset through an API-triggered reboot or when the machine reaches the phoned home state. 🚑 Machine reclaim has failed. The machine was deleted but it is not going back into the available machine pool. 🛡 Machine is connected to our VPN, ssh access only possible via this VPN.
metalctl machine ipmi [<machine ID>] [flags]
--bmc-address string bmc ipmi address (needs to include port) to filter [optional]
+ --bmc-mac string bmc mac address to filter [optional]
+ --board-part-number string fru board part number to filter [optional]
+ -h, --help help for ipmi
+ --hostname string allocation hostname to filter [optional]
+ --id string ID to filter [optional]
+ --image string allocation image to filter [optional]
+ --last-event-error-threshold duration the duration up to how long in the past a machine last event error will be counted as an issue [optional] (default 1h0m0s)
+ --mac string mac to filter [optional]
+ --manufacturer string fru manufacturer to filter [optional]
+ --name string allocation name to filter [optional]
+ --network-destination-prefixes string network destination prefixes to filter [optional]
+ --network-ids string network ids to filter [optional]
+ --network-ips string network ips to filter [optional]
+ --partition string partition to filter [optional]
+ --product-part-number string fru product part number to filter [optional]
+ --product-serial string fru product serial to filter [optional]
+ --project string allocation project to filter [optional]
+ --rack string rack to filter [optional]
+ --role string allocation role to filter [optional]
+ --size string size to filter [optional]
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: age|bios|bmc|event|id|liveliness|partition|project|rack|size|when
+ --state string state to filter [optional]
+ --tags strings tags to filter, use it like: --tags "tag1,tag2" or --tags "tag3".
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
display machine hardware events
metalctl machine ipmi events <machine ID> [flags]
-h, --help help for events
+ --ipmipassword string overwrite ipmi password (admin only).
+ --ipmiuser string overwrite ipmi user (admin only).
+ -n, --last string show last <n> log entries. (default "10")
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
display machines which are in a potential bad state
display machines which are in a potential bad state
Meaning of the emojis:
🚧 Machine is reserved. Reserved machines are not considered for random allocation until the reservation flag is removed. 🔒 Machine is locked. Locked machines can not be deleted until the lock is removed. 💀 Machine is dead. The metal-api does not receive any events from this machine. ❗ Machine has a last event error. The machine has recently encountered an error during the provisioning lifecycle. ❓ Machine is in unknown condition. The metal-api does not receive phoned home events anymore or has never booted successfully. ⭕ Machine is in a provisioning crash loop. Flag can be reset through an API-triggered reboot or when the machine reaches the phoned home state. 🚑 Machine reclaim has failed. The machine was deleted but it is not going back into the available machine pool. 🛡 Machine is connected to our VPN, ssh access only possible via this VPN.
metalctl machine issues [<machine ID>] [flags]
--bmc-address string bmc ipmi address (needs to include port) to filter [optional]
+ --bmc-mac string bmc mac address to filter [optional]
+ --board-part-number string fru board part number to filter [optional]
+ -h, --help help for issues
+ --hostname string allocation hostname to filter [optional]
+ --id string ID to filter [optional]
+ --image string allocation image to filter [optional]
+ --last-event-error-threshold duration the duration up to how long in the past a machine last event error will be counted as an issue [optional]
+ --mac string mac to filter [optional]
+ --manufacturer string fru manufacturer to filter [optional]
+ --name string allocation name to filter [optional]
+ --network-destination-prefixes string network destination prefixes to filter [optional]
+ --network-ids string network ids to filter [optional]
+ --network-ips string network ips to filter [optional]
+ --omit strings issue types to omit [optional]
+ --only strings issue types to include [optional]
+ --partition string partition to filter [optional]
+ --product-part-number string fru product part number to filter [optional]
+ --product-serial string fru product serial to filter [optional]
+ --project string allocation project to filter [optional]
+ --rack string rack to filter [optional]
+ --role string allocation role to filter [optional]
+ --severity string issue severity to include [optional]
+ --size string size to filter [optional]
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: age|bios|bmc|event|id|liveliness|partition|project|rack|size|when
+ --state string state to filter [optional]
+ --tags strings tags to filter, use it like: --tags "tag1,tag2" or --tags "tag3".
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all machine issues that the metal-api can evaluate
metalctl machine issues list [flags]
-h, --help help for list
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: id|severity
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all machines
list all machines
Meaning of the emojis:
🚧 Machine is reserved. Reserved machines are not considered for random allocation until the reservation flag is removed. 🔒 Machine is locked. Locked machines can not be deleted until the lock is removed. 💀 Machine is dead. The metal-api does not receive any events from this machine. ❗ Machine has a last event error. The machine has recently encountered an error during the provisioning lifecycle. ❓ Machine is in unknown condition. The metal-api does not receive phoned home events anymore or has never booted successfully. ⭕ Machine is in a provisioning crash loop. Flag can be reset through an API-triggered reboot or when the machine reaches the phoned home state. 🚑 Machine reclaim has failed. The machine was deleted but it is not going back into the available machine pool. 🛡 Machine is connected to our VPN, ssh access only possible via this VPN.
metalctl machine list [flags]
--bmc-address string bmc ipmi address (needs to include port) to filter [optional]
+ --bmc-mac string bmc mac address to filter [optional]
+ --board-part-number string fru board part number to filter [optional]
+ -h, --help help for list
+ --hostname string allocation hostname to filter [optional]
+ --id string ID to filter [optional]
+ --image string allocation image to filter [optional]
+ --last-event-error-threshold duration the duration up to how long in the past a machine last event error will be counted as an issue [optional] (default 1h0m0s)
+ --mac string mac to filter [optional]
+ --manufacturer string fru manufacturer to filter [optional]
+ --name string allocation name to filter [optional]
+ --network-destination-prefixes string network destination prefixes to filter [optional]
+ --network-ids string network ids to filter [optional]
+ --network-ips string network ips to filter [optional]
+ --partition string partition to filter [optional]
+ --product-part-number string fru product part number to filter [optional]
+ --product-serial string fru product serial to filter [optional]
+ --project string allocation project to filter [optional]
+ --rack string rack to filter [optional]
+ --role string allocation role to filter [optional]
+ --size string size to filter [optional]
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: age|event|id|image|liveliness|partition|project|rack|size|when
+ --state string state to filter [optional]
+ --tags strings tags to filter, use it like: --tags "tag1,tag2" or --tags "tag3".
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
lock a machine
when a machine is locked, it can not be destroyed, to destroy a machine you must first remove the lock from that machine with –remove
metalctl machine lock <machine ID> [flags]
-d, --description string description of the reason for the lock.
+ -h, --help help for lock
+ -r, --remove remove the lock.
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
display machine provisioning logs
metalctl machine logs <machine ID> [flags]
-h, --help help for logs
+ --last-event-error-threshold duration the duration up to how long in the past a machine last event error will be counted as an issue [optional] (default 168h0m0s)
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage machine power
-h, --help help for power
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
boot a machine into BIOS
the machine will boot into bios. (machine does not reboot automatically)
metalctl machine power bios <machine ID> [flags]
-h, --help help for bios
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
power cycle a machine (graceful shutdown)
(soft) cycle the machine power.
metalctl machine power cycle <machine ID> [flags]
-h, --help help for cycle
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
boot a machine from disk
the machine will boot from disk. (machine does not reboot automatically)
metalctl machine power disk <machine ID> [flags]
-h, --help help for disk
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
power off a machine
set the machine to power off state, if the machine already was off nothing happens. It will usually take some time to power off the machine, depending on the machine type. Power on will therefore not work if the machine is in the powering off phase.
metalctl machine power off <machine ID> [flags]
-h, --help help for off
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
power on a machine
set the machine to power on state, if the machine already was on nothing happens.
metalctl machine power on <machine ID> [flags]
-h, --help help for on
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
boot a machine from PXE
the machine will boot from PXE. (machine does not reboot automatically)
metalctl machine power pxe <machine ID> [flags]
-h, --help help for pxe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
power reset a machine
(hard) reset the machine power.
metalctl machine power reset <machine ID> [flags]
-h, --help help for reset
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
reinstalls an already allocated machine
reinstalls an already allocated machine. If it is not yet allocated, nothing happens, otherwise only the machine's primary disk is wiped and the new image will subsequently be installed on that device
metalctl machine reinstall <machine ID> [flags]
-d, --description string description of the reinstallation. [optional]
+ -h, --help help for reinstall
+ --image string id of the image to get installed. [required]
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
reserve a machine
reserve a machine for exclusive usage, this machine will no longer be picked by other allocations. This is useful for maintenance of the machine or testing. After the reservation is not needed anymore, the reservation should be removed with –remove.
metalctl machine reserve <machine ID> [flags]
-d, --description string description of the reason for the reservation.
+ -h, --help help for reserve
+ -r, --remove remove the reservation.
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
update a machine firmware
-h, --help help for update-firmware
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
update a machine BIOS
the machine BIOS will be updated to given revision. If revision flag is not specified an update plan will be printed instead.
metalctl machine update-firmware bios <machine ID> [flags]
--description string the reason why the BIOS should be updated
+ -h, --help help for bios
+ --revision string the BIOS revision
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
update a machine BMC
the machine BMC will be updated to given revision. If revision flag is not specified an update plan will be printed instead.
metalctl machine update-firmware bmc <machine ID> [flags]
--description string the reason why the BMC should be updated
+ -h, --help help for bmc
+ --revision string the BMC revision
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the machine
metalctl machine update [flags]
--add-tags strings tags to be added to the machine [optional]
+ --bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ --description string the description of the machine [optional]
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl machine describe machine-1 -o yaml > machine.yaml
+ $ vi machine.yaml
+ $ # either via stdin
+ $ cat machine.yaml | metalctl machine update -f -
+ $ # or via file
+ $ metalctl machine update -f machine.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --remove-tags strings tags to be removed from the machine [optional]
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
create markdown documentation
metalctl markdown [flags]
-h, --help help for markdown
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage network entities
networks can be attached to a machine or firewall such that they can communicate with each other.
-h, --help help for network
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
allocate a network
metalctl network allocate [flags]
-d, --description string description of the network to create. [optional]
+ --dmz use this private network as dmz. [optional]
+ -h, --help help for allocate
+ --labels strings labels for this network. [optional]
+ -n, --name string name of the network to create. [required]
+ --partition string partition where this network should exist. [required]
+ --project string partition where this network should exist. [required]
+ --shared shared allows usage of this private network from other networks
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more networks from a given file
metalctl network apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl network describe network-1 -o yaml > network.yaml
+ $ vi network.yaml
+ $ # either via stdin
+ $ cat network.yaml | metalctl network apply -f -
+ $ # or via file
+ $ metalctl network apply -f network.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the network
metalctl network create [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -d, --description string description of the network to create. [optional]
+ --destination-prefixes strings destination prefixes in this network.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl network describe network-1 -o yaml > network.yaml
+ $ vi network.yaml
+ $ # either via stdin
+ $ cat network.yaml | metalctl network create -f -
+ $ # or via file
+ $ metalctl network create -f network.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --id string id of the network to create. [optional]
+ --labels strings add initial labels, must be in the form of key=value, use it like: --labels "key1=value1,key2=value2".
+ -n, --name string name of the network to create. [optional]
+ --nat set nat flag of network, if set to true, traffic from this network will be natted.
+ -p, --partition string partition where this network should exist.
+ --prefixes strings prefixes in this network.
+ --privatesuper set private super flag of network, if set to true, this network is used to start machines there.
+ --project string project of the network to create. [optional]
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
+ --underlay set underlay flag of network, if set to true, this is used to transport underlay network traffic
+ --vrf int vrf of this network
+ --vrfshared vrf shared allows multiple networks to share a vrf
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the network
metalctl network delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl network describe network-1 -o yaml > network.yaml
+ $ vi network.yaml
+ $ # either via stdin
+ $ cat network.yaml | metalctl network delete <id> -f -
+ $ # or via file
+ $ metalctl network delete <id> -f network.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the network
metalctl network describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the network through an editor and update
metalctl network edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
free a network
metalctl network free <networkid> [flags]
-h, --help help for free
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage ip entities
an ip address can be attached to a machine or firewall such that network traffic can be routed to these servers.
-h, --help help for ip
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more ips from a given file
metalctl network ip apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl ip describe ip-1 -o yaml > ip.yaml
+ $ vi ip.yaml
+ $ # either via stdin
+ $ cat ip.yaml | metalctl ip apply -f -
+ $ # or via file
+ $ metalctl ip apply -f ip.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the ip
metalctl network ip create [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -d, --description string description of the IP to allocate. [optional]
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl ip describe ip-1 -o yaml > ip.yaml
+ $ vi ip.yaml
+ $ # either via stdin
+ $ cat ip.yaml | metalctl ip create -f -
+ $ # or via file
+ $ metalctl ip create -f ip.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --ipaddress string a specific ip address to allocate. [optional]
+ -n, --name string name of the IP to allocate. [optional]
+ --network string network from where the IP should be allocated.
+ --project string project for which the IP should be allocated.
+ --skip-security-prompts skips security prompt for bulk operations
+ --tags strings tags to attach to the IP.
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
+ --type string type of the IP to allocate: ephemeral|static [optional] (default "ephemeral")
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the ip
metalctl network ip delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl ip describe ip-1 -o yaml > ip.yaml
+ $ vi ip.yaml
+ $ # either via stdin
+ $ cat ip.yaml | metalctl ip delete <id> -f -
+ $ # or via file
+ $ metalctl ip delete <id> -f ip.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the ip
metalctl network ip describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the ip through an editor and update
metalctl network ip edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
display ips which are in a potential bad state
metalctl network ip issues [flags]
-h, --help help for issues
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all ips
metalctl network ip list [flags]
-h, --help help for list
+ --ipaddress string ipaddress to filter [optional]
+ --machineid string machineid to filter [optional]
+ --name string name to filter [optional]
+ --network string network to filter [optional]
+ --prefix string prefix to filter [optional]
+ --project string project to filter [optional]
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|ipaddress|name|network|type
+ --tags strings tags to filter [optional]
+ --type string type to filter [optional]
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the ip
metalctl network ip update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl ip describe ip-1 -o yaml > ip.yaml
+ $ vi ip.yaml
+ $ # either via stdin
+ $ cat ip.yaml | metalctl ip update -f -
+ $ # or via file
+ $ metalctl ip update -f ip.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all networks
metalctl network list [flags]
--destination-prefixes strings destination prefixes to filter, use it like: --destination-prefixes prefix1,prefix2.
+ -h, --help help for list
+ --id string ID to filter [optional]
+ --name string name to filter [optional]
+ --nat nat to filter [optional]
+ --parent string parent network to filter [optional]
+ --partition string partition to filter [optional]
+ --prefixes strings prefixes to filter, use it like: --prefixes prefix1,prefix2.
+ --privatesuper privatesuper to filter [optional]
+ --project string project to filter [optional]
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name|partition|project
+ --underlay underlay to filter [optional]
+ --vrf int vrf to filter [optional]
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the network
metalctl network update [flags]
--add-destinationprefixes strings destination prefixes to be added to the network [optional]
+ --add-prefixes strings prefixes to be added to the network [optional]
+ --bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ --description string the description of the network [optional]
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl network describe network-1 -o yaml > network.yaml
+ $ vi network.yaml
+ $ # either via stdin
+ $ cat network.yaml | metalctl network update -f -
+ $ # or via file
+ $ metalctl network update -f network.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --labels strings the labels of the network, must be in the form of key=value, use it like: --labels "key1=value1,key2=value2". [optional]
+ --name string the name of the network [optional]
+ --remove-destinationprefixes strings destination prefixes to be removed from the network [optional]
+ --remove-prefixes strings prefixes to be removed from the network [optional]
+ --shared marks a network as shared or not [optional]
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage partition entities
a partition is a failure domain in the data center.
-h, --help help for partition
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more partitions from a given file
metalctl partition apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl partition describe partition-1 -o yaml > partition.yaml
+ $ vi partition.yaml
+ $ # either via stdin
+ $ cat partition.yaml | metalctl partition apply -f -
+ $ # or via file
+ $ metalctl partition apply -f partition.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
show partition capacity
metalctl partition capacity [flags]
-h, --help help for capacity
+ --id string filter on partition id. [optional]
+ --size string filter on size id. [optional]
+ --sort-by strings order by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the partition
metalctl partition create [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ --cmdline string kernel commandline for the metal-hammer in the partition. [required]
+ -d, --description string Description of the partition. [required]
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl partition describe partition-1 -o yaml > partition.yaml
+ $ vi partition.yaml
+ $ # either via stdin
+ $ cat partition.yaml | metalctl partition create -f -
+ $ # or via file
+ $ metalctl partition create -f partition.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --id string ID of the partition. [required]
+ --imageurl string initrd for the metal-hammer in the partition. [required]
+ --kernelurl string kernel url for the metal-hammer in the partition. [required]
+ --mgmtserver string management server address in the partition. [required]
+ -n, --name string Name of the partition. [optional]
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the partition
metalctl partition delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl partition describe partition-1 -o yaml > partition.yaml
+ $ vi partition.yaml
+ $ # either via stdin
+ $ cat partition.yaml | metalctl partition delete <id> -f -
+ $ # or via file
+ $ metalctl partition delete <id> -f partition.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the partition
metalctl partition describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the partition through an editor and update
metalctl partition edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all partitions
metalctl partition list [flags]
-h, --help help for list
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the partition
metalctl partition update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl partition describe partition-1 -o yaml > partition.yaml
+ $ vi partition.yaml
+ $ # either via stdin
+ $ cat partition.yaml | metalctl partition update -f -
+ $ # or via file
+ $ metalctl partition update -f partition.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage project entities
a project belongs to a tenant and groups together entities in metal-stack.
-h, --help help for project
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more projects from a given file
metalctl project apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl project describe project-1 -o yaml > project.yaml
+ $ vi project.yaml
+ $ # either via stdin
+ $ cat project.yaml | metalctl project apply -f -
+ $ # or via file
+ $ metalctl project apply -f project.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the project
metalctl project create [flags]
--annotation strings add initial annotation, must be in the form of key=value, can be given multiple times to add multiple annotations, e.g. --annotation key=value --annotation foo=bar
+ --bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ --cluster-quota int32 cluster quota
+ --description string description of the project.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl project describe project-1 -o yaml > project.yaml
+ $ vi project.yaml
+ $ # either via stdin
+ $ cat project.yaml | metalctl project create -f -
+ $ # or via file
+ $ metalctl project create -f project.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --ip-quota int32 ip quota
+ --label strings add initial label, can be given multiple times to add multiple labels, e.g. --label=foo --label=bar
+ --machine-quota int32 machine quota
+ --name string name of the project, max 10 characters.
+ --skip-security-prompts skips security prompt for bulk operations
+ --tenant string create project for given tenant
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the project
metalctl project delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl project describe project-1 -o yaml > project.yaml
+ $ vi project.yaml
+ $ # either via stdin
+ $ cat project.yaml | metalctl project delete <id> -f -
+ $ # or via file
+ $ metalctl project delete <id> -f project.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the project
metalctl project describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the project through an editor and update
metalctl project edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all projects
metalctl project list [flags]
-h, --help help for list
+ --id string ID of the project.
+ --name string Name of the project.
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name|tenant
+ --tenant string tenant of this project.
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the project
metalctl project update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl project describe project-1 -o yaml > project.yaml
+ $ vi project.yaml
+ $ # either via stdin
+ $ cat project.yaml | metalctl project update -f -
+ $ # or via file
+ $ metalctl project update -f project.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage size entities
a size matches a machine in terms of cpu cores, ram and storage.
-h, --help help for size
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more sizes from a given file
metalctl size apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl size describe size-1 -o yaml > size.yaml
+ $ vi size.yaml
+ $ # either via stdin
+ $ cat size.yaml | metalctl size apply -f -
+ $ # or via file
+ $ metalctl size apply -f size.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the size
metalctl size create [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -d, --description string Description of the size. [required]
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl size describe size-1 -o yaml > size.yaml
+ $ vi size.yaml
+ $ # either via stdin
+ $ cat size.yaml | metalctl size create -f -
+ $ # or via file
+ $ metalctl size create -f size.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --id string ID of the size. [required]
+ --max int min value of given size constraint type. [required]
+ --min int min value of given size constraint type. [required]
+ -n, --name string Name of the size. [optional]
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
+ --type string type of constraints. [required]
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the size
metalctl size delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl size describe size-1 -o yaml > size.yaml
+ $ vi size.yaml
+ $ # either via stdin
+ $ cat size.yaml | metalctl size delete <id> -f -
+ $ # or via file
+ $ metalctl size delete <id> -f size.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the size
metalctl size describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the size through an editor and update
metalctl size edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage imageconstraint entities
if a size has specific requirements regarding the images which must fulfill certain constraints, this can be configured here.
-h, --help help for imageconstraint
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more imageconstraints from a given file
metalctl size imageconstraint apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl imageconstraint describe imageconstraint-1 -o yaml > imageconstraint.yaml
+ $ vi imageconstraint.yaml
+ $ # either via stdin
+ $ cat imageconstraint.yaml | metalctl imageconstraint apply -f -
+ $ # or via file
+ $ metalctl imageconstraint apply -f imageconstraint.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the imageconstraint
metalctl size imageconstraint create [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl imageconstraint describe imageconstraint-1 -o yaml > imageconstraint.yaml
+ $ vi imageconstraint.yaml
+ $ # either via stdin
+ $ cat imageconstraint.yaml | metalctl imageconstraint create -f -
+ $ # or via file
+ $ metalctl imageconstraint create -f imageconstraint.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the imageconstraint
metalctl size imageconstraint delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl imageconstraint describe imageconstraint-1 -o yaml > imageconstraint.yaml
+ $ vi imageconstraint.yaml
+ $ # either via stdin
+ $ cat imageconstraint.yaml | metalctl imageconstraint delete <id> -f -
+ $ # or via file
+ $ metalctl imageconstraint delete <id> -f imageconstraint.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the imageconstraint
metalctl size imageconstraint describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the imageconstraint through an editor and update
metalctl size imageconstraint edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all imageconstraints
metalctl size imageconstraint list [flags]
-h, --help help for list
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
try if size and image can be allocated
metalctl size imageconstraint try [flags]
-h, --help help for try
+ --image string image to check if allocaltion is possible
+ --size string size to check if allocaltion is possible
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the imageconstraint
metalctl size imageconstraint update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl imageconstraint describe imageconstraint-1 -o yaml > imageconstraint.yaml
+ $ vi imageconstraint.yaml
+ $ # either via stdin
+ $ cat imageconstraint.yaml | metalctl imageconstraint update -f -
+ $ # or via file
+ $ metalctl imageconstraint update -f imageconstraint.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all sizes
metalctl size list [flags]
-h, --help help for list
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
try a specific hardware spec and give the chosen size back
metalctl size try [flags]
-C, --cores int32 Cores of the hardware to try
+ -h, --help help for try
+ -M, --memory string Memory of the hardware to try, can be given in bytes or any human readable size spec
+ -S, --storagesize string Total storagesize of the hardware to try, can be given in bytes or any human readable size spec
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the size
metalctl size update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl size describe size-1 -o yaml > size.yaml
+ $ vi size.yaml
+ $ # either via stdin
+ $ cat size.yaml | metalctl size update -f -
+ $ # or via file
+ $ metalctl size update -f size.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage switch entities
switch are the leaf switches in the data center that are controlled by metal-stack.
-h, --help help for switch
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
shows switches with their connected machines
metalctl switch connected-machines [flags]
The command will show the machines connected to the switch ports.
+
+Can also be used with -o template in order to generate CSV-style output:
+
+$ metalctl switch connected-machines -o template --template '{{ $machines := .machines }}{{ range .switches }}{{ $switch := . }}{{ range .connections }}{{ $switch.id }},{{ $switch.rack_id }},{{ .nic.name }},{{ .machine_id }},{{ (index $machines .machine_id).ipmi.fru.product_serial }}{{ printf "\n" }}{{ end }}{{ end }}'
+r01leaf01,swp1,f78cc340-e5e8-48ed-8fe7-2336c1e2ded2,<a-serial>
+r01leaf01,swp2,44e3a522-5f48-4f3c-9188-41025f9e401e,<b-serial>
+...
+
-h, --help help for connected-machines
+ --id string ID of the switch.
+ --machine-id string The id of the connected machine, ignores size flag if set.
+ --name string Name of the switch.
+ --os-vendor string OS vendor of this switch.
+ --os-version string OS version of this switch.
+ --partition string Partition of this switch.
+ --rack string Rack of this switch.
+ --size string Size of the connected machines.
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
connect to the switch console
this requires a network connectivity to the ip address of the console server this switch is connected to.
metalctl switch console <switchID> [flags]
-h, --help help for console
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the switch
metalctl switch delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl switch describe switch-1 -o yaml > switch.yaml
+ $ vi switch.yaml
+ $ # either via stdin
+ $ cat switch.yaml | metalctl switch delete <id> -f -
+ $ # or via file
+ $ metalctl switch delete <id> -f switch.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the switch
metalctl switch describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
switch details
metalctl switch detail [flags]
-h, --help help for detail
+ --id string ID of the switch.
+ --name string Name of the switch.
+ --os-vendor string OS vendor of this switch.
+ --os-version string OS version of this switch.
+ --partition string Partition of this switch.
+ --rack string Rack of this switch.
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the switch through an editor and update
metalctl switch edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all switches
metalctl switch list [flags]
-h, --help help for list
+ --id string ID of the switch.
+ --name string Name of the switch.
+ --os-vendor string OS vendor of this switch.
+ --os-version string OS version of this switch.
+ --partition string Partition of this switch.
+ --rack string Rack of this switch.
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
put a leaf switch into replace mode in preparation for physical replacement. For a description of the steps involved see the long help.
Put a leaf switch into replace mode in preparation for physical replacement
Operational steps to replace a switch:
metalctl switch replace <switchID> [flags]
-h, --help help for replace
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
connect to the switch via ssh
this requires a network connectivity to the management ip address of the switch.
metalctl switch ssh <switchID> [flags]
-h, --help help for ssh
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the switch
metalctl switch update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl switch describe switch-1 -o yaml > switch.yaml
+ $ vi switch.yaml
+ $ # either via stdin
+ $ cat switch.yaml | metalctl switch update -f -
+ $ # or via file
+ $ metalctl switch update -f switch.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
manage tenant entities
a tenant belongs to a tenant and groups together entities in metal-stack.
-h, --help help for tenant
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
applies one or more tenants from a given file
metalctl tenant apply [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl tenant describe tenant-1 -o yaml > tenant.yaml
+ $ vi tenant.yaml
+ $ # either via stdin
+ $ cat tenant.yaml | metalctl tenant apply -f -
+ $ # or via file
+ $ metalctl tenant apply -f tenant.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for apply
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
creates the tenant
metalctl tenant create [flags]
--annotations strings add initial annotations, must be in the form of key=value, can be given multiple times to add multiple annotations, e.g. --annotation key=value --annotation foo=bar
+ --bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ --cluster-quota int32 cluster quota
+ --description string description of the tenant.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl tenant describe tenant-1 -o yaml > tenant.yaml
+ $ vi tenant.yaml
+ $ # either via stdin
+ $ cat tenant.yaml | metalctl tenant create -f -
+ $ # or via file
+ $ metalctl tenant create -f tenant.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for create
+ --id string id of the tenant, max 10 characters.
+ --ip-quota int32 ip quota
+ --labels strings add initial label, can be given multiple times to add multiple labels, e.g. --label=foo --label=bar
+ --machine-quota int32 machine quota
+ --name string name of the tenant, max 10 characters.
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
deletes the tenant
metalctl tenant delete <id> [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl tenant describe tenant-1 -o yaml > tenant.yaml
+ $ vi tenant.yaml
+ $ # either via stdin
+ $ cat tenant.yaml | metalctl tenant delete <id> -f -
+ $ # or via file
+ $ metalctl tenant delete <id> -f tenant.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for delete
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
describes the tenant
metalctl tenant describe <id> [flags]
-h, --help help for describe
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
edit the tenant through an editor and update
metalctl tenant edit <id> [flags]
-h, --help help for edit
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
list all tenants
metalctl tenant list [flags]
--annotations strings annotations
+ -h, --help help for list
+ --id string ID of the tenant.
+ --name string Name of the tenant.
+ --sort-by strings sort by (comma separated) column(s), sort direction can be changed by appending :asc or :desc behind the column identifier. possible values: description|id|name
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
updates the tenant
metalctl tenant update [flags]
--bulk-output when used with --file (bulk operation): prints results at the end as a list. default is printing results intermediately during the operation, which causes single entities to be printed in a row.
+ -f, --file string filename of the create or update request in yaml format, or - for stdin.
+
+ Example:
+ $ metalctl tenant describe tenant-1 -o yaml > tenant.yaml
+ $ vi tenant.yaml
+ $ # either via stdin
+ $ cat tenant.yaml | metalctl tenant update -f -
+ $ # or via file
+ $ metalctl tenant update -f tenant.yaml
+
+ the file can also contain multiple documents and perform a bulk operation.
+
+ -h, --help help for update
+ --skip-security-prompts skips security prompt for bulk operations
+ --timestamps when used with --file (bulk operation): prints timestamps in-between the operations
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
update the program
-h, --help help for update
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
check for update of the program
metalctl update check [flags]
-h, --help help for check
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
do the update of the program
metalctl update do [flags]
-h, --help help for do
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
print the client and server version information
metalctl version [flags]
-h, --help help for version
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
access VPN
access VPN
-h, --help help for vpn
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
create an auth key
create an auth key to connect to VPN
metalctl vpn key [flags]
auth key for tailscale can be created by this command:
+metalctl vpn key \
+ -- project cluster01
+
--ephemeral create an ephemeral key (default true)
+ -h, --help help for key
+ --project string project ID for which auth key should be created
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
shows current user
shows the current user, that will be used to authenticate commands.
metalctl whoami [flags]
-h, --help help for whoami
--api-token string api token to authenticate. Can be specified with METALCTL_API_TOKEN environment variable.
+ --api-url string api server address. Can be specified with METALCTL_API_URL environment variable.
+ -c, --config string alternative config file path, (default is ~/.metalctl/config.yaml).
+ Example config.yaml:
+
+ ---
+ apitoken: "alongtoken"
+ ...
+
+
+ --debug debug output
+ --force-color force colored output even without tty
+ --kubeconfig string Path to the kube-config to use for authentication and authorization. Is updated by login. Uses default path if not specified.
+ --no-headers do not print headers of table output format (default print headers)
+ -o, --output-format string output format (table|wide|markdown|json|yaml|template), wide is a table with more columns. (default "table")
+ --template string output template for template output-format, go template format.
+ For property names inspect the output of -o json or -o yaml for reference.
+ Example for machines:
+
+ metalctl machine list -o template --template "{{ .id }}:{{ .size.id }}"
+
+
+ --yes-i-really-mean-it skips security prompts (which can be dangerous to set blindly because actions can lead to data loss or additional costs)
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Please check out the contributing section in our docs.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
The mini-lab is a small, virtual setup to locally run the metal-stack. It deploys the metal control plane and a metal-stack partition with two simulated leaf switches. The lab can be used for trying out metal-stack, demonstration purposes or development.
ℹ This project can also be used as a template for writing your own metal-stack deployments.
<!– TOC depthfrom:2 depthto:6 withlinks:true updateonsave:false orderedlist:false –>
<!– /TOC –>
kvm-ok
command)172.17.0.1
), this hopefully does not overlap with other networks you haveHere is some code that should help you to set up most of the requirements:
# If UFW enabled.
+# Disable the firewall or allow traffic through Docker network IP range.
+sudo ufw status
+sudo ufw allow from 172.17.0.0/16
+
+# Install kvm
+sudo apt install -y git curl qemu qemu-kvm haveged
+
+# Install Docker
+curl -fsSL https://get.docker.com | sh
+# if you want to be on the safe side, follow the original installation
+# instructions at https://docs.docker.com/engine/install/ubuntu/
+
+# Ensure that your user is member of the group "docker"
+# you need to login again in order to make this change take effect
+sudo usermod -G docker -a ${USER}
+
+# Install containerlab
+bash -c "$(curl -sL https://get.containerlab.dev)" -- -v 0.25.1
+
+# Install kind (kubernetes in docker), for more details see https://kind.sigs.k8s.io/docs/user/quick-start/#installation
+sudo curl -Lo /usr/local/bin/kind "https://kind.sigs.k8s.io/dl/latest/kind-linux-amd64"
+sudo chmod +x /usr/local/bin/kind
+
+# Install docker-compose, for more details see https://docs.docker.com/compose/install/
+sudo curl -Lo /usr/local/bin/docker-compose "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)"
+sudo chmod +x /usr/local/bin/docker-compose
The following ports are used statically on your host machine:
Port | Bind Address | Description |
---|---|---|
6443 | 0.0.0.0 | kube-apiserver of the kind cluster |
4443 | 0.0.0.0 | HTTPS ingress |
4150 | 0.0.0.0 | nsqd |
8080 | 0.0.0.0 | HTTP ingress |
git clone https://github.com/metal-stack/mini-lab.git
+cd mini-lab
Start the mini-lab with a kind cluster, a metal-api instance as well as two containers wrapping leaf switches and another container that hosts two user-allocatable machines:
make
+# containerlab will ask you for root permissions (https://github.com/srl-labs/containerlab/issues/669)
After the deployment and waiting for a short amount of time, two machines in status PXE booting
become visible through metalctl machine ls
:
docker-compose run --rm metalctl machine ls
+
+ID LAST EVENT WHEN AGE HOSTNAME PROJECT SIZE IMAGE PARTITION
+e0ab02d2-27cd-5a5e-8efc-080ba80cf258 PXE Booting 3s
+2294c949-88f6-5390-8154-fa53d93a3313 PXE Booting 5s
Wait until the machines reach the waiting state:
docker-compose run --rm metalctl machine ls
+
+ID LAST EVENT WHEN AGE HOSTNAME PROJECT SIZE IMAGE PARTITION
+e0ab02d2-27cd-5a5e-8efc-080ba80cf258 Waiting 8s v1-small-x86 mini-lab
+2294c949-88f6-5390-8154-fa53d93a3313 Waiting 8s v1-small-x86 mini-lab
Create a firewall and a machine with:
make firewall
+make machine
Alternatively, you may want to issue the metalctl
commands on your own:
docker-compose run --rm metalctl network allocate \
+ --partition mini-lab \
+ --project 00000000-0000-0000-0000-000000000000 \
+ --name user-private-network
+
+# lookup the network ID and create a machine
+docker-compose run --rm metalctl machine create \
+ --description test \
+ --name machine \
+ --hostname machine \
+ --project 00000000-0000-0000-0000-000000000000 \
+ --partition mini-lab \
+ --image ubuntu-20.04 \
+ --size v1-small-x86 \
+ --networks <network-ID>
+
+# create a firewall that is also connected to the virtual internet-mini-lab network
+docker-compose run --rm metalctl machine create \
+ --description fw \
+ --name fw \
+ --hostname fw \
+ --project 00000000-0000-0000-0000-000000000000 \
+ --partition mini-lab \
+ --image firewall-ubuntu-2.0 \
+ --size v1-small-x86 \
+ --networks internet-mini-lab,$(privatenet)
See the installation process in action
make console-machine01/02
+...
+Ubuntu 20.04 machine ttyS0
+
+machine login:
Two machines are now installed and have status "Phoned Home"
docker-compose run --rm metalctl machine ls
+ID LAST EVENT WHEN AGE HOSTNAME PROJECT SIZE IMAGE PARTITION
+e0ab02d2-27cd-5a5e-8efc-080ba80cf258 Phoned Home 2s 21s machine 00000000-0000-0000-0000-000000000000 v1-small-x86 Ubuntu 20.04 20200331 mini-lab
+2294c949-88f6-5390-8154-fa53d93a3313 Phoned Home 8s 18s fw 00000000-0000-0000-0000-000000000000 v1-small-x86 Firewall 2 Ubuntu 20200730 mini-lab
Login with user name metal and the console password from
docker-compose run --rm metalctl machine consolepassword e0ab02d2-27cd-5a5e-8efc-080ba80cf258
If you want to access the firewall with SSH or have internet connectivity from the firewall and machine, you'll need to have a static route configured that points to the leaf switches:
# Add the route to the network internet-mini-lab 100.255.254.0/24 via leaf01 and leaf02, whose IPs are dynamically allocated. Make sure there's no old route before execution.
+make route
+
+# Connect to the firewall
+ssh metal@100.255.254.1
To remove the kind cluster, the switches and machines, run:
make cleanup
Reinstall a machine with
docker-compose run --rm metalctl machine reinstall \
+ --image ubuntu-20.04 \
+ e0ab02d2-27cd-5a5e-8efc-080ba80cf258
Free a machine with make free-machine01
or
docker-compose run --rm metalctl machine rm e0ab02d2-27cd-5a5e-8efc-080ba80cf258
There's few versions of mini-lab environment that you can run. We call them flavors. There's 2 flavors at the moment:
default
– runs 2 machines.cluster-api
– runs 3 machines. Useful for testing Control plane and worker node deployment with Cluster API provider.sonic
– use SONiC as network operating system for the leavesIn order to start specific flavor, you can define the flavor as follows:
export MINI_LAB_FLAVOR=cluster-api
+make
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
metal-stack is an open source software that provides an API for provisioning and managing physical servers in the data center. To categorize this product, we use the terms Metal-as-a-Service (MaaS) or bare metal cloud.
From the perspective of a user, the metal-stack does not feel any different from working with a conventional cloud provider. Users manage their resources (machines, networks and ip addresses, etc.) by themselves, which effectively turns your data center into an elastic cloud infrastructure.
The major difference to other cloud providers is that compute power and data reside in your own data center.
Your are currently reading the documentation for the metal-stack master
release.
Releases and integration tests are published through our release repository. You can also find the release notes for this metal-stack version in there. The release notes contain information about new features, upgrade paths and bug fixes.
If you want, you can sign up at our Slack channel where we are announcing every new release. Often, we provide additional information for metal-stack administrators and adopters at this place, too.
Before we started with our mission to implement the metal-stack, we decided on a couple of key characteristics and constraints that we think are unique in the domain (otherwise we would definitely have chosen an existing solution).
We hope that the following properties appeal to you as well.
Running on-premise gives you data sovereignty and usually a better price / performance ratio than with hyperscalers — especially the larger you grow your environment. Another benefit of running on-premise is an easier connectivity to existing company networks.
Provisioning bare metal machines should not feel much different from virtual machines. metal-stack is capable of provisioning servers in less than a minute. The underlying network topology is based on BGP and allows announcing new routes to your host machines in a matter of seconds.
Part of the metal-stack runs on dedicated switches in your data center. This way, it is possible to automate server inventorization, permanently reconcile network configuration and automatically manage machine lifecycles. Manual configuration is neither required nor wanted.
Our networking approach was designed for highest standards on security. Also, we enforce firewalling on dedicated tenant firewalls before users can establish connections to other networks than their private tenant network. API authentication and authorization is done with the help of OIDC.
The development of metal-stack is strictly API driven and offers self-service to end-users. This approach delivers the highest possible degree of automation, maintainability and performance.
Not only does the metal-stack run smoothly on Kubernetes (K8s). The major intent of metal-stack has always been to build a scalable machine infrastructure for Kubernetes as a Service (KaaS). In partnership with the open-source project Gardener, we can provision Kubernetes clusters on metal-stack at scale.
From the perspective of the Gardener, the metal-stack is just another cloud provider. The time savings compared to providing machines and Kubernetes by hand are significant. We actually want to be able to compete with offers of public cloud providers, especially regarding speed and usability.
Of course, you can use metal-stack only for machine provisioning as well and just put something else on top of your metal infrastructure.
The metal-stack is open source and free of constraints regarding vendors and third-party products. The stack is completely built on open source products. We have a community actively working on the metal-stack, which can assist you delivering all reasonable features you are gonna need.
Bare metal has several advantages over virtual environments and overcomes several drawbacks of virtual machines. We also listed drawbacks of the bare metal approach. Bare in mind though that it is still possible to virtualize on bare metal environments when you have your stack up and running.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
We are bootstrapping the metal control plane as well as our partitions with Ansible through CI.
In order to build up your deployment, we recommend to make use of the same Ansible roles that we are using by ourselves in order to deploy the metal-stack. You can find them in the repository called metal-roles.
In order to wrap up deployment dependencies there is a special deployment base image hosted on Docker Hub that you can use for running the deployment. Using this Docker image eliminates a lot of moving parts in the deployment and should keep the footprints on your system fairly small and maintainable.
This document will from now on assume that you want to use our Ansible deployment roles for setting up metal-stack. We will also use the deployment base image, so you should also have Docker installed. It is in the nature of software deployments to differ from site to site, company to company, user to user. Therefore, we can only describe you the way of how the deployment works for us. It is up to you to tweak the deployment described in this document to your requirements.
Probably you need to learn writing Ansible playbooks if you want to be able to deploy the metal-stack as presented in this documentation. However, even when starting without any knowledge about Ansible it should be possible to follow these docs. In case you need further explanations regarding Ansible please refer to docs.ansible.com.
If you do not want to use Ansible for deployment, you need to come up with a deployment mechanism by yourself. However, you will probably be able to re-use some of our contents from our metal-roles repository, e.g. the Helm chart for deploying the metal control plane.
You can use the mini-lab as a template project for your own deployment. It uses the same approach as described in this document.
The metal control plane is typically deployed in a Kubernetes cluster. Therefore, this document will assume that you have a Kubernetes cluster ready for getting deployed. Even though it is theoretically possible to deploy metal-stack without Kubernetes, we strongly advise you to use the described method because we believe that Kubernetes gives you a lot of benefits regarding the stability and maintainability of the application deployment.
For metal-stack it does not matter where your control plane Kubernetes cluster is located. You can of course use a cluster managed by a hyperscaler. This has the advantage of not having to setup Kubernetes by yourself and could even become beneficial in terms of fail-safe operation. The only requirement from metal-stack is that your partitions can establish network connections to the metal control plane. If you are interested, you can find a reasoning behind this deployment decision here.
Let's start off with a fresh folder for your deployment:
mkdir -p metal-stack-deployment
+cd metal-stack-deployment
At the end of this section we are gonna end up with the following files and folder structures:
.
+├── ansible.cfg
+├── deploy_metal_control_plane.yaml
+├── files
+│ └── certs
+│ ├── ca-config.json
+│ ├── ca-csr.json
+│ ├── metal-api-grpc
+│ │ ├── client.json
+│ │ ├── server.json
+│ ├── masterdata-api
+│ │ ├── client.json
+│ │ ├── server.json
+│ └── roll_certs.sh
+├── inventories
+│ ├── control-plane.yaml
+│ └── group_vars
+│ ├── all
+│ │ └── images.yaml
+│ └── control-plane
+│ ├── common.yaml
+│ └── metal.yml
+├── generate_role_requirements.yaml
+└── roles
+ └── ingress-controller
+ └── tasks
+ └── main.yaml
You can already define the inventories/group_vars/all/images.yaml
file. It contains the metal-stack version you are gonna deploy:
---
+metal_stack_release_version: master
As metal-stack consists of many microservices all having individual versions, we have come up with a releases repository. It contains a YAML file (we often call it release vector) describing the fitting versions of all components for every release of metal-stack.
Ansible role dependencies are also part of a metal-stack release. Therefore, we will now write up a playbook, which dynamically renders a requirements.yaml
file from the ansible-roles defined in the release repository. The requirements.yaml
can then be used to resolve the actual role dependencies through Ansible Galaxy. Define the following playbook in generate_role_requirements.yaml
:
---
+- name: generate requirements.yaml
+ hosts: control-plane
+ connection: local
+ gather_facts: false
+ vars:
+ release_vector_url: "https://raw.githubusercontent.com/metal-stack/releases/{{ metal_stack_release_version }}/release.yaml"
+ tasks:
+ - name: download release vector
+ uri:
+ url: "{{ release_vector_url }}"
+ return_content: yes
+ register: release_vector
+
+ - name: write requirements.yaml from release vector
+ copy:
+ dest: "{{ playbook_dir }}/requirements.yaml"
+ content: |
+ {% for role_name, role_params in (release_vector.content | from_yaml).get('ansible-roles').items() %}
+ - src: {{ role_params.get('repository') }}
+ name: {{ role_name }}
+ version: {{ hostvars[inventory_hostname][role_name | lower | replace('-', '_') + '_version'] | default(role_params.get('version'), true) }}
+ {% endfor %}
This playbook will always be run before the actual metal-stack deployment and provide you with the proper versions of the Ansible role dependencies.
Then, there will be an inventory for the control plane deployment in inventories/control-plane.yaml
that adds the localhost to the control-plane
host group:
---
+control-plane:
+ hosts:
+ localhost:
+ ansible_python_interpreter: "{{ ansible_playbook_python }}"
We do this since we are deploying to Kubernetes and do not need to SSH-connect to any hosts for the deployment (which is what Ansible typically does). This inventory is also necessary to pick up the variables inside inventories/group_vars/control-plane
during the deployment.
We recommend using the following ansible.cfg
:
[defaults]
+retry_files_enabled = false
+force_color = true
+host_key_checking = false
+stdout_callback = yaml
+jinja2_native = true
+transport = ssh
+timeout = 30
+force_valid_group_names = ignore
+
+[ssh_connection]
+retries=3
+ssh_executable = /usr/bin/ssh
Most of the properties in there are up to taste, but make sure you enable the Jinja2 native environment as this is needed for some of our roles in certain cases.
Next, we will define the actual deployment playbook in a file called deploy_metal_control_plane.yaml
. You can start with the following lines:
---
+- name: Deploy Control Plane
+ hosts: control-plane
+ connection: local
+ gather_facts: no
+ vars:
+ setup_yaml:
+ - url: https://raw.githubusercontent.com/metal-stack/releases/{{ metal_stack_release_version }}/release.yaml
+ meta_var: metal_stack_release
+ roles:
+ - name: ansible-common
+ tags: always
+ - name: ingress-controller
+ tags: ingress-controller
+ - name: metal-roles/control-plane/roles/prepare
+ tags: prepare
+ - name: metal-roles/control-plane/roles/nsq
+ tags: nsq
+ - name: metal-roles/control-plane/roles/metal-db
+ tags: metal-db
+ - name: metal-roles/control-plane/roles/ipam-db
+ tags: ipam-db
+ - name: metal-roles/control-plane/roles/masterdata-db
+ tags: masterdata-db
+ - name: metal-roles/control-plane/roles/metal
+ tags: metal
Basically, this playbook does the following:
As a next step you have to add a task for deploying an ingress-controller into your cluster. nginx-ingress is what we use. If you want to use another ingress-controller, you need to parametrize the metal roles carefully. When you just use ingress-nginx, make sure to also deploy it to the default namespace ingress-nginx.
This is how your roles/ingress-controller/tasks/main.yaml
could look like:
- name: Deploy ingress-controller
+ include_role:
+ name: ansible-common/roles/helm-chart
+ vars:
+ helm_repo: "https://helm.nginx.com/stable"
+ helm_chart: nginx-ingress
+ helm_release_name: nginx-ingress
+ helm_target_namespace: ingress-nginx
The ansible-common repository contains very general roles and modules that you can also use when extending your deployment further.
Now you can parametrize the referenced roles to fit your environment. The role parametrization can be looked up in the role documentation on metal-roles/control-plane. You should not need to define a lot of variables for the beginning as most values are reasonably defaulted. You can start with the following content for group_vars/control-plane/common.yaml
:
---
+metal_control_plane_ingress_dns: <your-dns-domain> # if you do not have a DNS entry, you could also start with <ingress-ip>.nip.io
We have several components in our stack that communicate over encrypted gRPC just like Kubernetes components do.
For the very basic setup you will need to create self-signed certificates for the communication between the following components (see architecture document):
Here is a snippet for files/roll_certs.sh
that you can use for generating your certificates (requires cfssl):
#!/usr/bin/env bash
+set -eo pipefail
+
+for i in "$@"
+do
+case $i in
+ -t=*|--target=*)
+ TARGET="${i#*=}"
+ shift
+ ;;
+ *)
+ echo "unknown parameter passed: $1"
+ exit 1
+ ;;
+esac
+done
+
+if [ -z "$TARGET" ]; then
+ echo "generating ca cert"
+ cfssl genkey -initca ca-csr.json | cfssljson -bare ca
+ rm *.csr
+fi
+
+if [ -z "$TARGET" ] || [ $TARGET == "grpc" ]; then
+ pushd metal-api-grpc
+ echo "generating grpc certs"
+ cfssl gencert -ca=../ca.pem -ca-key=../ca-key.pem -config=../ca-config.json -profile=server server.json | cfssljson -bare server
+ cfssl gencert -ca=../ca.pem -ca-key=../ca-key.pem -config=../ca-config.json -profile=client client.json | cfssljson -bare client
+ rm *.csr
+ popd
+fi
+
+if [ -z "$TARGET" ] || [ $TARGET == "masterdata-api" ]; then
+ pushd masterdata-api
+ echo "generating masterdata-api certs"
+ rm -f *.pem
+ cfssl gencert -ca=../ca.pem -ca-key=../ca-key.pem -config=../ca-config.json -profile=client-server server.json | cfssljson -bare server
+ cfssl gencert -ca=../ca.pem -ca-key=../ca-key.pem -config=../ca-config.json -profile=client client.json | cfssljson -bare client
+ rm *.csr
+ popd
+fi
Also define the following configurations for cfssl
:
files/certs/ca-config.json
{
+ "signing": {
+ "default": {
+ "expiry": "43800h"
+ },
+ "profiles": {
+ "server": {
+ "expiry": "43800h",
+ "usages": [
+ "signing",
+ "key encipherment",
+ "server auth"
+ ]
+ },
+ "client": {
+ "expiry": "43800h",
+ "usages": [
+ "signing",
+ "key encipherment",
+ "client auth"
+ ]
+ },
+ "client-server": {
+ "expiry": "43800h",
+ "usages": [
+ "signing",
+ "key encipherment",
+ "client auth",
+ "server auth"
+ ]
+ }
+ }
+ }
+}
files/certs/ca-csr.json
{
+ "CN": "metal-control-plane",
+ "hosts": [],
+ "key": {
+ "algo": "rsa",
+ "size": 4096
+ },
+ "names": [
+ {
+ "C": "DE",
+ "L": "Munich",
+ "O": "Metal-Stack",
+ "OU": "DevOps",
+ "ST": "Bavaria"
+ }
+ ]
+}
files/certs/masterdata-api/client.json
{
+ "CN": "masterdata-client",
+ "hosts": [""],
+ "key": {
+ "algo": "ecdsa",
+ "size": 256
+ },
+ "names": [
+ {
+ "C": "DE",
+ "L": "Munich",
+ "O": "Metal-Stack",
+ "OU": "DevOps",
+ "ST": "Bavaria"
+ }
+ ]
+}
files/certs/masterdata-api/server.json
{
+ "CN": "masterdata-api",
+ "hosts": [
+ "localhost",
+ "masterdata-api",
+ "masterdata-api.metal-control-plane.svc",
+ "masterdata-api.metal-control-plane.svc.cluster.local"
+ ],
+ "key": {
+ "algo": "ecdsa",
+ "size": 256
+ },
+ "names": [
+ {
+ "C": "DE",
+ "L": "Munich",
+ "O": "Metal-Stack",
+ "OU": "DevOps",
+ "ST": "Bavaria"
+ }
+ ]
+}
files/certs/metal-api-grpc/client.json
{
+ "CN": "grpc-client",
+ "hosts": [""],
+ "key": {
+ "algo": "rsa",
+ "size": 4096
+ },
+ "names": [
+ {
+ "C": "DE",
+ "L": "Munich",
+ "O": "Metal-Stack",
+ "OU": "DevOps",
+ "ST": "Bavaria"
+ }
+ ]
+}
files/certs/metal-api-grpc/server.json
(Fill in your control plane ingress DNS here){
+ "CN": "metal-api",
+ "hosts": [
+ "<your-metal-api-dns-ingress-domain>"
+ ],
+ "key": {
+ "algo": "rsa",
+ "size": 4096
+ },
+ "names": [
+ {
+ "C": "DE",
+ "L": "Munich",
+ "O": "Metal-Stack",
+ "OU": "DevOps",
+ "ST": "Bavaria"
+ }
+ ]
+}
Running the roll_certs.sh
bash script without any arguments should generate you the required certificates.
Now Provide the paths to these certificates in group_vars/control-plane/metal.yaml
:
---
+metal_masterdata_api_tls_ca: "{{ lookup('file', 'certs/ca.pem') }}"
+metal_masterdata_api_tls_cert: "{{ lookup('file', 'certs/masterdata-api/server.pem') }}"
+metal_masterdata_api_tls_cert_key: "{{ lookup('file', 'certs/masterdata-api/server-key.pem') }}"
+metal_masterdata_api_tls_client_cert: "{{ lookup('file', 'certs/masterdata-api/client.pem') }}"
+metal_masterdata_api_tls_client_key: "{{ lookup('file', 'certs/masterdata-api/client-key.pem') }}"
+
+metal_api_grpc_certs_server_key: "{{ lookup('file', 'certs/metal-api-grpc/server-key.pem') }}"
+metal_api_grpc_certs_server_cert: "{{ lookup('file', 'certs/metal-api-grpc/server.pem') }}"
+metal_api_grpc_certs_client_key: "{{ lookup('file', 'certs/metal-api-grpc/client-key.pem') }}"
+metal_api_grpc_certs_client_cert: "{{ lookup('file', 'certs/metal-api-grpc/client.pem') }}"
+metal_api_grpc_certs_ca_cert: "{{ lookup('file', 'certs/ca.pem') }}"
For the actual communication between the metal-api and the user clients (REST API, runs over the ingress-controller you deployed before), you can simply deploy a tool like cert-manager into your Kubernetes cluster, which will automatically provide your ingress domains with Let's Encrypt certificates.
Finally, it should be possible to run the deployment through a Docker container. Make sure to have the Kubeconfig file of your cluster and set the path in the following command accordingly:
export KUBECONFIG=<path-to-your-cluster-kubeconfig>
+docker run --rm -it \
+ -v $(pwd):/workdir \
+ --workdir /workdir \
+ -e KUBECONFIG="${KUBECONFIG}" \
+ -e K8S_AUTH_KUBECONFIG="${KUBECONFIG}" \
+ -e ANSIBLE_INVENTORY=inventories/control-plane.yaml \
+ metalstack/metal-deployment-base:v0.7.1 \
+ /bin/bash -ce \
+ "ansible-playbook obtain_role_requirements.yaml
+ ansible-galaxy install -r requirements.yaml
+ ansible-playbook deploy_metal_control_plane.yaml"
If you are having issues regarding the deployment take a look at the troubleshoot document. Please give feedback such that we can make the deployment of the metal-stack easier for you and for others!
After the deployment has finished (hopefully without any issues!), you should consider deploying some masterdata entities into your metal-api. For example, you can add your first machine sizes and operating system images. You can do this by further parametrizing the metal role. We will just add an operating system for demonstration purposes. Add the following variable to your inventories/group_vars/control-plane/common.yaml
:
metal_api_images:
+- id: firewall-ubuntu-2.0.20201004
+ name: Firewall 2 Ubuntu 20201004
+ description: Firewall 2 Ubuntu 20201004
+ url: http://images.metal-stack.io/metal-os/master/firewall/2.0-ubuntu/20201004/img.tar.lz4
+ features:
+ - firewall
+- id: ubuntu-20.04.20201004
+ name: Ubuntu 20.04 20201004
+ description: Ubuntu 20.04 20201004
+ url: http://images.metal-stack.io/metal-os/master/ubuntu/20.04/20201004/img.tar.lz4
+ features:
+ - machine
Then, re-run the deployment to apply your changes. Our playbooks are idempotent.
Image versions should be regularly checked for updates.
You can now verify the existence of the operating system images in the metal-api using our CLI client called metalctl. The configuration for metalctl
should look like this:
# ~/.metalctl/config.yaml
+---
+current: test
+contexts:
+ test:
+ # the metal-api endpoint depends on your dns name specified before
+ # you can look up the url to the metal-api via the kubernetes ingress
+ # resource with:
+ # $ kubectl get ingress -n metal-control-plane
+ url: <metal-api-endpoint>
+ # in the future you have to change the HMAC to a strong, random string
+ # in order to protect against unauthorized api access
+ # the default hmac is "change-me"
+ hmac: change-me
Issue the following command:
$ metalctl image ls
+ID NAME DESCRIPTION FEATURES EXPIRATION STATUS
+ubuntu-19.10.20200331 Ubuntu 19.10 20200331 Ubuntu 19.10 20200331 machine 89d 23h preview
The basic principles of how the metal control plane can be deployed should now be clear. It is now up to you to move the deployment execution into your CI and add things like certificates for the ingress-controller and NSQ.
The backup-restore-sidecar can come up very handy when you want to add another layer of security to the metal-stack databases in your Kubernetes cluster. The sidecar takes backups of the metal databases in small time intervals and stores them in a blobstore of a cloud provider. This way your metal-stack setup can even survive the deletion of your Kubernetes control plane cluster (including all volumes getting lost). After re-deploying metal-stack to another Kubernetes clusters, the databases come up with the latest backup data in a matter of seconds.
Checkout the role documentation of the individual databases to find out how to configure the sidecar properly. You can also try out the mechanism from the backup-restore-sidecar repository.
metal-stack currently supports two authentication methods:
In the metal-api, we have three different user roles for authorization:
How the user permissions are used is documented in the technical API docs.
If you decided to set up a dex server, you can parametrize the metal role for using the dex server by defining the variable metal_api_dex_address
.
We also have dedicated controllers for using the dex server for Kubernetes clusters when deploying metal-stack along with the Gardener in your environment. The approach is described in further detail in the section Gardener with metal-stack.
To be able to deploy and maintain a metal-stack partition, you need to bootstrap the Out-Of-Band-Network first. Some considerations must be made to fulfill the requirements of our infrastructure, a partition is designed to be:
In order to accomplish this task remotely and in a nearly automatic manner, you have to bootstrap the components in this order:
This document assumes that all cabling is done. Here is a quick overview of the architecture:
As you can see, the management firewalls are the first bastion hosts in a partition to provide access to our infrastructure. There are two of them in each partition to guarantee high availability and load balancing. The very first configuration of these routers has to be done manually to solve the chicken and egg problem that you need the management firewalls in place to deploy the partition. Manually means that we generate a configuration template with ansible that we deploy with copy/paste, and the load, through the machine console. Once the management server has been deployed, we are able to deploy this configuration via CI runner and ansible. For this you need the user and the ssh-key, which is deployed with the configuration file mentioned above. The Edgerouters has to fulfill some requirements including:
The second bastion hosts are the management servers. They are the main bootstrapping components of the Out-Of-Band-Network. They also act as jump hosts for all components in a partition. Once they are installed and deployed, we are able to bootstrap all the other components. To bootstrap the management servers, we generate an ISO image which will automatically install an OS and an ansible user with ssh keys. It is preconfigured with a preseed file to allow an unattended OS installation for our needs. This is why we need remote access to the IPMI interface of the management servers: The generated ISO is attached via the virtual media function of the BMC. Ater that, all we have to do is boot from that virtual CD-ROM and wait for the installation to finish. Deployment jobs (Gitlab-CI) in a partition are delegated to the appropriate management servers, therefore we need a CI runner active on each management server.
After the CI runner has been installed, you can trigger your Playbooks from the the CI. The Ansible-Playbooks have to make sure that these functionalities are present on the management servers:
If you are using SONiC switches, you should make use of Zero Touch Provisioning and Onie Boot
The purpose of these switches is to connect the management interfaces of all switches to the management servers. The management spine's own management interface is connected to the management firewall for the bootstrapping of the management spine itself. The management firewall will provide a DHCP address and DHCP options to start SONiC's Zero Touch Provisioning; the images for all switches are downloaded from the management server (nginx container). Each management leaf is connected to both management spines to provide redundant connectivity to both management servers. BGP is used as a routing protocol such that, when a link goes down, an alternate path is used. In the picture above you can see that there are also switch management interfaces connected to the management spine. This has to be done so that we can bootstrap these switches; the management spine relays the DHCP requests from these switches to the management servers so that they are able to Onie Boot and get their ZTP scripts.
All workers have to be connected with their IPMI/BMC interface to the management leaves to get DHCP addresses from the management server. The management leaves are relaying those DHCP requests to the management server which will answer the requests and provide IPs from a given range. The management interfaces of the management leaves also have to be reachable from the management server, and need to get their IP address via DHCP for the bootstrapping process.
In the example setup, these interfaces are connected to an end-of-row-switch which aggregates them and connects them to the management spines with a fiber-optics connection. If you can reach the management spines from the management leaves with copper cables, you do not need the end of row switch. After the initial bootstrapping, the management interfaces of the management leaves continue to be used for access to the switches' command line, and for subsequent OS updates. (update=reset+bootrap+deployment)
If you want to deploy metal-stack as a cloud provider for Gardener, you should follow the regular Gardener installation instructions and setup a Gardener cluster first. It's perfectly fine to setup the Gardener cluster in the same cluster that you use for hosting metal-stack.
You can find installation instructions for Gardener on the Gardener website beneath docs. metal-stack is an out-of-tree provider and therefore you will not find example files for metal-stack resources in the Gardener repositories. The following list describes the resources and components that you need to deploy into the Gardener cluster in order to make Gardener work with metal-stack:
The following list assumes you have Gardener installed in a Kubernetes cluster and that you have a basic understanding of how Gardener works. If you need further help with the following steps, you can also come and ask in our Slack channel.
metal
containing all your machine images, machine types and regions (region names can be chosen freely, the zone names need to match your partition names) together with our metal-stack-specific provider config as defined here networking:
+ type: calico
+ # we can peer with the frr within 10.244.0.0/16, which we do with the metallb
+ # the networks for the shoot need to be disjunct with the networks of the seed, otherwise the VPN connection will not work properly
+ # the seeds are typically deployed with podCIDR 10.244.128.0/18 and serviceCIDR 10.244.192.0/18
+ # the shoots are typically deployed with podCIDR 10.244.0.0/18 and serviceCIDR 10.244.64.0/18
+ pods: 10.244.0.0/18
+ services: 10.244.64.0/18
+ providerConfig:
+ apiVersion: calico.networking.extensions.gardener.cloud/v1alpha1
+ kind: NetworkConfig
+ backend: vxlan
+ ipv4:
+ pool: vxlan
+ mode: Always
+ autoDetectionMethod: interface=lo
+ typha:
+ enabled: false
metalAPIHMac
, which is the API HMAC to grant editor access to the metal-apiWe are officially supported by Gardener dashboard. The dashboard can also help you setting up some of the resources mentioned above.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
We are currently working on providing the sources of our monitoring deployment for public usage. Please come back later.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
This document summarizes help when something goes wrong and provides advice on debugging the metal-stack in certain situations.
Of course, it is also advisable to check out the issues on the Github projects for help.
If you still can't find a solution to your problem, please reach out to us and our community. We have a public Slack Channel to discuss problems, but you can also reach us via mail. Check out metal-stack.io for contact information.
There can be many reasons for this. Since you are deploying the metal control plane into a Kubernetes cluster, the first step should be to install kubectl and check the pods in your cluster. Depending on the metal-stack version and Kubernetes cluster, your control-plane should look something like this after the deployment (this is in a Kind cluster):
kubectl get pod -A
+NAMESPACE NAME READY STATUS RESTARTS AGE
+ingress-nginx nginx-ingress-controller-56966f7dc7-khfp9 1/1 Running 0 2m34s
+kube-system coredns-66bff467f8-grn7q 1/1 Running 0 2m34s
+kube-system coredns-66bff467f8-n7n77 1/1 Running 0 2m34s
+kube-system etcd-kind-control-plane 1/1 Running 0 2m42s
+kube-system kindnet-4dv7m 1/1 Running 0 2m34s
+kube-system kube-apiserver-kind-control-plane 1/1 Running 0 2m42s
+kube-system kube-controller-manager-kind-control-plane 1/1 Running 0 2m42s
+kube-system kube-proxy-jz7kp 1/1 Running 0 2m34s
+kube-system kube-scheduler-kind-control-plane 1/1 Running 0 2m42s
+local-path-storage local-path-provisioner-bd4bb6b75-cwfb7 1/1 Running 0 2m34s
+metal-control-plane ipam-db-0 2/2 Running 0 2m31s
+metal-control-plane masterdata-api-6dd4b54db5-rwk45 1/1 Running 0 33s
+metal-control-plane masterdata-db-0 2/2 Running 0 2m29s
+metal-control-plane metal-api-998cb46c4-jj2tt 1/1 Running 0 33s
+metal-control-plane metal-api-initdb-r9sc6 0/1 Completed 0 2m24s
+metal-control-plane metal-api-liveliness-1590479940-brhc7 0/1 Completed 0 6s
+metal-control-plane metal-console-7955cbb7d7-p6hxp 1/1 Running 0 33s
+metal-control-plane metal-db-0 2/2 Running 0 2m34s
+metal-control-plane nsq-lookupd-5b4ccbfb64-n6prg 1/1 Running 0 2m34s
+metal-control-plane nsqd-6cd87f69c4-vtn9k 2/2 Running 0 2m33s
If there are any failing pods, investigate those and look into container logs. This information should point you to the place where the deployment goes wrong.
Sometimes, you see a helm errors like "no deployed releases" or something like this. When a helm chart fails after the first deployment it could be that you have a chart installation still pending. Also, the control plane helm chart uses pre- and post-hooks, which creates jobs that helm expects to be completed before attempting another deployment. Delete the helm chart (use Helm 3) with helm delete -n metal-control-plane metal-control-plane
and delete the jobs in the metal-control-plane
namespace before retrying the deployment.
The control-plane deployment returns an error like this:
deploy-control-plane | fatal: [localhost]: FAILED! => changed=false
+deploy-control-plane | attempts: 60
+deploy-control-plane | content: ''
+deploy-control-plane | elapsed: 0
+deploy-control-plane | msg: 'Status code was -1 and not [200]: Request failed: <urlopen error [Errno -5] No address associated with hostname>'
+deploy-control-plane | redirected: false
+deploy-control-plane | status: -1
+deploy-control-plane | url: http://api.172.17.0.1.nip.io:8080/metal/v1/health
+deploy-control-plane |
+deploy-control-plane | PLAY RECAP *********************************************************************
+deploy-control-plane | localhost : ok=29 changed=4 unreachable=0 failed=1 skipped=7 rescued=0 ignored=0
+deploy-control-plane |
+deploy-control-plane exited with code 2
Some home routers have a security feature that prevents DNS Servers to resolve anything in the router's local IP range (DNS-Rebind-Protection).
You need to add an exception for nip.io
in your router configuration or add 127.0.0.1 api.172.17.0.1.nip.io
to your /etc/hosts
.
Home Network -> Network -> Network Settings -> Additional Settings -> DNS Rebind Protection -> Host name exceptions -> nip.io
The metalctl machine issues
command gives you an overview over machines in your metal-stack environment that are in an unusual state.
Machines that are known not to function properly, should be locked through metalctl machine lock
and annotated with a description of the problem. This way, you can mark machine for replacement without being in danger of having a user allocating the faulty machine.
In the following sections, you can look up the machine issues that are returned by metalctl
and find out how to deal with them properly.
Every machine in the metal-stack database usually has a corresponding event container where provisioning events are stored. This database entity gets created lazily as soon as a machine is registered by the metal-hammer or a provisioning event for the machine arrives at the metal-api.
When there is no event container, this means that the machine has never registered nor received a provisioning event. As an operator you should evaluate why this machine is not booting into the metal-hammer.
This issue is special in a way that it prevents other issues from being evaluated for this machine because the issue calculation usually requires information from the machine event container.
When a machine has no partition, the metal-hammer has not yet registered the machine at the metal-api. Instead, the machine was created through metal-stack's event machinery, which does not have a lot of information about a machine (e.g. a PXE boot event was reported from the pixiecore), or just by the metal-bmc which discovered the machine through DHCP.
This can usually happen on the very first boot of a machine and the machine's hardware is not supported by metal-stack, leading to the metal-bmc being unable to report BMC details to the metal-api (a metal-bmc report sets the partition id of a machine) and the metal-hammer not finishing the machine registration phase.
To resolve this issue, you need to identify the machine in your metal-stack partition that emits PXE boot events and find the reason why it is not properly booting into the metal-hammer. The console logs of this machine should enable you to find out the root cause.
For machines without an allocation, the metal-hammer consistently reports whether a machine is still being responsive or not. When the liveliness is Dead
, there were no events received from this machine for longer than ~5 minutes.
Reasons for this can be:
In order to minimize maintenance overhead, a machine which is dead for longer than an hour will be rebooted through the metal-api.
In case you want to prevent this action from happening for a machine, you can lock the machine through metalctl machine lock
.
If the machine is dead for a long time and you are sure that it will never come back, you can clean up the machine through metalctl machine rm --remove-from-database
.
For machines that are allocated by a user, the ownership has gone over to this user and as an operator you cannot access the machine anymore. This makes it harder to detect whether a machine is in a healthy state or not. Typically, all official metal-stack OS images deploy an LLDP daemon, that consistently emits alive messages. These messages are caught by the metal-core and turned into a Phoned Home
event. Internally, the metal-api uses these events as an indicator to decide whether the machine is still responsive or not.
When the LLDP daemon stopped sending packages, the reasons are identical to those of dead machines. However, it's not possible anymore to decide whether the user is responsible for reaching this state or not.
In most of the cases, there is not much that can be done from the operator's perspective. You will need to wait for the user to report an issue with the machine. When you do support, you can use this issue type to quickly identify this machine.
This is more of a theoretical issue. When the machine liveliness is not available check that the Kubernetes CronJob
in the metal-stack control plane for evaluating the machine liveliness is running regularly and not containing error logs. Make the machine boot into the metal-hammer and this issue should not appear.
If a machine remains in the Phoned Home
state without having an allocation, this indicates that the metal-bmc was not able to put the machine back into PXE boot mode after metalctl machine rm
. The machine is still running the operating system and it does not return back into the allocatable machine pool. Effectively, you lost a machine in your environment and no-one pays for it. Therefore, you should resolve this issue as soon as possible.
In bad scenarios, when the machine was a firewall, the machine can still reach the internet through the PXE boot network and also attract traffic, which it cannot route anymore inside the tenant VRF. This can cause traffic loss inside a tenant network.
In most of the cases, it should be sufficient to run another metalctl machine rm
on this machine in order to retry booting into PXE mode. If this still does not succeed, you can boot the machine into the BIOS and manually and change the boot order to PXE boot. This should force booting the metal-hammer again and add the machine back into your pool of allocatable machines.
For further reference, see metal-api#145.
Under bad circumstances, a machine diverges from its typical machine lifecycle. When this happens, the internal state-machine of the metal-api detects that the machine reboots unexpectedly during the provisioning phase. It is likely that the machine has entered a crash loop where it PXE boots again and again without the machine ever becoming usable.
Reasons for this can be:
metalctl machine rm --remove-from-database
.Please also consider console logs of the machine for investigating the issue.
The incomplete cycle count is reset as soon as the machine reaches Phoned Home
state or there is a Planned Reboot
of the machine (planned reboot is also done by the metal-hammer once a day in order to reboot with the latest version).
The machine had an error during the provisioning lifecycle recently or events are arriving out of order at the metal-api. This can be an interesting hint for the operator that something during machine provisioning went wrong. You can look at the error through metalctl machine describe
or metalctl machine logs
.
This error will disappear after a certain time period from machine issues
. You can still look up the error as described above.
This issue was introduced by a bug in earlier versions of metal-stack and was fixed in PR105
To resolve the issue, you need to recreate the firewalls that use the same ASN.
The metal-bmc is responsible to report connection data for the machine's BMC.
If it's uncapable of discovering this information, your hardware might not be supported. Please investigate the logs of the metal-bmc to find out what's going wrong with this machine.
The metal-bmc is responsible to report connection data for the machine's BMC.
If it's uncapable of discovering this information, your hardware might not be supported. Please investigate the logs of the metal-bmc to find out what's going wrong with this machine.
The metal-bmc is responsible to report connection data for the machine's BMC.
When there is no distinct IP address for the BMC, it can be that an orphaned machine used this IP in the past. In this case, you need to clean up the orphaned machine through metalctl machine rm --remove-from-database
.
The metal-bmc is responsible to report bmc details for the machine's BMC.
When the metal-bmc was not able to fetch the bmc info for longer than 20 minutes, something is wrong with the BMC configuration of the machine. This can be caused by one of the following reasons:
In either case, please check the logs for the given machine UUID on the metal-bmc for further details. Also check that the metal-bmc is configured to only consider BMC IPs in the range they are configured from the DHCP server in the partition. This prevents grabbing unrelated BMCs.
metal-stack heavily relies on steady machine UUIDs as the UUID is the primary key of the machine entity in the metal-api.
For further reference also see metal-stack/metal-hammer#52.
There are some scenarios (can be vendor-specific), which can cause a machine UUID to change over time, e.g.:
metalctl machine ls
metalctl machine rm --remove-from-database --yes-i-really-mean-it <uuid>
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
The metal-stack is a compound of microservices predominantly written in Golang.
This page gives you an overview over which microservices exist, how they communicate with each other and where they are deployed.
For our environments, we chose to deploy the metal-stack into a Kubernetes cluster. This means that also our entire installation was developed for metal-stack being run on Kubernetes. Running applications on Kubernetes gives you a lot of benefits regarding ease-of-deployment, scalability, reliability and so on.
However, very early we decided that we do not want to depend on technical Kubernetes functionality with our software (i.e. we did not implement the stack "kube-native" by using controllers and Kubernetes CRDs and things like that). With the following paragraph we want to point out the reasoning behind this "philosophical" decision that may sound conservative at first glance. But not relying on Kubernetes technology:
One more word towards determining the location for your metal control plane: It is not strictly required to run the control plane inside the same data center as your servers. It even makes sense not to do so because this way you can place your control plane and your servers into a different failure domains, which makes your installation more robust to data center meltdown. Externally hosting the control plane brings you up and running quickly plus having the advantage of higher security through geo-distribution.
The foundation of the metal-stack is what we call the metal control plane.
The control plane contains of a couple of essential microservices for the metal-stack including:
The following figure shows the relationships between these microservices:
Figure 1: The metal control plane deployed in a Kubernetes environment with an ingress-controller exposing additional services via service exposal.
Some notes on this picture:
A partition is our term for describing hardware in the data center controlled by the metal-stack with all the hardware participating in the same network topology. Being in the same network topology causes the hardware inside a partition to build a failure domain. Even though the network topology for running the metal-stack is required to be redundant by design, you should consider setting up multiple partitions. With multiple partitions it is possible for users to maintain availability of their applications by spreading them across the partitions. Installing partitions in multiple data centers would be even better in regards of fail-safe application performance, which would even tolerate the meltdown of a data center.
In our setups, we encode the name of a region and a zone name into our partition names. However, we do not have dedicated entities for regions and zones in our APIs.
A region is a geographic area in which data centers are located.
Zones are geographic locations in a region usually in different fire compartments. Regions can consist of several zones.
A zone can consist of several partitions. Usually, a partition spans a rack or a group of racks.
We strongly advise to group your hardware into racks that are specifically assembled for running metal-stack. When using modular rack design, the amount of compute resources of a partition can easily be extended by adding more racks to your partition.
The hardware that we currently support to be placed inside a partition is described in the hardware document.
How large you can grow your partitions and how the network topology inside a partition looks like is described in the networking document.
The metal-stack has microservices running on the leaf switches in a partition. For this reason, your leaf switches are required to run a Linux distribution that you have full access to. Additionally, there are a servers not added to the pool of user-allocatable machines, which are instead required for running metal-stack and we call them management servers. We also call the entirety of switches inside a partition the switch plane.
The microservices running inside a partition are:
Figure 2: Simplified illustration of services running inside a partition.
Some notes on this picture:
The following figure shows several partitions connected to a single metal control plane. Of course, it is also possible to have multiple metal control planes, which can be useful for staging.
Figure 3: Reduced view on the communication between the metal control plane and multiple partitions.
Some notes on this picture:
The following sequence diagram illustrates some of the main principles of the machine provisioning lifecycle.
Figure 4: Sequence diagram of the machine provisioning sequence.
Here is a video showing a screen capture of a machine's serial console while running the metal-hammer in "wait mode". Then, a user allocates the machine and the metal-hammer installs the target operating system and the machine boots into the new operating system kernel via the kexec system call.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
As metal-stack is the foundation to build Kubernetes clusters on premise on bare metal, there are several commercial solutions available which offer management of Kubernetes. In this document we describe the differences between some of the most popular solutions. It´s is not a complete list.
Comparison between Gardener on Metal Stack and Openshift running on VMWare.
Gardener is a Kubernetes cluster manager to organize a fleet of Kubernetes clusters at scale. It is designed to scale to thousands of clusters at a variety of IaaS Providers regardless where - in the cloud or on premise, virtualized or bare metal. It not only manages the creation and deletion of Kubernetes clusters, it also takes care of updating or upgrading Kubernetes and the operating system of the involved worker nodes in a automatic manner. Gardener is designed cloud-native and as such, it defines clusters, workers and all other components as Kubernetes resources (like pods and deployments) and reconciles these resources to the desired state.
Kubernetes is the de facto open-source standard for container scheduling and orchestration in the data center.
A fork of Kubernetes with proprietary addons, created by RedHat. For all details see: https://en.wikipedia.org/wiki/OpenShift.
Is an IaaS provider for bare metal focused to create Kubernetes cluster on premise. Gardener support is built in.
The most used virtualization technology in the enterprise data centers.
Feature | Gardener on Metal Stack | Openshift on VMWare |
---|---|---|
Container Runtime | docker, containerd, gvisor | cri-o |
Host Operating System | Ubuntu, Debian , also see OS | RHEL, Fedora-Core |
Network Plugins | Calico, Cilium(soon) | Openshift SDN |
Storage | Local NVME, Lightbits NVMEoTCP, all CSI compatible Solutions, also see Storage | CSI compatible |
Loadbalancing | BGP built in | requires extra HW like F5, VMWare NSX |
IO at Native Speed | Pods run on bare metal | all IO must go through the Hypervisor |
Hard Multitenancy | Workers, firewall and load balancers are dedicated for every cluster on bare metal | Shared virtualization hosts, shared load balancers |
UI | Gardener Dashboard | Openshift Console |
Multi-cluster management | Yes (through Gardener) | Requires extra licences SW: Redhat Advanced Cluster Manager |
Automatic Kubernetes Updates | Yes | Yes |
Automatic Worker Nodes Updates | Yes | Yes |
Supported IaaS Providers | GCP, AWS, Azure, Alibaba, Openstack, VMWare, metal-stack and more | GCP, AWS, Azure Openstack, VMWare |
Monitoring / Logging Stack | Grafana/Loki, Kibana/Elastic | Kibana/Elastic |
GitOPS | Tool of choice via Helm Install | Openshift GitOPS |
Container Registry | all public accessible registries, private deployed registry of choice | all public accessible registries, in cluster registry |
CI/CD | Tool of choice via Helm Install | Jenkins |
Security | K8s control plane isolated from tenant, PSP enabled by default | Strong cluster defaults |
CNCF Kubernetes certified | Yes (Gardener) | Yes |
Local development | minikube, kind | minishift |
Proprietary extensions | No | DeploymentConfig and others |
kubectl access | Yes | Yes |
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
In order to keep the automation and maintenance overhead small, we strongly advise against building highly heterogeneous environments with metal-stack. Having a lot of different vendors and server models in your partitions will heavily increase the time and effort for introducing metal-stack in your infrastructure. From experience we can tell that the interfaces for automating hardware provisioning are usually inconsistent between vendors and even between server models of the same vendor. Therefore, we encourage adopters to start off with only a small amount of machine types. If you want to be on the safe side, you should consider buying the hardware that we officially support.
We came up with a repository called go-hal, which includes the interface required for metal-stack to support a machine vendor. If you plan to implement support for new vendors, please check out this repository and contribute back your efforts in order to make the community benefit from extended vendor support as well.
At the moment we support the following server types:
Vendor | Series | Model | Board Type | Status |
---|---|---|---|---|
Supermicro | Big-Twin | SYS-2029BT-HNR | X11DPT-B | stable |
Supermicro | SuperServer | SSG-5019D8-TR12P | X11SDV-8C-TP8F | stable |
Supermicro | SuperServer | 2029UZ-TN20R25M | X11DPU | stable |
Supermicro | Microcloud | 5039MD8-H8TNR | X11SDD-8C-F | stable |
Lenovo | ThinkSystem | SD530 | alpha |
At the moment we support the following switch types:
Vendor | Series | Model | OS | Status |
---|---|---|---|---|
Edge-Core | AS7700 Series | AS7712-32X | Cumulus 3.7.13 | stable |
Edge-Core | AS7700 Series | AS7726-32X | Cumulus 4.1.1 | stable |
Edge-Core | AS7700 Series | AS7712-32X | Edgecore SONiC | stable |
Edge-Core | AS7700 Series | AS7726-32X | Edgecore SONiC | stable |
On our switches we run SONiC. The metal-core writes network configuration specifically implemented for this operating system. Please also consider running SONiC on your switches if you do not want to run into any issues with networking.
Our previous support for Cumulus Linux will come to an end.
Of course, contributions for supporting other switch vendors and operating systems are highly appreciated.
A minimal physical hardware setup may contain at least the following components:
This setup should work as the components are very similar to the currently supported ones but it's currently untested.
# | Vendor | Series | Model | Function |
---|---|---|---|---|
2x | Edge-Core | AS5500 Series | AS5512-54x (10G) | Leaf / Exit switches |
1x | Supermicro | Microcloud | SYS-5039MA16-H12RFT | Usable machines |
1x | Unifi | Edgemax | Edgerouter Pro | Front router for internet and out-of-band access to servers and switches |
Besides that, a 6HE rack with 1000mm depth and a portable LTE modem is needed.
This MVP will yield in 12 usable machines, one of them will be reserved as management server.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
With the help of the Gardener project, metal-stack can be used for spinning up Kubernetes clusters quickly and reliably on bare metal machines.
To make this happen, we implemented a couple of components, which are described here.
CCM stands for cloud-controller-manager and is the bridge between Kubernetes and a cloud-provider.
We implemented the cloud provider interface in the metal-ccm repository. With the help of the cloud-controller-controller we provide metal-stack-specific properties for Kubernetes clusters, e.g. load balancer configuration through MetalLB or node properties.
To make the firewalls created with metal-stack easily configurable through Kubernetes resources, we add our firewall-controller to the firewall image. The controller watches special CRDs, enabling users to manage:
Please check out the guide on how to use it.
There are some Gardener resources that need be reconciled when you act as a cloud provider for the Gardener. This section briefly describes the controllers implemented for deploying Kubernetes clusters through Gardener.
If you want to learn how to deploy metal-stack with Gardener, please check out the installation section.
The gardener-extension-provider-metal contains of a set of webhooks and controllers for reconciling or mutating Gardener-specific resources.
The project also contains a validator for metal-type Gardener resources, which you should also deploy in case you want to use metal-stack in combination with Gardener.
Due to the reason we use ignition in our operating system images for userdata, we had to provide an own extension controller for metal-stack, which you can find at Github in the os-metal-extension repository.
Worker nodes are managed through Gardener's machine-controller-manager (MCM). The MCM allows out-of-tree provider implementation via sidecar, which is what we implemented in the machine-controller-manager-provider-metal repository.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
We spent a lot of time on trying to provide state-of-the-art networking in the data center. This document describes the requirements, ideas and implementation details of the network topology that hosts the metal-stack.
The document is separated into three main sections describing the constraints, theoretical ideas and implementation details.
Finding the requirements for this greenfield project was kicked off with a handful of design parameters that included:
Evaluation of those parameters led to more specific requirements:
Furthermore, requirements such as operational simplicity and network stability that a small group of people can effectively support have been identified being a primary focus for building metal-stack.
The theoretical concept targets the aforementioned requirements. New technologies have been evaluated to apply the best solutions. The process was heavily inspired by the work of Dinesh G. Dutt regarding BGP (bgp-ebook) and EVPN (evpn-ebook).
External BGP together with network overlay concepts as EVPN can address the essential demands. These revolutionary concepts are part of the next evolutionary step in data center design. It overcomes common issues of traditional layer 2 architectures (e.g. VLAN limitations, network visibility for operations, firewall requirements) by introducing a layer 3 based network topology.
A CLOS topology is named after the pioneer Charles Clos (short: CLOS) who first formalized this approach. CLOS defines a multistage network topology that is used today to improve performance and resilience while enabling a cost effective scalability. A CLOS topology comprises network switches aggregated into spine and leaf layers. Each leaf switch (short: leaf) is connected to all spine switches (short: spine) but there is no direct leaf-to-leaf or spine-to-spine connection (See: picture 1).
Picture 1: Fragment of CLOS to show leaf-spine layer.
This data center network architecture, based on a leaf-spine architecture, is also know as "two-tier" CLOS topology.
Picture 2: Fragment to show a 3-stage, 2-layer CLOS topology.
Tenant servers are dual-attached to the leaf layer in order to have redundancy and load balancing capability (Picture 2). The set of leaves, spine switches and tenant servers define stages. From top down each server is reachable with 3 hops (spine -> leaf -> server). This is why that CLOS design is called a 3-stage CLOS. Consistent latency throughout the data center are an outcome of this design.
It is not only important to have a scalable and resilient infrastructure but also to support planning and operation teams. Visibility within the network is of significant meaning for them. Consequently layer-3 routing in favor of layer-2 bridging provides this kind of tooling.
For routing the Border Gateway Protocol (BGP), more specific: External BGP was selected. Extensive testing and operational experiences have shown that External BGP is well suited as a stand-alone routing protocol (see: RFC7938).
Not all tenant servers are connected to the same leaf. Instead they can be distributed among any of the leaves of the data center. To not let this detail restrict the intra-tenant communication it is required to interconnect those layer-2 domains. In the context of BGP there is a concept of overlay networking with VXLAN/ EVPN that was evaluated to satisfy the needs of the metal-stack.
In BGP traditionally each BGP peer-facing interface requires a separate IPv4 address. This consumes a lot of IP addresses. RFC 5549 defines the BGP unnumbered standard. It allows to use interface's IPv6 link local address (LLA) to set up a BGP session with a peer. With BGP unnumbered the IPv6 LLA of the remote is automatically discovered via Router Advertisement (RA) protocol. Important: This does not (!) mean that IPv6 must be deployed in the network. BGP uses RFC 5549 to encode IPv4 routes as reachable over IPv6 next-hop using the LLA. Having unnumbered interfaces does not mean no IPv4 address may be in place. It is a good practice to configure an IP address to the never failing and always present local loopback interface (lo). This lo address is reachable over BGP from other peers because the RFC 5549 standard provides an encoding scheme to allow a router to advertise IPv4 routes with an IPv6 next-hop. BGP unnumbered also has an advantage from security perspective. It removes IPv4 and global IPv6 addresses from router interfaces, thus reducing the attack vector.
To sum it up:
In BGP, ASN is how BGP peers know each other.
Within the data center each BGP router is identified by a private autonomous system number (ASN). This ASN is used for internal communication. The default is to have 2-byte ASN. To avoid having to find workarounds in case the ASN address space is exhausted, a 4-byte ASN that supports up to 95 million ASNs (4200000000–4294967294) is used from the beginning.
ASN numbering in a CLOS topology should follow a model to avoid routing problems (path hunting) due to it's redundant nature. Within a CLOS topology the following ANS numbering model is suggested to solve path hunting problems:
As stated, BGP is a multi-protocol routing protocol. Since it is planned to use IPv4 and overlay networks using EVPN/VXLAN several address-families have to be activated for the BGP sessions to use:
Ethernet VPN (EVPN) is an overlay virtual network that connects layer-2 segments over layer-3 infrastructure. EVPN is an answer to common problems of entire layer-2 data centers.
Challenges such as large failure domains, spanning tree complexities, difficult troubleshooting and scaling issues are addressed by EVPN:
Virtual routing permits multiple network paths without the need of multiple switches. Hence the servers are logically isolated by assigning their networks to dedicated virtual routers using virtual routing and forwarding (short: VRF).
EVPN (technology) is based on BGP as control plane protocol (underlay) and VXLAN as data plane protocol (overlay).
As EVPN is an overlay network, only the VXLAN Tunnel End Points (VTEPs) must be configured. In the case of two-tier CLOS networks leaf switches are tunnel endpoints.
In EVPN routing is assumed to occur in the context of a VRF. VRF enables true multitenancy. Therewith, VRF is the first step for EVPN configuration and there is a 1:1 relationship between tenant and VRF.
To enable layer-2 connectivity, we need a special interface to route between layer-2 networks. This interface is called Switched VLAN Interface (SVI). The SVI is realized with a VLAN. It is part of a VRF (layer-3).
The VTEP configuration requires the setup of a VXLAN interface. A VLAN aware bridge interconnects the VXLAN interface and the SVI.
Required Interfaces to establish the EVPN control plane:
Picture 3: Required interfaces on the switch to wire up the vrf to swp 1 connectivity with a given vxlan
Integrated routing and bridging (IRB) is the most complex part of EVPN. You could choose between centralized or distributed routing, and between asymmetrical (routing on ingress) or symmetrical (routing on ingress and egress) routing. We expect a lot of traffic within the data center itself which implies the need to avoid zigzag routing. This is why we go with distributed routing model. Further it is recommended to use the symmetric model since it makes the cut in most cases and has advantages in scalability (see "EVPN in the Data Center", Dinesh G. Dutt).
In a layer-3 network it is important to associate each interface with a proper Maximum Transmission Unit (MTU) to avoid fragmentation of IP packets. Typical modern networks do not fragment IP packets and the introduction of VXLAN adds another additional header to the packets that must not exceed the MTU. If the MTU is exceeded, VXLAN might just fail without error. This already represents a difficult-to-diagnose connectivity issue that has to be avoided.
It is common practice to set the MTU for VXLAN facing interfaces (e.g. inter-switch links) to a value of 9216
to compensate the additional VXLAN overhead and an MTU of 9000
as a default to other interfaces (e.g. server facing ports). The common MTU of 1500
is not sufficient for traffic inside a data center!
Routing is needed for communication between VXLAN tunnels or between a VXLAN tunnel and an external networks. VXLAN routing supports layer-3 multi-tenancy. All routing occurs in the context of a VRF. There is a 1:1 relation of a VRF to a tenant. Picture 3 illustrates this. Servers A and B belong to the same vrf VRF1. Server C is enslaved into VRF2. There is no communication possible between members of VRF1 and those of VRF2.
Picture 4: Illustration of two distinct routing tables of VRF1 (enslaved: servers A and B) and VRF2 (enslaved: server C)
To leaverage the potential and power of BGP, VRF, EVPN/VXLAN without a vendor lock-in the implementation relies on hardware that is supported by open network operating system: SONiC.
Implementation of the network operation requires the data center infrastructure to be in place. To implement a functional meaning for the parts of the CLOS network, all members must be wired accordingly.
Reference: See the CLOS overview picture in ./README.md.
Name | Wiring |
---|---|
Tenant server (aka Machine) | Bare metal server that is associated to a tenant. Dual-connected to leafs. |
Tenant firewall | Bare metal server that is associated to a tenant. Dual-connected to leafs. |
Leaf | Network Switch that interconnects tenant servers and firewalls. Connected to spines. |
Spine | Network switch that interconnects leafs and exit switches. |
Exit | Network switch that connects to spines and interconnects to external networks. |
Management Server | Jump-host to access all network switches within the CLOS topology for administrative purpose. |
Management Switch | Connected to the management port of each of the network switches. |
Tenant servers are organized into a layer called projects. In case those tenant servers require access to or from external networks, a new tenant server to function as a firewall is created. Leaf and spine switches form the fundament of the CLOS network to facilitate redundancy, resilience and scalability. Exit switches establish connectivity to or from external networks. Management Switch and Management Server are mandatory parts that build a management network to access the network switches for administration.
To operate the CLOS topology, software defined configuration to enable BGP, VRF, EVPN and VXLAN must be set up.
SONiC as the network operating system will be installed on all network switches (leaves, spines, exit switches) within the CLOS topology. SONiC cannot be installed on bare metal servers that require BGP/EVPN but does not have a switching silicon.
Components without a switching silicon are:
There exist two paradigms to use BGP and/or VXLAN/EVPN on non switching bare metal servers: BGP-to-the-host and EVPN-to-the-host. Both describe a setup of Free Range Routing Framework (see frrouting.org) and its configuration. FRR seamlessly integrates with the native Linux IP networking stacks.
Starting with an explanation of the tenant server's BGP-to-the-Host helps to get an insight into the setup of the CLOS network from a bottom-up perspective.
Tenant servers are dual-connected to leaf switches. To communicate with other servers or reach out to external networks they must join a BGP session with each of the leaf switches. Thus, it is required to bring BGP to those hosts (aka BGP-to-the-Host). Each tenant server becomes a BGP router (aka BGP speaker).
BGP-to-the-Host is established by installing and configuring FRR. The required FRR configuration for tenant servers is limited to a basic setup to peer with BGP next-hops:
# /etc/network/interfaces
+
+auto lo
+iface lo inet static
+ address 10.0.0.1/32
+
+auto lan0
+iface lan0 inet6 auto
+ mtu 9000
+
+auto lan1
+iface lan1 inet6 auto
+ mtu 9000
Listing 1: Network interfaces of a tenant server.
Listing 1 shows the local interfaces configuration. lan0 and lan1 connect to the leaves. As described, there is no IPv4 address assigned to them (BGP unnumbered). The local loopback has an IPv4 address assigned that is announced by BGP.
The required BGP configuration:
# /etc/frr/frr.conf
+
+frr version 7.0
+frr defaults datacenter
+log syslog debugging
+service integrated-vtysh-config
+!
+interface lan0
+ ipv6 nd ra-interval 6
+ no ipv6 nd suppress-ra
+!
+interface lan1
+ ipv6 nd ra-interval 6
+ no ipv6 nd suppress-ra
+!
+router bgp 4200000001
+ bgp router-id 10.0.0.1
+ bgp bestpath as-path multipath-relax
+ neighbor TOR peer-group
+ neighbor TOR remote-as external
+ neighbor TOR timers 1 3
+ neighbor lan0 interface peer-group TOR
+ neighbor lan1 interface peer-group TOR
+ neighbor LOCAL peer-group
+ neighbor LOCAL remote-as internal
+ neighbor LOCAL timers 1 3
+ neighbor LOCAL route-map local-in in
+ bgp listen range 10.244.0.0/16 peer-group LOCAL
+ address-family ipv4 unicast
+ redistribute connected
+ neighbor TOR route-map only-self-out out
+ exit-address-family
+!
+bgp as-path access-list SELF permit ^$
+!
+route-map local-in permit 10
+ set weight 32768
+!
+route-map only-self-out permit 10
+ match as-path SELF
+!
+route-map only-self-out deny 99
+!
Listing 2: FRR configuration of a tenant server.
The frr configuration in Listing 2 starts with frr defaults datacenter
. This is a marker that enables compile-time provided settings that e.g. set specific values for BGP session timers. This is followed by a directive to state that instead of several configuration files for different purposes a single frr.conf file is used: service integrated-vtysh-config
. The two interface specific blocks starting with interface ...
enable the RA mechanism that is required for BGP unnumbered peer discovery. There is a global BGP instance configuration router bgp 4200000001
that sets the private ASN. The BGP router configuration contains a setup that identifies the BGP speaker bgp router-id 10.0.0.1
. This router id should be unique. It is a good practice to assign the local loopback IPv4 as router-id. To apply the same configuration to several interfaces a peer group named TOR
is defined via neighbor TOR peer-group
. remote-as external
activates external BGP for this peer group. To have a fast convergence, limits of default timers are reduced by timer 1 3
section. The two BGP-peer-facing interfaces are enslaved into the peer-group to inherit the peer-group's setup. Activation of IPv4 unicast protocol is completed with address-family ipv4 unicast
. To prevent a tenant server from announcing other paths than lo
interface a route-map only-self-out
is defined. This route map is activated within the ipv4 address family: neighbor TOR route-map only-self-out out
.
Application of the route map only-self-out
enables to announce only local ip(s). This is to avoid that a tenant server announces paths to other servers (prevents unwanted traffic). To achieve this:
the route-map named only-self-out
permits only matches against an access list named SELF
access list SELF
permits only empty path announcements
the path of the tenant server itself has no ASN. It is always empty (see line *> 10.0.0.2/32 0.0.0.0 0 32768 ?
):
root@machine:~# vtysh -c 'show bgp ipv4 unicast'
+BGP table version is 7, local router ID is 10.0.0.2, vrf id 0
+Default local pref 100, local AS 4200000002
+Status codes: s suppressed, d damped, h history, * valid, > best, = multipath,
+ i internal, r RIB-failure, S Stale, R Removed
+Nexthop codes: @NNN nexthop's vrf id, < announce-nh-self
+Origin codes: i - IGP, e - EGP, ? - incomplete
+
+ Network Next Hop Metric LocPrf Weight Path
+*= 0.0.0.0/0 lan1 0 4200000012 4200000040 i
+*> lan0 0 4200000011 4200000040 i
+*= 10.0.0.1/32 lan1 0 4200000012 4200000001 ?
+*> lan0 0 4200000011 4200000001 ?
+*> 10.0.0.2/32 0.0.0.0 0 32768 ?
+*= 10.0.0.78/32 lan1 0 4200000012 4200000001 ?
+*> lan0 0 4200000011 4200000001 ?
+
+Displayed 4 routes and 7 total paths
That is why only the self ip (looback ip) is announced.
To allow for peering between FRR and other routing daemons on a tenant server a listen range
is specified to accept iBGP sessions on the network 10.244.0.0/16
. Therewith it gets possible that pods / containers like metal-lb with IPs of this range may peer with FRR.
This is the only place where we use iBGP in our topology. For local peering this has the advantage, that we don't need an additional ASN that has to be handled / pruned in the AS-path of routes. Routes coming from other routing daemons look as if they are configured on the tenant server's lo interface from the viewpoint of the leaves. iBGP routes are differently handled than eBGP routes in BGPs best path algorithm. Generally BGP has the rule to prefer eBGP routes over iBGP routes (s. 'eBGP over iBGP' ). BGP adds automatically an weight based on the route type. To overcome this issue, we set the weight of iBGP routes to the same weight that eBGP routes have, namely 32768 (set weight 32768
). Without this configuration we will only get a single route to the IPs announced via iBGP. So this setting is essential for HA/failover!
Statistics of the established BGP session can be viewed locally from the tenant server via: sudo vtysh -c 'show bgp ipv4 unicast'
To establish this BGP session a BGP setup is required on the leaves as well.
Every leaf switch is connected to every spine switch. Tenant servers can be distributed within the data center and thus be connected to different leaves. Routing for tenant servers is isolated in unique VRFs. These constraints imply several configuration requirements for the leaf and spine switches:
The leaf setup requires the definition of a tenant VRF that enslaves the tenant server facing interfaces:
# /etc/network/interfaces
+
+# [...]
+
+iface vrf3981
+ vrf-table auto
+
+iface swp1
+ mtu 9000
+ post-up sysctl -w net.ipv6.conf.swp1.disable_ipv6=0
+ vrf vrf3981
+
+# [...]
Listing 3: Fragment that shows swp1 being member of vrf vrf3981.
There is a VRF defintion iface vrf3981
to create a distinct routing table and a section vrf vrf3981
that enslaves swp1 (connects the tenant server) into the VRF. Those host facing ports are also called edge ports
.
Unfortunately, due to a kernel bug, IPv6 is not reliably enabled, so it is enforced explicitly via post-up sysctl -w net.ipv6.conf.swp1.disable_ipv6=0
. If this post-up
trigger is missing the LLA of the interface might be absent.
Additional to the VRF definition the leaf must be configured to provide and connect a VXLAN interface to establish a VXLAN tunnel. This network virtualization begins at the leaves. Therefore, the leaves are also called Network Virtualization Edges (NVEs). The leaves encapsulate and decapsulate VXLAN packets.
# /etc/network/interfaces
+
+# [...]
+
+iface bridge
+ bridge-ports vni3981
+ bridge-vids 1001
+ bridge-vlan-aware yes
+
+iface vlan1001
+ mtu 9000
+ vlan-id 1001
+ vlan-raw-device bridge
+ vrf vrf3981
+
+iface vni3981
+ mtu 9000
+ bridge-access 1001
+ bridge-arp-nd-suppress on
+ bridge-learning off
+ mstpctl-bpduguard yes
+ mstpctl-portbpdufilter yes
+ vxlan-id 3981
+ vxlan-local-tunnelip 10.0.0.11
+
+# [...]
Listing 4: Fragment that shows VXLAN setup for vrf vrf3981.
All routing happens in the context of the tenant VRF. To send and receive packets of a VRF, several interface are in place.
A bridge is used to attach VXLAN interface bridge-ports vni3981
and map its local VLAN to a VNI. Router MAC addresses of remote VTEPs are installed over this interface.
The Routed VLAN Interface or Switched Virtual Interface (SVI) iface vlan1001
is configured corresponding to the per-tenant VXLAN interface. It is attached to the tenant VRF. Remote host routes are installed over this SVI. The vlan-raw-device bridge
is used to associate the SVI with the VLAN aware bridge. For a packet received from a locally attached host the SVI interface corresponding to the VLAN determines the VRF vrf vrf3981
.
The VXLAN interface iface vni3981
defines a tunnel address that is used for the VXLAN tunnel header vlxan-local-tunnelip 10.0.0.11
. This VTEP IP address is typically the loopback device address of the switch. When EVPN is provisioned, data plane MAC learning for VXLAN interfaces must be disabled because the purpose of EVPN is to exchange MACs between VTEPs in the control plane: bridge-learning off
. EVPN is responsible for installing remote MACs. bridge-arp-nd-suppress
suppresses ARP flooding over VXLAN tunnels. Instead, a local proxy handles ARP requests received from locally attached hosts for remote hosts. ARP suppression is the implementation for IPv4; ND suppression is the implementation for IPv6. It is recommended to enable ARP suppression on all VXLAN interfaces. Bridge Protocol Data Unit (BPDU) are not transmitted over VXLAN interfaces. So as a good practice bpduguard and pbdufilter are enabled with mstpctl-bpduguard yes
and mstpctl-portbpdufilter yes
. These settings filter BPDU and guard the spanning tree topology from unauthorized switches affecting the forwarding path. vxlan-id 3981
specifies the VXLAN Network Identifier (VNI). The type of VNI can either be layer-2 (L2) or layer-3 (L3). This is an implicit thing. A VNI is a L3 VNI (L3VNI) when a mapping exists that maps the VNI to a VRF (configured in /etc/frr/frr.conf
) otherwise it is a L2 VNI (L2VNI).
# /etc/frr/frr.conf
+# [...]
+vrf vrf3981
+ vni 3981
+ exit-vrf
+#[...]
+router bgp 4200000011
+# [...]
+ address-family ipv4 unicast
+ redistribute connected route-map LOOPBACKS
+ # [...]
+ address-family l2vpn evpn
+ neighbor FABRIC activate
+ advertise-all-vni
+ exit-address-family
+# [...]
+router bgp 4200000011 vrf vrf3981
+ # [...]
+ address-family ipv4 unicast
+ redistribute connected
+ neighbor MACHINE maximum-prefix 100
+ exit-address-family
+ !
+ address-family l2vpn evpn
+ advertise ipv4 unicast
+ exit-address-family
+
+# [...]
+route-map LOOPBACKS permit 10
+ match interface lo
+# [...]
Listing 5: Leaf FRR configuration.
Listing 5 shows the required FRR configuration of the BGP control plane. Only content not discussed so far is explained. The section vrf vrf3981
contains the mapping from layer-3 VNI to VRF. This is required to be able to install EVPN IP prefix routes (type-5 routes) into the routing table. Further the file contains a global BGP instance router bgp 4200000011
definition. A new setting redistribute connected route-map LOOPBACKS
is in place to filter the redistribution of routes that are not matching the local loopback interface. The route-map is defined with route-map LOOPBACKS permit 10
. With the configuration line address-family l2vpn evpn
, the EVPN address family is enabled between BGP neighbours. advertise-all-vni
makes the switch a VTEP configures it in such a way, that all locally configured VNIs should be advertised by the BGP control plane.
The second BGP instance configuration is specific to the tenant VRF router bgp 4200000011 vrf vrf3981
. This VRF BGP instance configures the l2vpn evpn address family with advertise ipv4 unicast
to announce IP prefixes in BGP's routing information base (RIB). This is required to apply learned routes to the routing tables of connected hosts. The Maximum-Prefix feature is useful to avoid that a router recieves more routes than the router memory can take. The maximum number of prefixes a tenant server is allowed to announce is limited to 100
with: neighbor MACHINE maximum-prefix 100
.
On the spine switches the setup is quite simple. /etc/network/interfaces
contains the loopback interface definition to support BGP unnumbered and listings for connected switch ports to provide proper MTUs (Listing 6). I.e. swp1 is configured with an MTU of 9216 as it is a VXLAN-facing interface.
# /etc/network/interfaces
+# [...]
+iface swp1
+ mtu 9216
Listing 6: Fragment of spine interface configuration.
The spines are important to forward EVPN routes and transport VXLAN packets between the VTEPs. They are not configured as VTEPs. The FRR configuration only contains the already known global BGP instance configuration router bgp 4200000020
plus the activation of the l2vpn evpn address family address-family l2vpn evpn
to enable EVPN type-5 route forwarding (Listing 7).
hostname spine01
+username admin nopassword
+!
+# [...]
+interface swp1
+ ipv6 nd ra-interval 6
+ no ipv6 nd suppress-ra
+!
+# [...]
+!
+router bgp 4200000020
+ # [...]
+!
+ address-family l2vpn evpn
+ neighbor FABRIC activate
+ exit-address-family
+!
+# [...]
Listing 7: Fragment of spine FRR configuration to show the activated L2VPN EVPN address-family.
In case a tenant server needs to reach out to external networks as the Internet, a tenant firewall is provisioned. The firewall is a bare metal server without a switching silicon. Thus, there is no installation of SONiC. FRR provides the BGP / EVPN functionality known as EVPN-to-the-host
. The firewall is configured as a VTEP and applies dynamic route-leaking
to install routes of an foreign VRF. The set of routes that are leaked are restricted with route-maps.
As Listing 8 shows, the firewall is configured with VXLAN interfaces as known from the leaf setup. Additionally, a VXLAN setup for VRF vrfInternet
is added to provide Internet access. vrfInternet contains a route to the Internet that will be leaked into the tenant VRF.
Traffic that originates from the tenant network 10.0.0.0/22
will be masqueraded before leaving the inferface vlanInternet
towards the internet.
# /etc/network/interfaces
+# [...]
+iface bridge
+# [...]
+iface vlan1001
+# [...]
+iface vni3981
+# [...]
+iface vrf3981
+# [...]
+iface vlanInternet
+ mtu 9000
+ vlan-id 4009
+ vlan-raw-device bridge
+ vrf vrfInternet
+ address 185.1.2.3
+ post-up iptables -t nat -A POSTROUTING -s 10.0.0.0/22 -o vlanInternet -j MASQUERADE
+ pre-down iptables -t nat -D POSTROUTING -s 10.0.0.0/22 -o vlanInternet -j MASQUERADE
+
+iface vniInternet
+ mtu 9000
+ bridge-access 4009
+ mstpctl-bpduguard yes
+ mstpctl-portbpdufilter yes
+ vxlan-id 104009
+ vxlan-local-tunnelip 10.0.0.40
+
+iface vrfInternet
+ mtu 9000
+ vrf-table auto
Listing 8: Interfaces configuration of firewall to show the VTEP interface configuration.
To install a default route into the routing table of tenant VRF vrf3981 a dynamic route leak is established for it (import vrf vrfInternet
). With the help of a route-map import vrf route-map vrf3981-import-map
only the default route will be leaked:
root@firewall01:~# vtysh -c 'show ip route vrf vrf3981'
+# [...]
+VRF vrf3981:
+S>* 0.0.0.0/0 [1/0] is directly connected, vrfInternet(vrf vrfInternet), 03:19:26
+B>* 10.0.0.1/32 [20/0] via 10.0.0.12, vlan1001 onlink, 02:34:48
+ * via 10.0.0.11, vlan1001 onlink, 02:34:48
+B>* 10.0.0.2/32 [20/0] via 10.0.0.12, vlan1001 onlink, 02:34:49
+ * via 10.0.0.11, vlan1001 onlink, 02:34:49
To receive responses from vrfInternet in vrf3981 a route is leaked into vrfInternet as well (import vrf vrf3981
) restricted with the route-map vrfInternet-import-map
that allows leaking of the tenant routes as well as internet prefixes used on worker nodes of the tenant. To limit the prefixes that are announced from the firewall within the global BGP instance a route-map only-self-out
is defined and applied within the ipv4 and l2vpn evpn address family. Together with the definition of an as path access list bgp as-path access-list
it avoids the announcement of prefixes to non VRF BGP peers.
# /etc/frr/frr.conf
+!
+vrf vrf3981
+ vni 3981
+!
+vrf vrfInternet
+ vni 104009
+!
+# [...]
+!
+router bgp 4200000040
+ # [...]
+ !
+ address-family ipv4 unicast
+ # [...]
+ neighbor FABRIC route-map only-self-out out
+ exit-address-family
+ !
+!
+router bgp 4200000040 vrf vrf3981
+ # [...]
+ address-family ipv4 unicast
+ redistribute connected
+ import vrf vrfInternet
+ import vrf route-map vrf3981-import-map
+ # [...]
+ addrress-family l2vpn evpn
+ advertise ipv4 unicast
+ # [...]
+router bgp 4200000040 vrf vrfInternet
+ # [...]
+ address-family ipv4 unicast
+ redistribute connected
+ import vrf vrf3981
+ import vrf route-map vrfInternet-import-map
+ # [...]
+ addrress-family l2vpn evpn
+ advertise ipv4 unicast
+ # [...]
+ bgp as-path access-list SELF permit ^$
+!
+route-map only-self-out permit 10
+ match as-path SELF
+!
+route-map only-self-out deny 99
+!
+route-map LOOPBACKS permit 10
+ match interface lo
+!
+ip prefix-list vrf3981-import-prefixes seq 100 permit 0.0.0.0/0
+!
+route-map vrf3981-import-map permit 10
+ match ip address prefix-list vrf3981-import-prefixes
+!
+route-map vrf3981-import-map deny 99
+!
+ip prefix-list vrfInternet-import-prefixes seq 100 permit 10.0.0.0/22 le 32
+ip prefix-list vrfInternet-import-prefixes seq 101 permit 185.1.2.0/24 le 32
+ip prefix-list vrfInternet-import-prefixes seq 102 permit 185.27.0.0/27 le 32
+!
+route-map vrfInternet-import-map permit 10
+ match ip address prefix-list vrfInternet-import-prefixes
+!
+route-map vrfInternet-import-map deny 99
+!
+line vty
+!
Listing 9: FRR configuration of a tenant firewall to show route leak and prefix announcement filtering.
Traffic to external networks is routed via the firewalls to the exit switch. The exit switch, as an exception, connects to the Internet Service Provider using numbered BGP. Numbered BGP implies to assign IPv4 addresses to network interfaces (See Listing 10, swp1). Interface swp1 is enslaved into vrf vrfInternet
to include the port that is connected to the ISP within the VRF that is expected to contain a way into the Internet. The exit switch is configured to be a VTEP to terminate traffic coming from the firewall VRF vrfInternet
.
# /etc/network/interfaces
+# [...]
+iface swp1
+ mtu 9000
+ vrf vrfInternet
+ address 172.100.0.2/30
+# [...]
+iface vlan4000
+ mtu 9000
+ address 10.0.0.71/24
+ vlan-id 4000
+ vlan-raw-device bridge
+# [...]
+iface vlanInternet
+# [...]
+iface vniInternet
+# [...]
+iface vrfInternet
+# [...]
Listing 10: Fragment of interfaces configuration of exit switch.
The configuration of FRR is equivalent to the previously discussed ones. It contains a global BGP instance configuration that enables IPv4 unicast and l2vpn evpn address families. The vrfInternet BGP instance defines neighbor 172.100.0.1 peer-group INTERNET
to use "old style BGP" transit network.
# [..]
+vrf vrfInternet
+ vni 104009
+!
+# [...]
+router bgp 4200000031
+ bgp router-id 10.0.0.31
+ neighbor FABRIC peer-group
+ neighbor FABRIC remote-as external
+ neighbor FABRIC timers 1 3
+ # [...]
+ !
+ address-family ipv4 unicast
+ neighbor FABRIC activate
+ redistribute connected route-map LOOPBACKS
+ exit-address-family
+ !
+ address-family l2vpn evpn
+ neighbor FABRIC activate
+ advertise-all-vni
+ exit-address-family
+!
+router bgp 4200000031 vrf vrfInternet
+ bgp router-id 10.0.0.31
+ bgp bestpath as-path multipath-relax
+ neighbor INTERNET peer-group
+ neighbor INTERNET remote-as external
+ neighbor INTERNET timers 1 3
+ neighbor 172.100.0.1 peer-group INTERNET
+ !
+ address-family ipv4 unicast
+ neighbor INTERNET route-map PREPEND-PATH-TO-DISFAVOR-IN in
+ neighbor INTERNET route-map PREPEND-PATH-TO-DISFAVOR-OUT out
+ exit-address-family
+
+ !
+ address-family l2vpn evpn
+ advertise ipv4 unicast
+ exit-address-family
+!
+route-map LOOPBACKS permit 10
+ match interface lo
+!
+route-map PREPEND-PATH-TO-DISFAVOR-IN permit 10
+ set as-path prepend last-as 2
+!
+route-map PREPEND-PATH-TO-DISFAVOR-OUT permit 10
+ set as-path prepend last-as 2
+!
+vrf mgmt
+ ip route 10.0.0.0/24 10.0.0.71 nexthop-vrf default
+ exit-vrf
+!
+ip route 0.0.0.0/0 192.168.0.254 nexthop-vrf mgmt
+!
+line vty
+!
Listing 11: Fragment of FRR configuration on exit switch to give an example for numbered BGP and route leak.
In addition to the standard BGP setup the exit switches have configured static route leak
to support internet access during PXE. There is one route leak from default
VRF into the mgmt
VRF defined with: ip route 0.0.0.0/0 192.168.0.254 nexthop-vrf mgmt
and another one from mgmt
VRF into the default
VRF: ip route 10.0.0.0/24 10.0.0.71 nexthop-vrf default
. The first one adds a default route into the default
VRF and the second one routes traffic destined to the PXE network back from mgmt
VRF into the default
VRF.
To reach out into external networks each of the exit nodes joins a BGP session with a distinct external router. There is a different latency to each of these routers. To favor routes of exit nodes connected with lower latency over exit nodes with higher latency two route maps PREPEND-PATH-TO-DISFAVOR-IN
and PREPEND-PATH-TO-DISFAVOR-OUT
are added to high latency exit nodes. These route maps apply actions to prolong the path of the incoming and outgoing routes. Because of this path extension BGP will calculate a lower weight for these paths and favors paths via other exit nodes. It is important to know that within an address family only one route map (the last) will be applied. To apply more than one actions within a route-map the required entries can be applied to a single route-map.
Before a bare metal server can act as tenant server or tenant firewall, it has to be provisioned. Within the Metal domain, this provisioning mode is called "PXE Mode" since it is based on Preboot eXecution Environment (PXE). PXE uses protocols like DHCP. This requires all bare metal servers that need provisioning to be located in a layer-2 domain where DHCP is available. This domain is a VLAN vlan4000
. A DHCP server for PXE Mode is installed on the exit switches to work in this specific VLAN.
# /etc/default/isc-dhcp-server
+INTERFACES="vlan4000"
Listing 13: DHCP server configration of exit switches.
As shown in listing 13, the PXE DHCP server is located on the exit switches and enforced to bind to interface vlan4000
. This represents a layer-2 separation that allows only DHCP clients in the same VLAN to request IP addresses. Only unprovisionned bare metal servers are configured to be member of this VLAN. Thus unwanted or accidential provisionning is impossible.
To provide vlan4000
on the leaves (that face the bare metal servers) the exit and leaf switches are configured as VTEPs and share an interface configuration that contains the required interfaces (Listing 13). Since no EVPN routing is in place vni104000
is configured as an L2 VNI (there is no mapping for this VNI in /etc/frr/frr.conf
).
# /etc/network/interfaces
+# [...]
+iface bridge
+ bridge-ports vni104000 [...]
+ bridge-vids 4000 [...]
+ bridge-vlan-aware yes
+
+iface vlan4000
+# [...]
+
+iface vni104000
+# [...]
Listing 13: Interfaces configuration on exit and leaf switches to show DHCP/PXE related fragments.
On the leaf switches the bare metal server facing ports are configured as VLAN access ports to carry the traffic for only the PXE VLAN vlan4000
(listing 14)to separate unprovisioned from other bare metal servers.
# /etc/network/interfaces
+# [...]
+auto swp1
+iface swp1
+ mtu 9000
+ bridge-access 4000
+# [...]
Listing 14: VLAN access setup for bare metal server facing ports on leaves.
Once a bare metal server is provisioned it is deconfigured from PXE VLAN vlan4000
to avoid accidential or unwanted provisioning.
During provisioning bare metal servers get internet access via the management network of the exit switches. This is because the exit switches are announced as DHCP gateway to the DHCP clients.
To manage network switches beside the out-of-band system console access a further management access is required. For this purpose the concept of Management VRF is applied. The Management VRF is a subset of VRF. It provides a separation between out-of-band management network and the in-band data plane network by introducing another routing table mgmt. SONiC supports eth0 to be used as the management interface.
To enable and use the Management VRF all switches have to be connected via their eth0 interface to a management-switch. The management switch is connected to a management server. All access is established from within the managment server. Logins to the switch are set into the Management VRF context once the Managment VRF is enabled.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Our operating system images are built on regular basis from the metal-images repository.
All images are hosted on GKE at images.metal-stack.io. Feel free to use this as a mirror for your metal-stack partitions if you want. The metal-stack developers continuously have an eye on the supported images. They are updated regularly and scanned for vulnerabilities.
The operating system images that we build are trimmed down to their bare essentials for serving as Kubernetes worker nodes. Small image sizes make machine provisioning blazingly fast.
The supported images for worker nodes currently are:
Platform | Distribution | Version |
---|---|---|
Linux | Debian | 11 |
Linux | Ubuntu | 22.04 |
The supported images for firewalls are:
Platform | Distribution | Version | Based On |
---|---|---|---|
Linux | Ubuntu | 3 | 22.04 |
It is fully possible to build your own operating system images and provide them through the metal-stack.
There are some conventions though that you need to follow in order to make your image installable through the metal-hammer. You should understand the machine provisioning sequence before starting to write your own images.
md5
checksum file with the same name as the image archive needs to be provided in the download path along with the actual os imagepackages.txt
containing the packages contained in the OS image should be provided in the download path (not strictly required)os-major.minor.patch
➡️ ubuntu-19.10.20191018
)install.sh
script, which applies user-specific configuration in the installed imageinstall.yaml
file that the metal-hammer writes to /etc/metal/install.yaml
kexec
command is issued by the metal-hammer after running the install.sh
. We do this because kexec
is much faster than rebooting a machine.Building own operating system images is an advanced topic. When you have just started with metal-stack, we recommend using the public operating system images first.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
When working with bare-metal servers, providing cloud storage is a challenge. With physical machines there is no opportunity that a hypervisor can mount storage devices into the servers and thus, we have to implement other mechanisms that are capable of dynamically mounting storage onto the machines.
In the meantime, we have started to integrate third-party solutions into our metal-stack landscape. They help us to provide modern, well-integrated and scalable storage solutions to our end-users.
Lightbits Labs offers a proprietary implementation of persistent storage using NVMe over TCP. The solution has some very superior traits that fit very well to metal-stack. The strongest advantages are:
We are maintaining an open source integration for running LightOS in our Gardener cluster provisioning. You can enable it through the controller registration of the gardener-extension-provider-metal.
With the integration in place, the extension-provider deploys a duros-controller along with a Duros Storage CRD into the seed's shoot namespace. The duros-controller takes care of creating projects and managing credentials at the Lightbits Duros API. It also provides storage classes as configured in the extension-provider's controller registration to the customer's shoot cluster such that users can start consuming the Lightbits storage immediately.
If you wish to quickly start off with cluster provisioning without caring so much about complex cloud storage solutions, we recommend using a small storage driver we wrote called csi-driver-lvm. It provides a storage class that manages node-local storage through LVM.
A definition of a PVC can look like this:
apiVersion: v1
+kind: PersistentVolumeClaim
+metadata:
+ name: csi-pvc
+spec:
+ accessModes:
+ - ReadWriteOnce
+ resources:
+ requests:
+ storage: 100Mi
+ storageClassName: csi-lvm-sc-linear
The solution does not provide cloud-storage or whatsoever, but it improves the user's accessibility of local storage on bare-metal machines through Kubernetes. Check out the driver's documentation here.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Before starting to buy any hardware, you should try out the metal-stack on your notebook and familiarize with the software.
For this, we made the mini-lab.
The mini-lab is a fully virtual setup of metal-stack and is supposed to be run locally on a single machine. For this reason, the setup was slightly simplified in comparison to full-blown setups on real hardware. However, the lab should help to understand all ideas behind the metal-stack.
Get your hands dirty and follow the guide on how to get on with the mini-lab here.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.
Settings
This document was generated with Documenter.jl version 0.27.25 on Monday 16 October 2023. Using Julia version 1.9.3.