Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release v0.29.4 #533

Merged
merged 22 commits into from
Aug 11, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
1a3c312
feat: added --post-apply-phases flag
May 6, 2024
9ed9665
chore: add validation to flag
May 8, 2024
e557c9f
fix: wrong package name
Jul 19, 2024
b715795
Merge pull request #514 from sighupio/feature/post-run-phases
nutellinoit Jul 31, 2024
9dc5171
feat: add lockfile (#528)
Al-Pragliola Jul 31, 2024
48c865c
feat(create pki): add command create pki to generate PKI files needed…
ralgozino Jul 31, 2024
6c1df0c
fix: block sending on closed channel
Aug 1, 2024
30161c0
fix: panic on closed channel mixpanel
Aug 1, 2024
1d1dbb7
chore(lockfile): improve error message
ralgozino Aug 1, 2024
6f04d5b
fix: closing a closed channel
Aug 1, 2024
9c88d7f
Merge pull request #529 from sighupio/chore-better-lock-file-message
ralgozino Aug 1, 2024
62be0b0
Add renew certificates command for kind OnPremises (#527)
alessiodionisi Aug 1, 2024
bc2a866
feat: add upgrade paths for 1.27.7, 1.28.2, 1.29.2
nutellinoit Aug 1, 2024
8970a56
chore: removed unused upgrade path and add new versions to compatibility
Aug 1, 2024
f49b3dc
chore: add new versions to compat matrix
Aug 1, 2024
24eff11
chore: bump version in README
Aug 1, 2024
d0aa6b1
fix: prevent env:// usage when the variable does not exist
Aug 1, 2024
91f0435
docs(readme): align readme with latest versions
ralgozino Aug 1, 2024
b1a7ecd
Merge pull request #531 from sighupio/docs-update-readme
nutellinoit Aug 5, 2024
17ff358
Merge pull request #530 from sighupio/feat/upgrade-paths-v1.29.2-and-…
nutellinoit Aug 8, 2024
c1a5b58
fix: add envs for e2e tests (#532)
alessiodionisi Aug 8, 2024
0f43967
feat: update fury-distribution library
nutellinoit Aug 10, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 34 additions & 0 deletions .rules/.golangci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,40 @@ linters-settings:
extra-rules: true
goimports:
local-prefixes: github.com/sighupio
gomoddirectives:
# we need to use replace to be able to use Internal Kubernetes libraries
# needed for the create PKI feature.
replace-allow-list:
- k8s.io/api
- k8s.io/apiextensions-apiserver
- k8s.io/apimachinery
- k8s.io/apiserver
- k8s.io/cli-runtime
- k8s.io/client-go
- k8s.io/cloud-provider
- k8s.io/cluster-bootstrap
- k8s.io/code-generator
- k8s.io/component-base
- k8s.io/component-helpers
- k8s.io/controller-manager
- k8s.io/cri-api
- k8s.io/csi-translation-lib
- k8s.io/dynamic-resource-allocation
- k8s.io/endpointslice
- k8s.io/kms
- k8s.io/kube-aggregator
- k8s.io/kube-controller-manager
- k8s.io/kube-proxy
- k8s.io/kube-scheduler
- k8s.io/kubectl
- k8s.io/kubelet
- k8s.io/legacy-cloud-providers
- k8s.io/metrics
- k8s.io/mount-utils
- k8s.io/pod-security-admission
- k8s.io/sample-apiserver
- k8s.io/sample-cli-plugin
- k8s.io/sample-controller
gosec:
excludes:
- G204
Expand Down
8 changes: 7 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,13 @@ test-integration:
@GOFLAGS=-mod=mod go test -v -tags=integration -timeout 120s ./...

test-e2e:
@GOFLAGS=-mod=mod ginkgo run -vv --trace -tags=e2e -timeout 600s -p test/e2e
@export KFD_AUTH_DEX_CONNECTORS_GITHUB_CLIENT_ID=dummy && \
export KFD_AUTH_DEX_CONNECTORS_GITHUB_CLIENT_SECRET=dummy && \
export KFD_BASIC_AUTH_PASSWORD=dummy && \
export KFD_AUTH_POMERIUM_COOKIE_SECRET=dummy && \
export KFD_AUTH_POMERIUM_IDP_CLIENT_SECRET=dummy && \
export KFD_AUTH_POMERIUM_SHARED_SECRET=dummy && \
GOFLAGS=-mod=mod ginkgo run -vv --trace -tags=e2e -timeout 600s -p test/e2e

test-expensive:
$(call yes-or-no, "WARNING: This test will create a cluster on AWS. Are you sure you want to continue?")
Expand Down
107 changes: 61 additions & 46 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,8 @@

<p>The Swiss Army Knife<br/>for the Kubernetes Fury Distribution</p>

<!-- FIXME: UPDATE THE BUILD BADGE WITH THE RIGHT BRANCH -->

[![Build Status](https://ci.sighup.io/api/badges/sighupio/furyctl/status.svg)](https://ci.sighup.io/sighupio/furyctl)
![Release](https://img.shields.io/badge/furyctl-v0.29.3-blue)
[![Build Status](https://ci.sighup.io/api/badges/sighupio/furyctl/status.svg?ref=refs/heads/main)](https://ci.sighup.io/sighupio/furyctl)
![Release](https://img.shields.io/badge/furyctl-v0.29.4-blue)
![Slack](https://img.shields.io/badge/slack-@kubernetes/fury-yellow.svg?logo=slack)
![License](https://img.shields.io/github/license/sighupio/furyctl)
[![Go Report Card](https://goreportcard.com/badge/github.com/sighupio/furyctl)](https://goreportcard.com/report/github.com/sighupio/furyctl)
Expand All @@ -21,7 +19,7 @@

> The next generation of `furyctl`, called "furyctl next", has been officially released. It is now in a stable state and available starting from version v0.25.0. The previous version, furyctl 0.11, is considered legacy and will only receive bug fixes. It will be maintained under the v0.11 branch.

## What is Furyctl?
## What is furyctl?

`furyctl` is the command line companion for the Kubernetes Fury Distribution to manage the **full lifecycle** of your Kubernetes Fury clusters.
<br/>
Expand Down Expand Up @@ -56,15 +54,6 @@ sudo mv /tmp/furyctl /usr/local/bin/furyctl

Alternatively, you can install `furyctl` using the asdf plugin.

<!--
### Installing with [Homebrew](https://brew.sh/)

```console
brew tap sighupio/furyctl
brew install furyctl
```
-->

### Installing with [asdf](https://github.com/asdf-vm/asdf)

Add furyctl asdf plugin:
Expand All @@ -80,7 +69,7 @@ $ furyctl version
...
goVersion: go1.22
osArch: amd64
version: 0.29.3
version: 0.29.4
```

### Installing from source
Expand All @@ -101,8 +90,6 @@ Once you've ensured the above dependencies are installed, you can proceed with t

1. Clone the repository:

<!-- FIXME: remove the branch switching in the future -->

```console
git clone [email protected]:sighupio/furyctl.git
# cd into the cloned repository
Expand All @@ -112,31 +99,31 @@ cd furyctl
2. Build the binaries by running the following command:

```console
make build
go build .
```

3. You will find the binaries for Linux and Darwin (macOS) for your current architecture inside the `dist` folder:
3. You will find the binaries for your current architecture inside the current folder:

```console
$ tree dist/furyctl_*/
dist/furyctl_darwin_amd64_v1
└── furyctl
dist/furyctl_linux_amd64_v1
└── furyctl
$ ls furyctl
furyctl
```

4. Check that the binary is working as expected:

> **Note** replace `darwin` with your OS and `amd64` with your architecture in the following commands.

```console
./dist/furyctl_darwin_amd64_v1/furyctl version
$ ./furyctl version
buildTime: unknown
gitCommit: unknown
goVersion: unknown
osArch: unknown
version: unknown
```

5. (optional) move the binary to your `bin` folder, in macOS:

```console
sudo mv ./dist/furyctl_darwin_amd64_v1/furyctl /usr/local/bin/furyctl
sudo mv ./furyctl /usr/local/bin/furyctl
```

## Usage
Expand All @@ -150,25 +137,32 @@ See all the available commands and their usage by running `furyctl help`.

<!-- line left blank as spacer -->

> Check [KFD Compatibility matrix](https://github.com/sighupio/fury-distribution/blob/main/docs/COMPATIBILITY_MATRIX.md) for the Furyctl / KFD versions to use.
> 💡 **TIP**
>
> You can follow the Kubernetes Fury Distribution quick start guides in KFD's official documentation site:
> <https://docs.kubernetesfury.com/docs/quickstart/quickstart>

<!-- line left blank as spacer -->

> Check [KFD Compatibility matrix](https://github.com/sighupio/fury-distribution/blob/main/docs/COMPATIBILITY_MATRIX.md) for the furyctl / KFD versions to use.

### Basic Usage

Basic usage of `furyctl` for a new project consists on the following steps:

1. Creating a configuration file defining the prequired infrastructure, Kubernetes cluster details, and KFD modules configuration.
1. Creating a configuration file defining the required infrastructure, Kubernetes cluster details, and KFD modules configuration.
2. Creating a cluster as defined in the configuration file.
3. Destroying the cluster and its related resources.

#### 1. Create a configuration file

`furyctl` provides a command that outputs a sample configuration file (by default called `furyctl.yaml`) with all the possible fields explained in comments.

Furyctl configuration files have a kind that specifies what type of cluster will be created, for example the `EKSCluster` kind has all the parameters needed to create a KFD cluster using the EKS managed clusters from AWS.
furyctl configuration files have a kind that specifies what type of cluster will be created, for example the `EKSCluster` kind has all the parameters needed to create a KFD cluster using the EKS managed clusters from AWS.

You can also use the `KFDDistribution` kind to install the KFD distribution on top of an existing Kubernetes cluster or `OnPremises` kind to install a KFD cluster on VMs.

Additionaly, the schema of the file is versioned with the `apiVersion` field, so when new features are introduced you can switch to a newer version of the configuration file structure.
Additionally, the schema of the file is versioned with the `apiVersion` field, so when new features are introduced you can switch to a newer version of the configuration file structure.

To scaffold a configuration file to use as a starter, you use the following command:

Expand All @@ -184,7 +178,7 @@ furyctl create config --version v1.29.1 --kind "EKSCluster"

Open the generated configuration file with your editor of choice and edit it according to your needs. You can follow the instructions included as comments in the file.

Once you have filled your configuration file, you can check that it's content is valid by running the following comand:
Once you have filled your configuration file, you can check that it's content is valid by running the following command:

```console
furyctl validate config --config /path/to/your/furyctl.yaml
Expand All @@ -201,9 +195,9 @@ Requirements (EKSCluster):
- AWS CLI
- OpenVPN (when filling the `vpn` field in the configuration file)

In the previous step, you have created and validated a configuration file that defines the Kubernetes cluster and its sorroundings, you can now proceed to actually creating the resources.
In the previous step, you have created and validated a configuration file that defines the Kubernetes cluster and its surroundings, you can now proceed to actually creating the resources.

Furyctl divides the cluster creation in four phases: `infrastructure`, `kubernetes`, `distribution` and `plugins`.
furyctl divides the cluster creation in four phases: `infrastructure`, `kubernetes`, `distribution` and `plugins`.

1. The first phase, `infrastructure`, creates all the prerequisites needed to be able to create a cluster. For example, the VPC and its networks.
2. The second phase, `kubernetes`, creates the actual Kubernetes clusters. For example, the EKS cluster and its node pools.
Expand All @@ -214,7 +208,7 @@ Furyctl divides the cluster creation in four phases: `infrastructure`, `kubernet
>
> You will find these four phases when editing the furyctl.yaml file.

Just like you can validate that your configuration file is well formed, `furyctl` let you check that you have all the needed dependencies (environment variables, binaries, etc.) before starting a cluster creation process.
Just like you can validate that your configuration file is well-formed, `furyctl` let you check that you have all the needed dependencies (environment variables, binaries, etc.) before starting a cluster creation process.

To validate that your system has all the dependencies needed to create the cluster defined in your configuration file, run the following command:

Expand All @@ -241,7 +235,7 @@ furyctl create cluster --config /path/to/your/furyctl.yaml
> 💡 **TIP**
>
> You can use the alias `furyctl apply` instead of `furyctl create cluster`.

<!-- spacer -->
> 📖 **NOTE**
>
> The creation process will take a while.
Expand All @@ -252,7 +246,7 @@ furyctl create cluster --config /path/to/your/furyctl.yaml

Upgrading a cluster is a process that can be divided into two steps: upgrading the fury version and running the migrations (if present).

The first step consist in bringing the cluster up to date with the latest version of the Kubernetes Fury Distribution. This is done by running the following command:
The first step consists in bringing the cluster up to date with the latest version of the Kubernetes Fury Distribution. This is done by running the following command:

```console
furyctl apply --upgrade --config /path/to/your/furyctl.yaml
Expand Down Expand Up @@ -342,6 +336,24 @@ The following steps will guide you through the process of creating a Kubernetes
4. Run `furyctl create cluster` to create the cluster.
5. (Optional) Watch the logs of the cluster creation process with `tail -f ~/.furyctl/furyctl.<timestamp>-<random>.log`.

#### Create the PKI for on-premises clusters

On-premises clusters need a set of certificates authorities and certificate files to work as a prerequisite. Both for the Kubernetes control plane and for the etcd database.

furyctl provides a command that allows the creation of this PKI:

```bash
furyctl create pki
```

The command supports some additional options, like `--etcd` to create only the PKI for etcd, or creating the files in a different path.

See all the additional options with the `--help` flag:

```bash
furyctl create pki --help
```

#### Create a cluster in an already existing infrastructure

Same as the previous section, but you can skip the infrastructure creation phase
Expand Down Expand Up @@ -378,9 +390,9 @@ to use the flag `--kubeconfig` in the following command.
furyctl create cluster --phase distribution
```

#### Legacy download
#### Legacy vendor download

The new furyctl still embed some of the legacy features, for example the command `furyctl legacy vendor` to download KFD dependencies from a deprecated `Furyfile.yml`.
The new furyctl still embeds some legacy features, for example the command `furyctl legacy vendor` to download KFD dependencies from a deprecated `Furyfile.yml`.

This can be still used to manually manage all the components of the distribution.

Expand All @@ -390,11 +402,14 @@ This can be still used to manually manage all the components of the distribution

#### Plugins

Furyctl supports Helm and Kustomize plugins.
furyctl supports Helm and Kustomize plugins.

##### Helm plugins

To install an Helm plugin (chart), first you have to add the repository to the `spec.plugins.helm.repositories` section of your `furyctl.yaml` file and then you can add the release to the `spec.plugins.helm.releases` section, specifying the chart name, the namespace, the chart version and the values to override. To override the values you can use the `spec.plugins.helm.releases[].set` or the `spec.plugins.helm.releases[].values` section.
To install a Helm plugin (chart), follow these steps:

1. Add the repository to the `spec.plugins.helm.repositories` section of your `furyctl.yaml` file.
2. Add the release to the `spec.plugins.helm.releases` section, specifying the chart name, the namespace, the chart version and the values to override. To override the values you can use the `spec.plugins.helm.releases[].set` or the `spec.plugins.helm.releases[].values` section.

For example to install the Prometheus Helm chart you have to add the following to your `furyctl.yaml`:

Expand Down Expand Up @@ -439,11 +454,11 @@ spec:

#### Using a custom distribution location

Furyctl comes with the flag `--distro-location`, allowing you to use a local copy of KFD instead of downloading it from the internet. This allows you to test changes to the KFD without having to push them to the repository, and might come in handy when you need to test new features or bugfixes.
furyctl comes with the flag `--distro-location`, allowing you to use a local copy of KFD instead of downloading it from the internet. This allows you to test changes to the KFD without having to push them to the repository, and might come in handy when you need to test new features or bug fixes.

#### Using a custom upgrade path location

On the same note, the tool comes with the `--upgrade-path-location` flag, too, allowing you to test changes to the upgrade path without having to push them to the repository, and to support cases that are not covered by the official release, such as upgrading from a beta or rc release to a stable one.
On the same note, the tool comes with the `--upgrade-path-location` flag, too, allowing you to test changes to the upgrade path without having to push them to the repository, and to support cases that are not covered by the official release, such as upgrading from a beta or release candidate release to a stable one.

#### Restarting the cluster creation or update process from a specific (sub-)phase

Expand All @@ -454,10 +469,10 @@ If, for any reason, the cluster creation or update process fails, you can restar

### Test classes

There are four kind of tests: unit, integration, e2e, and expensive.
There are four kinds of tests: unit, integration, e2e, and expensive.

Each of them covers specific use cases depending on the speed, cost, and dependencies at play in a given scenario.
Anything that uses i/o should be marked as integration, with the only expection of local files and folders: any test
Anything that uses i/o should be marked as integration, with the only expectation of local files and folders: any test
that uses the local filesystem and nothing more can be marked as 'unit'. This is made for convenience and it's open to
change in the future should we decide to refactor the code to better isolate that kind of i/o from the logic of the tool.

Expand Down
Loading