4.4 KiB
kep-number | title | authors | owning-sig | participating-sigs | reviewers | approvers | editor | creation-date | last-updated | status | see-also | replaces | superseded-by | |||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
28 | Optional Service Environment Variables |
|
sig-apps |
|
|
TBD | 2018-09-25 | 2018-09-25 | provisional |
|
Optional Service Environment Variables
Table of Contents
Summary
This enhancement allows application developers to choose whether their Pods will receive environment variables from services in their namespace. They can choose to disable them via the new enableServiceLinks
field in PodSpec
. The current behaviour will continue to be the default behaviour, but the developer may choose to disable these environment variables for certain workloads for reasons such as incompatibilities with other expected environment variables or scalability issues.
Motivation
Today, a list of all services that were running when a pod's containers are created is automatically injected to those containers as environment variables matching the syntax of Docker links. There is no way to disable this.
Docker links have long been considered as a deprecated legacy feature of Docker since the introduction of networks and DNS. Likewise, in Kubernetes, DNS is to be preferred over service links.
Possible issues with injected service links are:
- Accidental coupling.
- Incompatibilities with container images that no longer utilize service links and explicitly fail at startup time if certain service links are defined.
- Performance penalty in starting up pods for namespaces with many services
Goals
- Allow users to choose whether to inject service environment variables in their Pods.
- Do this in a backwards-compatible, non-breaking way. Default to the current behaviour.
Non-Goals
N/A
Proposal
User Stories
- As an application developer, I want to be able to disable service link injection since the injected environment variables interfere with a Docker image that I am trying to run on Kubernetes.
- As an application developer, I want to be able to disable service link injection since I don't need it and it takes increasingly longer time to start pods as services are added to the namespace.
- As an application developer, I want to be able to disable service link injection since pods can fail to start if the environment variable list becomes too long. This can happen when there are >5,000 services in the same namespace.
Implementation Details/Notes/Constraints
PodSpec
is extended with an additional field, enableServiceLinks
. The field should be a pointer to a boolean and default to true if nil.
In kubelet_pods.go
, the value of that field is passed along to the function getServiceEnvVarMap
where it is used to decide which services will be propogated into environment variables. In case enableServiceLinks
is false then only the kubernetes
service in the kl.masterServiceNamespace
should be injected. The latter is needed in order to preserve Kubernetes variables such as KUBERNETES_SERVICE_HOST
since a lot of code depends on it.
Risks and Mitigations
The current behaviour is being kept as the default as much existing code and documentation depends on these environment variables.
Graduation Criteria
N/A