Skip to content

Commit

Permalink
design-proposal: Adjust virtiofs feature gates (#313)
Browse files Browse the repository at this point in the history
This design document explains how and why virtiofs feature gates should
be adjusted. The main purpose is to avoid mixing feature control and
configuration with feature enablement.

Signed-off-by: Javier Cano Cano <[email protected]>
  • Loading branch information
jcanocan authored Dec 11, 2024
1 parent 81ce772 commit 6710d75
Showing 1 changed file with 69 additions and 0 deletions.
69 changes: 69 additions & 0 deletions design-proposals/virtiofs-support/virtiofs-feature-gates.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
# Overview
Virtiofs allows sharing Secrets, ConfigMaps, ServiceAccounts and DownwardAPI (a.k.a., ConfigVolumes) in a dynamic way,
i.e., any change in those objects are reflected in the VirtualMachine (VM) without restarting the VM. Moreover, PVCs and/or
DVs may also be shared using virtiofs allowing multiple readers and writers in the shared PVCs and/ord DVs.

## Motivation
Currently, the usage of feature gates are mixed with the feature control. The feature gate `ExperimentalVirtiofsSupport`
controls whether virtiofsd runs as rootful container inside the launcher pod or not. There is no way to only run
virtiofs for use cases which doesn't require rootful virtiofsd or the other way around.

In order to GA virtiofs, VMs should be able to live migrate while sharing data with virtiofs. The virtiofsd’s live
migration support will distinguish between different use cases: sharing ConfigVolumes and PVCs/DVs.

In order to fully support sharing ConfigVolumes and PVCs/DVs while allowing live migration, deep changes are required in
KubeVirt, QEMU, libvirt and virtiofsd projects. However, those changes are complementary, i.e., the changes required to
support sharing ConfigVolumes while allowing a VM to live migrate are the needed and preliminary steps to support
sharing PVCs/DVs. Therefore, this distinction will create a staged and granular support giving users time to test the
ConfigVolumes sharing support and allowing the involved developers to get feedback before next steps to support sharing
PVCs/DVs.

## Goals
- Align virtiofs feature gates to just control the feature enablement.
- Deprecate current virtiofs feature gate.
- Protect the sharing functionalities: ConfigVolumes, PVCs and DVs, with feature gates.

## Non Goals
- Support live migration while sharing data with virtiofs.

## Definition of Users
Cluster administrators

## User Stories

As a cluster administrator, I want to allow VM owners to share ConfigVolumes in a dynamic way without running rootful
containers on the cluster. For this purpose, I need to enable the feature gate `EnableVirtioFsConfigVolumes`.

As a cluster administrator, I want to allow VM owners to share PVCs and/or DVs with one or multiple VMs while allowing users to
read and/or write on them without running rootful containers. For this purpose, I need to enable the feature gate
`EnableVirtioFsStorageVolumes`.

## Repos
Kubevirt/kubevirt

# Design
## KubeVirt Feature Gates
Two feature gates will be introduced as a means to granular support virtiofs functionalities:
- `EnableVirtioFsConfigVolumes` to allow sharing ConfigMaps, Secrets, DownwardAPI and ServiceAccount.
- `EnableVirtioFsStorageVolumes` to allow sharing PVCs and/or DVs.
The feature gates may start its path to GA once a VM will be able to live migrate while sharing data with virtiofs
without requiring rootful containers to work.
These feature gates will be removed once GA is reached.

## VM API
From the VM API point of view, everything should keep as it is.

## Update/Rollback Compatibility
As stated before, `ExperimentalVirtiofsSupport` will be marked as deprecated. However, in order to do not disrupt current
systems relying on the `ExperimentalVirtiofsSupport` feature gate, it will allow users to share ConfigVolumes and PVCs/DVs
until KubeVirt version 1.6. In versions equal or greater than 1.6, the feature gate
`ExperimentalVirtiofsSupport` will have no effect. Moreover, the use of the deprecated `ExperimentalVirtiofsSupport`
will trigger a warning advising the user to move to the new feature gates.

## Functional Testing Approach
Current functional tests will be adjusted to those new feature gates.

# Implementation Phases
- Drop usage of `ExperimentalVirtiofsSupport`
- Add the feature gate `EnableVirtioFsConfigVolumes`.
- Add the feature gate and `EnableVirtioFsStorageVolumes`.

0 comments on commit 6710d75

Please sign in to comment.