Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/kubernetes-sigs/cluster-api-provider-aws

Kubernetes Cluster API Provider AWS provides consistent deployment and day 2 operations of "self-managed" and EKS Kubernetes clusters on AWS.
https://github.com/kubernetes-sigs/cluster-api-provider-aws

cluster-api k8s-sig-cluster-lifecycle kubernetes-cluster

Last synced: about 1 month ago
JSON representation

Kubernetes Cluster API Provider AWS provides consistent deployment and day 2 operations of "self-managed" and EKS Kubernetes clusters on AWS.

Awesome Lists containing this project

README

        

# Kubernetes Cluster API Provider AWS


Powered by AWS Cloud Computing







------

Kubernetes-native declarative infrastructure for AWS.

## What is the Cluster API Provider AWS

The [Cluster API][cluster_api] brings
declarative, Kubernetes-style APIs to cluster creation, configuration and
management.

The API itself is shared across multiple cloud providers allowing for true AWS
hybrid deployments of Kubernetes. It is built atop the lessons learned from
previous cluster managers such as [kops][kops] and
[kubicorn][kubicorn].

## Documentation

Please see our [book](https://cluster-api-aws.sigs.k8s.io) for in-depth documentation.

## Launching a Kubernetes cluster on AWS

Check out the [Cluster API Quick Start](https://cluster-api.sigs.k8s.io/user/quick-start.html) for launching a
cluster on AWS.

## Features

- Native Kubernetes manifests and API
- Manages the bootstrapping of VPCs, gateways, security groups and instances.
- Choice of Linux distribution using [pre-baked AMIs][published_amis].
- Deploys Kubernetes control planes into private subnets with a separate
bastion server.
- Doesn't use SSH for bootstrapping nodes.
- Installs only the minimal components to bootstrap a control plane and workers.
- Supports control planes on EC2 instances.
- [EKS support][eks_support]

------

## Compatibility with Cluster API and Kubernetes Versions

This provider's versions are compatible with the following versions of Cluster API
and support all Kubernetes versions that is supported by its compatible Cluster API version:

| | Cluster API v1alpha4 (v0.4) | Cluster API v1beta1 (v1.x) |
| --------------------------- | :-------------------------: | :-------------------------: |
| CAPA v1alpha4 `(v0.7)` | ✓ | ☓ |
| CAPA v1beta1 `(v1.x)` | ☓ | ✓ |
| CAPA v1beta2 `(v2.x, main)`| ☓ | ✓ |

(See [Kubernetes support matrix][cluster-api-supported-v] of Cluster API versions).

------

## Kubernetes versions with published AMIs

See [amis] for the list of most recently published AMIs.

------

## clusterawsadm

`clusterawsadm` CLI tool provides bootstrapping, AMI, EKS, and controller related helpers.

`clusterawsadm` binaries are released with each release, can be found under [assets](https://github.com/kubernetes-sigs/cluster-api-provider-aws/releases/latest) section.

`clusterawsadm` could also be installed via Homebrew on macOS and linux OS.
Install the latest release using homebrew:

```shell
brew install clusterawsadm
```

Test to ensure the version you installed is up-to-date:

```shell
clusterawsadm version
```

------

## Getting involved and contributing

Are you interested in contributing to cluster-api-provider-aws? We, the
maintainers and community, would love your suggestions, contributions, and help!
Also, the maintainers can be contacted at any time to learn more about how to get
involved.

In the interest of getting more new people involved we tag issues with
[`good first issue`][good_first_issue].
These are typically issues that have smaller scope but are good ways to start
to get acquainted with the codebase.

We also encourage ALL active community participants to act as if they are
maintainers, even if you don't have "official" write permissions. This is a
community effort, we are here to serve the Kubernetes community. If you have an
active interest and you want to get involved, you have real power! Don't assume
that the only people who can get things done around here are the "maintainers".

We also would love to add more "official" maintainers, so show us what you can
do!

This repository uses the Kubernetes bots. See a full list of the commands [here][prow].

### Build the images locally

If you want to just build the CAPA containers locally, run

```shell
REGISTRY=docker.io/my-reg make docker-build
```

### Tilt-based development environment

See [development][development] section for details.

### Implementer office hours

Maintainers hold office hours every two weeks, with sessions open to all
developers working on this project.

Office hours are hosted on a zoom video chat every other Monday
at 09:00 (Pacific) / 12:00 (Eastern) / 17:00 (Europe/London),
and are published on the [Kubernetes community meetings calendar][gcal].

### Other ways to communicate with the contributors

Please check in with us in the [#cluster-api-aws][slack] channel on Slack.

## Github issues

### Bugs

If you think you have found a bug please follow the instructions below.

- Please spend a small amount of time giving due diligence to the issue tracker. Your issue might be a duplicate.
- Get the logs from the cluster controllers. Please paste this into your issue.
- Open a [new issue][new_issue].
- Remember that users might be searching for your issue in the future, so please give it a meaningful title to help others.
- Feel free to reach out to the cluster-api community on the [kubernetes slack][slack].

### Tracking new features

We also use the issue tracker to track features. If you have an idea for a feature, or think you can help kops become even more awesome follow the steps below.

- Open a [new issue][new_issue].
- Remember that users might be searching for your issue in the future, so please
give it a meaningful title to help others.
- Clearly define the use case, using concrete examples. EG: I type `this` and
cluster-api-provider-aws does `that`.
- Some of our larger features will require some design. If you would like to
include a technical design for your feature please include it in the issue.
- After the new feature is well understood, and the design agreed upon, we can
start coding the feature. We would love for you to code it. So please open
up a **WIP** *(work in progress)* pull request, and happy coding.

>“Amazon Web Services, AWS, and the “Powered by AWS” logo materials are
trademarks of Amazon.com, Inc. or its affiliates in the United States
and/or other countries."

## Our Contributors

Thank you to all contributors and a special thanks to our current maintainers & reviewers:

| Maintainers | Reviewers |
|------------------------------------------------------------------| -------------------------------------------------------------------- |
| [@richardcase](https://github.com/richardcase) (from 2020-12-04) | [@cnmcavoy](https://github.com/cnmcavoy) (from 2023-10-16) |
| [@Ankitasw](https://github.com/Ankitasw) (from 2022-10-19) | [@AverageMarcus](https://github.com/AverageMarcus) (from 2022-10-19) |
| [@dlipovetsky](https://github.com/dlipovetsky) (from 2021-10-31) | [@luthermonson](https://github.com/luthermonson ) (from 2023-03-08) |
| [@nrb](https://github.com/nrb) (from 2024-05-24) | [@faiq](https://github.com/faiq) (from 2023-10-16) |
| [@AndiDog](https://github.com/AndiDog) (from 2023-12-13) | [@fiunchinho](https://github.com/fiunchinho) (from 2023-11-6) |
| | [@damdo](https://github.com/damdo) (from 2023-03-01) |

and the previous/emeritus maintainers & reviewers:

| Emeritus Maintainers | Emeritus Reviewers |
|------------------------------------------------------|--------------------------------------------------------|
| [@chuckha](https://github.com/chuckha) | [@ashish-amarnath](https://github.com/ashish-amarnath) |
| [@detiber](https://github.com/detiber) | [@davidewatson](https://github.com/davidewatson) |
| [@ncdc](https://github.com/ncdc) | [@enxebre](https://github.com/enxebre) |
| [@randomvariable](https://github.com/randomvariable) | [@ingvagabund](https://github.com/ingvagabund) |
| [@rudoi](https://github.com/rudoi) | [@michaelbeaumont](https://github.com/michaelbeaumont) |
| [@sedefsavas](https://github.com/sedefsavas) | [@sethp-nr](https://github.com/sethp-nr) |
| [@Skarlso](https://github.com/Skarlso) | [@shivi28](https://github.com/shivi28) |
| [@vincepri](https://github.com/vincepri) | [@dthorsen](https://github.com/dthorsen) |
| | [@pydctw](https://github.com/pydctw) |

All the CAPA contributors:





[slack]: https://kubernetes.slack.com/messages/CD6U2V71N
[good_first_issue]: https://github.com/kubernetes-sigs/cluster-api-provider-aws/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%22good+first+issue%22
[gcal]: https://calendar.google.com/calendar/embed?src=cgnt364vd8s86hr2phapfjc6uk%40group.calendar.google.com
[prow]: https://go.k8s.io/bot-commands
[new_issue]: https://github.com/kubernetes-sigs/cluster-api-provider-aws/issues/new
[cluster_api]: https://github.com/kubernetes-sigs/cluster-api
[kops]: https://github.com/kubernetes/kops
[kubicorn]: http://kubicorn.io/
[amis]: https://cluster-api-aws.sigs.k8s.io/topics/images/amis.html
[published_amis]: https://cluster-api-aws.sigs.k8s.io/topics/images/built-amis.html
[eks_support]: https://cluster-api-aws.sigs.k8s.io/topics/eks/index.html
[cluster-api-supported-v]: https://cluster-api.sigs.k8s.io/reference/versions.html
[development]: https://cluster-api-aws.sigs.k8s.io/development/development.html