community/sig-node/annual-report-2023.md

122 lines
8.2 KiB
Markdown

# 2023 Annual Report: SIG Node
## Current initiatives and Project Health
1. What work did the SIG do this year that should be highlighted?
As accelerator workloads importance grows, SIG Node **doubled down on DRA**
related work. There were a few changes proposed and many improvements started in
2023 will be continued in 2024.
SIG Node started many alpha-level features in 2023. Specifically, **SIG Node
green-lit two major features that touch Pod Lifecycle** that used to be hard to
change in the past. InPlace pod update is still in alpha. Sidecar containers
reached beta stage and were enabled by default in 1.29. Note that sidecar
containers' importance is also partially driven by AI/ML training workloads that
highly depend on reliable sidecar containers support in Kubernetes.
Group is also continuing the effort of **eliminating perma-betas**. A few old beta
features were GA-d and there are plans to continue this effort in 2024.
2. Are there any areas and/or subprojects that your group needs help with (e.g. fewer than 2 active OWNERS)?
SIG Node delivers the highest number of KEPs in many releases despite the fact
that SIG Node is heavily bottlenecked on the number of approvers. Approvers are
overloaded, which creates community tension around KEPs which cannot get enough
attention. This is true for global approvers, as well as subprojects like NPD.
SIG Node codebase is hard to split into individual components, which makes the
growing of new approvers harder.
Even with the push for perma beta elimination, SIG Node still has many features
that are heavily used in production, but still marked as beta. Most of the time,
the work needed is not challenging or complicated, but requires a lot of effort.
Help in this area will be very appreciated.
3. Did you have community-wide updates in 2023 (e.g. KubeCon talks)?
- KubeCon EU 2023 [maintainers track](https://kccnceu2023.sched.com/event/1HyU4/kubernetes-sig-node-intro-and-deep-dive-sergey-kanzhelev-dawn-chen-google-derek-carr-mrunal-patel-red-hat)
- KubeCon China 2023 [maintainers track](https://kccncosschn2023.sched.com/event/1PTJk/kubernetes-sigze-tao-recheng-kubernetes-sig-node-intro-and-deep-dive-paco-xu-daocloud-xiongxiong-yuan-gitlab-china)
- KubeCon NA 2023 [maintainers track](https://kccncna2023.sched.com/event/1R2qd/kubernetes-sig-node-intro-and-deep-dive-sergey-kanzhelev-google-mrunal-patel-red-hat)
4. KEP work in 2023 (v1.27, v1.28, v1.29):
- Alpha
- [1287 - In-place Update of Pod Resources](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/1287-in-place-update-pod-resources) - v1.27
- [2371 - cAdvisor-less, CRI-full Container and Pod Stats](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/2371-cri-pod-container-stats) - v1.29
- [2570 - Memory QoS](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/2570-memory-qos) - v1.27
- [3673 - KEP Template](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3673-kubelet-parallel-image-pull-limit) - v1.27
- [3695 - Extend the PodResources API to include resources allocated by DRA](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3695-pod-resources-for-dra) - v1.27
- [3960 - Pod lifecycle sleep action](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3960-pod-lifecycle-sleep-action) - v1.29
- [3983 - Add support for a kubelet drop-in configuration directory](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3983-drop-in-configuration) - v1.28
- [4033 - Discover cgroup driver from CRI](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/4033-group-driver-detection-over-cri) - v1.28
- [4191 - Splitting the Image Filesystem](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/4191-split-image-filesystem) - v1.29
- [4210 - ImageMaximumGCAge in Kubelet](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/4210-max-image-gc-age) - v1.29
- [4216 - Image pull per runtime class](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/4216-image-pull-per-runtime-class) - v1.29
- Beta
- [1029 - Quotas for Ephemeral Storage](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/1029-ephemeral-storage-quotas) - 1.29
- [3085 - Pod networking ready condition](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3085-pod-conditions-for-starting-completition-of-sandbox-creation) - v1.29
- [3386 - Kubelet Evented PLEG for Better Performance](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3386-kubelet-evented-pleg) - v1.27
- [3545 - Improved multi-numa alignment in Topology Manager](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3545-improved-multi-numa-alignment) - v1.28
- [4009 - Add CDI devices to device plugin API](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/4009-add-cdi-devices-to-device-plugin-api) - v1.29
- [753 - Sidecar Containers](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/753-sidecar-containers) - v1.29
- Stable
- [2053 - Downward API HugePages](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/2053-downward-api-hugepages) - v1.27
- [2238 - Liveness Probe Grace Period](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/2238-liveness-probe-grace-period) - v1.28
- [2403 - Extend kubelet pod resource assignment endpoint to return allocatable resources](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/2403-pod-resources-allocatable-resources) - v1.28
- [2413 - Seccomp by default](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/2413-seccomp-by-default) - v1.27
- [2727 - Add gRPC probe to Pod.Spec.Container.{Liveness,Readiness,Startup}Probe](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/2727-grpc-probe) - v1.27
- [3288 - Split Stdout and Stderr Log Stream of Container](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3288-separate-stdout-from-stderr) - v1.27
- [3327 - CPUManager policy option to align CPUs by Socket instead of by NUMA node](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/3327-align-by-socket) - v1.28
- [606 - Kubelet endpoint for device assignment observation details](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/606-compute-device-assignment) - v1.28
- [693 - Node Topology Manager](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/693-topology-manager) - v1.27
- [727 - Kubelet Resource Metrics Endpoint](https://github.com/kubernetes/enhancements/tree/master/keps/sig-node/727-resource-metrics-endpoint) - v1.29
## [Subprojects](https://git.k8s.io/community/sig-node#subprojects)
**New in 2023:**
- [resource-management](https://git.k8s.io/community/sig-node#resource-management)
**Retired in 2023:**
- noderesourcetopology-api
**Continuing:**
- ci-testing
- cri-api
- cri-tools
- kernel-module-management
- kubelet
- node-api
- node-feature-discovery
- node-problem-detector
- security-profiles-operator
## [Working groups](https://git.k8s.io/community/sig-node#working-groups)
**Retired in 2023:**
- Multitenancy
**Continuing:**
- Batch
- Policy
- Structured Logging
## Operational
Operational tasks in [sig-governance.md]:
- [X] [README.md] reviewed for accuracy and updated if needed
- [X] [CONTRIBUTING.md] reviewed for accuracy and updated if needed
- [X] Other contributing docs (e.g. in devel dir or contributor guide) reviewed for accuracy and updated if needed
- [X] Subprojects list and linked OWNERS files in [sigs.yaml] reviewed for accuracy and updated if needed
- [X] SIG leaders (chairs, tech leads, and subproject leads) in [sigs.yaml] are accurate and active, and updated if needed
- [X] Meeting notes and recordings for 2023 are linked from [README.md] and updated/uploaded if needed
[CONTRIBUTING.md]: https://git.k8s.io/community/sig-node/CONTRIBUTING.md
[sig-governance.md]: https://git.k8s.io/community/committee-steering/governance/sig-governance.md
[README.md]: https://git.k8s.io/community/sig-node/README.md
[sigs.yaml]: https://git.k8s.io/community/sigs.yaml
[devel]: https://git.k8s.io/community/contributors/devel/README.md