The Kubernetes project leverages multiple GitHub organizations to store and organize code. This guide contains the details on how to run those organizations for CNCF compliance and for the guidelines of the community.
Kubernetes managed organizations should be in the form of kubernetes-[thing]
.
For example, kubernetes-client where the
API clients are housed.
Prior to creating an organization please contact the steering committee for direction and approval.
Note: The CNCF, as part of the Linux Foundation, holds the trademark on the Kubernetes name. All GitHub organizations with Kubernetes in the name should be managed by the Kubernetes project or use a different name.
Due to licensing and CLA issues, prior to transferring software into a Kubernetes managed organization there is some due diligence that needs to occur. Please contact the steering committee and CNCF prior to moving any code in.
It is easier to start new code in a Kubernetes organization than it is to transfer in existing code.
The following organizations are currently known to be part of the Kubernetes project:
- kubernetes
- kubernetes-client
- kubernetes-csi
- kubernetes-incubator
- kubernetes-retired
- kubernetes-security
- kubernetes-sig-testing
- kubernetes-sigs
- kubernetes-addons
- kubernetes-charts
- kubernetes-extensions
- kubernetes-federation
- kubernetes-graveyard †
- kubernetes-incubator-retired
- kubernetes-providers
- kubernetes-sidecars
- kubernetes-test
- kubernetes-tools
† kubernetes-retired should be used instead of kubernetes-graveyard going forward.
Note, this list is subject to change.
There are more organization names that we are squatting on with possible future intentions. For more details please see community issue #1407.
Each organization should have the following teams:
- teams for each repo
foo
foo-admins
: granted admin access to thefoo
repofoo-maintainers
: granted write access to thefoo
repofoo-reviewers
: granted read access to thefoo
repo; intended to be used as a notification mechanism for interested/active contributors for thefoo
repo
- a
bots
team- should contain bots such as @k8s-ci-robot and @thelinuxfoundation that are necessary for org and repo automation
- an
owners
team- should be populated by everyone who has
owner
privileges to the org - gives users the opportunity to ping owners as a group rather than having to search for individuals
- should be populated by everyone who has
NB: Not all organizations in use today currently follow this team guidance. We are looking to coalesce existing teams towards this model, and use this model for all orgs going forward. Notable discrepancies at the moment:
foo-reviewers
teams are considered a historical subset ofkubernetes-sig-foo-pr-reviews
teams and are intended mostly as a fallback notification mechanism when requested reviewers are being unresponsive. Ideally OWNERS files can be used in lieu of these teams.admins-foo
andmaintainers-foo
teams as used by the kubernetes-incubator org. This was a mistake that swapped the usual convention, and we would like to rename the team
Repositories have additional guidelines and requirements, such as the use of CLA checking on all contributions. For more details on those please see the Kubernetes Template Project.