8.3 KiB
		
	
	
	
	
	
			
		
		
	
	Table of Contents
The developer guide is for anyone wanting to either write code which directly accesses the Kubernetes API, or to contribute directly to the Kubernetes project. It assumes some familiarity with concepts in the User Guide and the Cluster Admin Guide.
The process of developing and contributing code to the Kubernetes project
- 
Contributor Guide (Please start here) to learn about how to contribute to Kubernetes 
- 
GitHub Issues (/contributors/guide/issue-triage.md): How incoming issues are triaged. 
- 
Pull Request Process (/contributors/guide/pull-requests.md): When and why pull requests are closed. 
- 
Getting Recent Builds (getting-builds.md): How to get recent builds including the latest builds that pass CI. 
- 
Automated Tools (automation.md): Descriptions of the automation that is running on our github repository. 
Setting up your dev environment, coding, and debugging
- 
Development Guide (development.md): Setting up your development environment. 
- 
Testing (testing.md): How to run unit, integration, and end-to-end tests in your development sandbox. 
- 
Conformance Testing (conformance-tests.md) What is conformance testing and how to create/manage them. 
- 
Hunting flaky tests (flaky-tests.md): We have a goal of 99.9% flake free tests. Here's how to run your tests many times. 
- 
Logging Conventions (logging.md): klog levels. 
- 
Profiling Kubernetes (profiling.md): How to plug in go pprof profiler to Kubernetes. 
- 
Instrumenting Kubernetes with a new metric (instrumentation.md): How to add a new metrics to the Kubernetes code base. 
- 
Coding Conventions (coding-conventions.md): Coding style advice for contributors. 
- 
Document Conventions (The Kubernetes documentation) Document style advice for contributors. 
- 
Running a cluster locally (running-locally.md): A fast and lightweight local cluster deployment for development. 
Developing against the Kubernetes API
- 
The REST API documentation explains the REST API exposed by apiserver. 
- 
Annotations (Annotations): are for attaching arbitrary non-identifying metadata to objects. Programs that automate Kubernetes objects may use annotations to store small amounts of their state. 
- 
API Conventions (api-conventions.md): Defining the verbs and resources used in the Kubernetes API. 
- 
API Client Libraries (Client Libraries): A list of existing client libraries, both supported and user-contributed. 
Writing plugins
- 
Authentication (Authentication): The current and planned states of authentication tokens. 
- 
Authorization Plugins (Authorization): Authorization applies to all HTTP requests on the main apiserver port. This doc explains the available authorization implementations. 
- 
Admission Control Plugins (admission_control) 
Building releases
See the kubernetes/release repository for details on creating releases and related tools and helper scripts.
SIG Developer Guide Contributions
SIG Release
- 
Cherry Picks cherry-picks.md How cherry picks are managed on release branches within the kubernetes/kubernetesrepository.
- 
Getting Kubernetes Builds getting-builds.md 
- 
Targeting enhancements, Issues and PRs to Release Milestones release.md 
SIG Instrumentation
- 
Logging Conventions logging.md 
- 
Event style guide event-style-guide.md 
- 
Instrumenting Kubernetes instrumentation.md 
- 
Structured Logging migration instructions migration-to-structured-logging.md 
SIG Storage
- Flexvolume flexvolume.md Flexvolume enables users to write their own drivers and add support for their volumes in Kubernetes.
SIG Scalability
- 
Kubemark User Guide kubemark-guide.md 
- 
How to Set Up a Kubemark Cluster kubemark-setup-guide.md 
- 
Profiling Kubernetes profiling.md 
SIG Scheduling
- 
Understanding the Kubernetes Scheduler scheduler.md 
- 
Scheduler Algorithm in Kubernetes scheduler_algorithm.md 
- 
Scheduler Benchmarking scheduler_benchmarking.md 
SIG Architecture
- 
API Conventions api-conventions.md 
- 
Component Configuration Conventions component-config-conventions.md 
- 
Changing the API api_changes.md 
- 
Staging Directory and Publishing staging.md 
- 
Using Go Modules to Manage Dependencies vendor.md This document only applies to Kubernetes development after 1.14.x. See previous godep documentation for working with dependencies for Kubernetes 1.14.x and earlier. 
- 
Using Go Modules to Manage Dependencies (for Kubernetes 1.14.x and earlier) godep.md See current documentation for working with dependencies for master branch development. 
SIG Architecture
- Conformance Testing in Kubernetes conformance-tests.md
SIG API Machinery
- Strategic Merge Patch strategic-merge-patch.md
- Writing Controllers controllers.md
- Generation and release cycle of clientset generating-clientset.md
SIG Testing
- 
Testing guide testing.md 
- 
Writing good e2e tests for Kubernetes writing-good-e2e-tests.md 
- 
Writing Good Conformance Tests for Kubernetes writing-good-conformance-tests.md 
- 
Integration Testing in Kubernetes integration-tests.md 
- 
End-to-End Testing in Kubernetes e2e-tests.md 
- 
Debugging with Gubernator gubernator.md 
- 
Flaky tests flaky-tests.md 
- 
Build and test with Bazel bazel.md 
SIG Node
- 
CRI: the Container Runtime Interface container-runtime-interface.md 
- 
Container Runtime Interface (CRI) Networking Specifications kubelet-cri-networking.md 
- 
Measuring Node Performance node-performance-testing.md 
- 
Container Runtime Interface: Container Metrics cri-container-stats.md 
- 
Container Runtime Interface (CRI) Validation Testing cri-validation.md 
- 
Node End-To-End tests e2e-node-tests.md 
- 
Container Runtime Interface: Testing Policy cri-testing-policy.md 
SIG CLI
- Kubectl Conventions kubectl-conventions.md