JetBrains IDEA plugin that allows to browse, create, modify and delete resources on Kubernetes or OpenShift clusters. The plugin provides functionalities and user experiences that are very close to the Kubernetes extension for Visual Studio Code.
It is available for install from the JetBrains Marketplace.
- Edit Kubernetes resource manifests and apply them to your cluster
- View Kubernetes and OpenShift clusters in an explorer tree view
- Tree View supports dynamic update of K8s resources
- Allow Push and Pull Feature to keep the editor in sync with the Kubernetes resource
- Support Creation and Deletion of new Kubernetes resources on Cluster
- Navigate into Kubernetes workloads, services, pods and nodes
- Switching contexts and namespaces within Kubernetes
- Follow logs from the connected cluster resource
This plugin allows the user to view the Kubernetes and OpenShift Cluster resources in a Tree and browse through them. The explorer tree is dynamically updated in sync with the Kubernetes resources on the cluster so that the tree always display the current state of the resources.
The user can switch the current context by choosing any context that exists and selecting Set as Current Cluster
action from the context menu.
OpenShift clusters are shown with OpenShift icon and thus differentiated from Kubernetes clusters.
Kubernetes Resources that exist within the current Namespace/Project (as specified in kubeconfig file) are displayed in the tree view.
Non-namespaced aka cluster-scoped resources are of course listed, too.
Users can switch the current Namespace/Project using the context menu action Use Namespace
In OpenShift clusters the tree also lists projects where the tooling behaves in an equivalent manner.
Resources are grouped in different categories such as Namespaces, Nodes, Workloads, Network, Storage, Configuration and Custom Resources.
The pod in the container is identified with color based on the state of the pod.
- A green dot indicates that the pod is currently running.
- A red dot indicates that the pod is in Pending, Succeeded (Terminated), Failed or in Unknown State.
Pods also unveil their IP address and the number of running containers out of the total number of containers.
You can edit Kubernetes resources that is shown in the resource tree and apply them to the cluster.
The action can be performed either by Double Click on Resource
or selecting Edit
action from the context menu.
This opens the resource YAML file in the editor and allows the user to make the necessary changes.
Pushing the editor to the cluster updates the resource on the cluster or creates a new resource if it didn't exist yet.
Users can also create a new Kubernetes resource from local YAML/JSON file.
The editor validates your content on behalf of a schema that's matching your kubernetes resource. For instance if you're editing a pod, the editor validates it by a kubernetes pod schema and highlights the portions that are infringing.
User can push the local changes made to the cluster in order to update an existing resource or create a new resource.
The editor is saving the changes to the current context (cluster, namespace and user) that's defined in the kubeconfig.
There is a Push
button available in the editor toolbar to make the action more discoverable.
Alternatively the editor notifies you whenever you may push your content to the cluster. Clicking the "Push" link in the editor notification saves your editor to the cluster.
Pushing updates the resource on the cluster or creates a new resource if it doesn't exist yet. The new resource will then appear in the resource tree that's displayed in our tool window.
The editor also notifies you if your resource has changed on the cluster.
The notification informs you of a newer version that is available on the cluster and allows you to Pull
it into your editor.
Competing changes in your editor and on the cluster get notified with 2 options: You can either overwrite the cluster by pushing the editor to the cluster. Alternatively you can replace your local version with the one on the cluster and pull it.
The editor allows you to compare the local content with the resource content on the cluster. The toolbar holds an action that opens up a fully editable diff that highlights the differences.
The very same dialog may also be opened with a link that's present in the notification toolbar.
You may delete any resource that is listed in the resource tree by choosing "Delete" in the context menu.
IntelliJ-Kubernetes extension allows you to follow logs of the cluster resources such as Pods, Jobs and Builds. There is a dedicated tab to display the log messages for the selected Kubernetes resource.
The JetBrains IntelliJ Kubernetes plugin collects anonymous usage data and sends it to Red Hat servers to help improve our products and services. Read our privacy statement to learn more. This extension respects the Red Hat Telemetry setting which you can learn more about at https://github.com/redhat-developer/intellij-redhat-telemetry#telemetry-reporting
See the change log.
This is an open source project open to anyone. This project welcomes contributions and suggestions!
For information on getting started, refer to the CONTRIBUTING instructions.
If you discover an issue please file a bug and we will fix it as soon as possible.
- File a bug in GitHub Issues.
- Open a Discussion on GitHub.
You can perform UI testing by running the following command:
./gradlew clean runIdeForUiTests -PideaVersion=IC-2020.2 & ./gradlew integrationTest
EPL 2.0, See LICENSE for more information.