Support and Shared Responsibilities
Find out about some of the key responsibilities for both Oracle and users, along with technical support policies and limitations for Kubernetes Engine (OKE). Also find out about responsibilities for node management, managed control plane components, third-party open-source components, and security and patch management.
Running a business-critical application on Kubernetes Engine requires both you and Oracle to assume different but equally essential responsibilities. This non-exhaustive topic:
- Captures some of the key responsibilities for both you and Oracle.
- Describes technical support policies for, and limitations of, Kubernetes Engine.
- Details responsibilities for node management, managed control plane components, third-party open-source components, security, and patch management.
Oracle's Responsibilities for the Control Plane
Kubernetes Engine provides a fully-managed Kubernetes control plane, which consists of the necessary components for Kubernetes clusters. All components of the control plane are maintained and operated by Oracle. The service is 'managed' in the sense that Oracle deploys, operates, and is responsible for service availability and functionality.
Kubernetes Engine is certified as Kubernetes software conformant by the CNCF through the Certified Kubernetes Conformance Program. The Certified Kubernetes Conformance Program ensures that every vendor's version of Kubernetes supports the required APIs. For organizations using Kubernetes, conformance enables interoperability between one Kubernetes installation and another. When compared with the upstream Kubernetes project, Oracle limits customization to ensure a stable and consistent user experience.
As part of a fully-managed Kubernetes control plane, Kubernetes Engine manages and monitors the following components:
These components are fully managed by Oracle and exist in the Kubernetes Engine service tenancy. You cannot access the fully-managed components directly, and you can only modify them in ways supported by Kubernetes Engine public APIs.
Since Kubernetes Engine provides a managed Kubernetes control plane, Oracle performs automated etcd backup every 15 minutes. You cannot access these backups. However, if an event requiring disaster recovery occurs, Oracle uses these backups to restore clusters created byKubernetes Engine.
If you want to configure or directly access the Kubernetes control plane, consider using the Kubernetes Cluster API Provider for Oracle Cloud Infrastructure to deploy self-managed Kubernetes clusters.
Shared Responsibilities for the Control Plane
Oracle has responsibility for managing the Kubernetes control plane (including both the Kubernetes control plane components themselves, and the compute instances hosting these components).
However, upgrading the Kubernetes control plane is a task for which you and Oracle share responsibility.
Kubernetes Engine regularly releases updates to support new Kubernetes minor and patch versions, containing security or functionality improvements for the Kubernetes control plane components.
You are responsible for initiating the upgrade of the Kubernetes control plane components, using the provided user interfaces (such as the Console, API, and CLI). See Upgrading the Kubernetes Version on Control Plane Nodes in a Cluster.
Once you have initiated the upgrade of the Kubernetes control plane, Oracle has responsibility for actually performing the control plane upgrade.
Shared Responsibilities for the Data Plane
You and Oracle share responsibilities for the data plane components. The data plane components fall into two categories:
- Kubernetes Components that must run within the data plane for a cluster to function correctly.
- Worker Nodes that run the applications you deploy in a cluster.
Shared Responsibilities for Patching Security Issues
You and Oracle have a shared responsibility for patching security issues, as follows:
- If a security vulnerability is detected in one or more of the Kubernetes control plane components managed by Kubernetes Engine, it is Oracle's responsibility to patch all affected clusters to mitigate the issue.
- If a security vulnerability is detected in one or more of the Kubernetes data plane components, it is Oracle's responsibility to provide a patched image. It is your responsibility to update the Kubernetes data plane with this patched image.
Support Coverage
Areas covered by Oracle Support
Oracle provides support via My Oracle Support (MOS) for the following areas:
- Connectivity to the Kubernetes API server.
- Management, uptime, quality of service, and operations of all Kubernetes components that Kubernetes Engine provides and supports.
- Any integration points in the OCI cloud-controller-manager provider for Kubernetes. These integration points include integration with other OCI services (such as load balancers, persistent volumes, and networking).
- Issues related to networking (such as kube-proxy, CoreDNS, or other network access and functionality issues). Note that changes to the Kubernetes data plane components are not supported.
-
Failures associated with other OCI services that are outside Kubernetes Engine (for these cases, raise a MOS support ticket for the service that is failing). Examples include, but are not limited to:
- Block volumes failing to attach to a worker node.
- Load balancers dropping network packets.
- Configuration of OCI resources other than those used by Kubernetes Engine.
- Limits and Quota for services beyond Kubernetes Engine, such as compute, load balancers, and block volumes.
Areas not covered by Oracle Support
Oracle does not provide support for the following areas:
- Questions about how to use Kubernetes. For example, advice on how to create manifest files, how to deploy images, how to structure applications for Kubernetes.
- Third-party open-source projects that are not provided as part of the Kubernetes control plane, or not deployed with clusters created by Kubernetes Engine. These projects might include Istio, Helm, Envoy, and others. If Oracle provides documentation on how to install such a project, Oracle will provide best effort support.
- Third-party closed-source software. This software can include security scanning tools and networking devices or software.
- Versions of Kubernetes beyond those listed in Supported Versions of Kubernetes. If you request support for a cluster running an unsupported version of Kubernetes, you will be asked to upgrade the cluster to a supported version of Kubernetes. To learn more about which versions of Kubernetes are currently supported, refer to Supported Versions of Kubernetes.
- Upstream Kubernetes bugs.
- Kubernetes Alpha features.
Responsibility Matrix
The following matrix summarizes how responsibilities are shared between you and Oracle.
Area | Oracle's Responsibility | Your Responsibility |
---|---|---|
Kubernetes Engine Service (API) |
Responsibility: Total Oracle is solely responsible for the management of the Kubernetes Engine service. |
Responsibility: None |
Kubernetes Control Plane |
Responsibility: Total Oracle is solely responsible for the management of:
|
Responsibility: None |
Kubernetes Data Plane |
Responsibility: Shared Oracle is responsible for deploying Kubernetes data plane components and add-on software (for example, kubelet, kube-proxy, flannel). |
Responsibility: Shared
|
Worker Nodes |
Responsibility: Shared Oracle is responsible for:
|
Responsibility: Shared You are responsible for:
|
Kubernetes Version |
Responsibility: Shared Oracle is responsible for:
|
Responsibility: Shared You are responsible for:
|
Cluster Observability |
Responsibility: Shared Oracle is responsible for providing:
|
Responsibility: Shared You are responsible for monitoring the health of worker nodes using the cluster observability features provided by Oracle. |
Backups |
Responsibility: Shared Oracle is responsible for performing an automated etcd backup every 15 minutes. |
Responsibility: Shared You are responsible for backups required by the application. |
Disaster Recovery |
Responsibility: Shared If an event requiring disaster recovery occurs, Oracle is responsible for restoring the cluster from the etcd backups. |
Responsibility: Shared You are responsible for restoring data from backups created by the application. |
Cluster Networking |
Responsibility: None |
Responsibility: Total You are solely responsible for:
|
Application Networking |
Responsibility: None |
Responsibility: Total You are solely responsible for setting up application networking capabilities (for example, load balancers, ingress controllers, and network policies). |
Application Observability |
Responsibility: None |
Responsibility: Total You are solely responsible for setting up and managing container logs (seeViewing Application Logs on Managed Nodes and Self-Managed Nodes) and metrics. |
Application Health and Performance |
Responsibility: None |
Responsibility: Total You are solely responsible for monitoring the health and performance of applications running on clusters. |
Application Security |
Responsibility: None |
Responsibility: Total You are solely responsible for application security. |
Application |
Responsibility: None |
Responsibility: Total You are solely responsible for workloads running within a cluster. This responsibility covers both software you have written and software written by the open source community. |