community/contributors/devel
David Eads c18b45800e add acceptable justifications for updating a godep 2018-11-09 12:08:09 -05:00
..
gubernator-images imported docs/devel as a subtree 2016-11-30 14:43:43 -05:00
OWNERS Add thockin and lavalamp to devel OWNERS 2018-11-02 12:42:02 -07:00
README.md Adding Conformance Guidelines document. 2018-07-20 13:01:25 -07:00
adding-an-APIGroup.md removed autogenerated munge analytics from files 2017-11-03 16:55:51 -07:00
api-conventions.md Document conditions vs fields (#2350) 2018-10-18 09:54:52 -07:00
api_changes.md Document pluralization of API fields 2018-10-23 12:14:14 -07:00
arch-roadmap-1.png Added architectural layers diagram, placeholder for Summary section. 2017-11-16 16:46:04 -08:00
architectural-roadmap.md Fix blog links after migration from blog.kubernetes.io to kubernetes.io/blog 2018-10-22 15:01:25 -07:00
automation.md Fix typos: creats -> creates (#2899) 2018-11-05 09:46:47 -08:00
bazel.md Update bazel documentation with current known issues and limitations 2018-11-07 16:52:06 -08:00
cherry-picks.md Updates and clarifies cherrypick process 2018-10-17 12:34:54 -07:00
client-libraries.md update link to Kubernetes client libraries overview page 2018-06-26 22:11:40 -05:00
collab.md removed unnecessary link from guide README, also removed duplicate text from linked file 2018-01-16 13:33:18 -08:00
component-config-conventions.md Fix various spelling mistakes 2018-03-04 14:46:53 -08:00
conformance-tests.md Address review comments 2018-10-08 15:15:53 -07:00
container-runtime-interface.md Fix blog links after migration from blog.kubernetes.io to kubernetes.io/blog 2018-10-22 15:01:25 -07:00
controllers.md fix a typo in contributors/devel/controllers.md 2018-07-06 23:30:18 -07:00
cri-container-stats.md Use git.k8s.io for links 2017-12-21 18:34:08 -08:00
cri-testing-policy.md Update links of cri-tools 2018-09-07 10:47:41 +08:00
cri-validation.md Update links of cri-tools 2018-09-07 10:47:41 +08:00
development.md Add rsync as development dependency 2018-10-13 08:41:06 +02:00
e2e-node-tests.md Use git.k8s.io for links 2017-12-21 18:34:08 -08:00
e2e-tests.md Adding note about new directories with tests 2018-11-01 13:44:32 -07:00
event-style-guide.md Add Event style guide for Events v2 2018-01-23 11:35:32 +00:00
flaky-tests.md Replace submit queue with Tide in docs 2018-10-06 23:08:24 +05:30
flexvolume.md Flexvolume example updates, and miscellaneous documentation fixes. 2018-08-08 15:00:29 -07:00
generating-clientset.md Update generating-clientset.md 2018-07-19 22:47:48 +08:00
getting-builds.md removed autogenerated munge analytics from files 2017-11-03 16:55:51 -07:00
godep.md add acceptable justifications for updating a godep 2018-11-09 12:08:09 -05:00
gubernator.md Change k8s-merge-robot to k8s-ci-robot 2018-03-15 06:48:54 +08:00
help-wanted.md Fix markdown formatting in help wanted 2018-06-10 15:49:32 -05:00
how-to-doc.md Fix italic style 2018-01-08 17:02:37 +03:00
instrumentation.md removed autogenerated munge analytics from files 2017-11-03 16:55:51 -07:00
issues.md Fix a broken link for a file moved to guide from devel 2018-02-15 12:03:18 -05:00
kubectl-conventions.md Use git.k8s.io for links 2017-12-21 18:34:08 -08:00
kubelet-cri-networking.md remove UNVERSIONED_WARNING (#382) 2017-02-17 14:50:10 -06:00
kubemark-guide.md doc: fix some typo 2018-02-04 22:41:56 +08:00
logging.md Add Trace level logging 2018-11-02 04:59:08 +00:00
mesos-style.md removed autogenerated munge analytics from files 2017-11-03 16:55:51 -07:00
node-performance-testing.md Use git.k8s.io for links 2017-12-21 18:34:08 -08:00
on-call-federation-build-cop.md fix test grid config link 2018-10-28 17:29:34 -07:00
profiling.md Add tips for profiling tests 2018-01-02 17:18:08 -08:00
release-cycle.png devel guide: pull in issue doc from sig-release/ephemera 2018-08-30 17:35:05 -07:00
release-lifecycle.png devel guide: pull in issue doc from sig-release/ephemera 2018-08-30 17:35:05 -07:00
release.md link fix 2018-10-24 17:30:51 +02:00
running-locally.md removed autogenerated munge analytics from files 2017-11-03 16:55:51 -07:00
scheduler.md Link to new target 2018-05-07 10:25:53 +08:00
scheduler_algorithm.md typo in scheduler alg doc 2018-04-10 10:32:30 -04:00
staging.md doc: fix some typo 2018-02-04 22:41:56 +08:00
strategic-merge-patch.md smp: OpenAPI annotations are now allowed 2017-12-26 16:04:31 +05:30
testing.md syntax fix for testing doc 2018-08-21 18:11:01 -04:00
update-release-docs.md update urls 2018-07-05 08:30:02 -07:00
updating-docs-for-feature-changes.md update urls 2018-07-05 08:30:02 -07:00
vagrant.md Use git.k8s.io for links 2017-12-21 18:34:08 -08:00
welcome-to-kubernetes-new-developer-guide.md Correct the URL 2017-12-14 15:44:42 -05:00
writing-a-getting-started-guide.md Fix wrong link 2018-09-22 02:53:56 -04:00
writing-good-e2e-tests.md Remove duplication (#2898) 2018-11-05 09:42:13 -08:00

README.md

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

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): Glog 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 (how-to-doc.md) 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.md): 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.