Skip to content

olkornii/intellij-kubernetes

 
 

Repository files navigation

JetBrains Marketplace Downloads Build Status License

Kubernetes

Overview

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.

editor push scenario

Key Features

  • 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

Features

Browse Kubernetes & OpenShift resources

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.

Current Context

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.

Current Namespace/Project

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.

Resource Categories

Resources are grouped in different categories such as Namespaces, Nodes, Workloads, Network, Storage, Configuration and Custom Resources.

img.png

Pods

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.

img.png

Pods also unveil their IP address and the number of running containers out of the total number of containers.

Create and Edit Resources

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.

editor

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.

editor schema

Push (Save) to Cluster

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.

editor toolbar push

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.

editor push

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.

Pull (Load) from Cluster

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.

editor pulled

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.

editor pull or push

Diff

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.

editor toolbar diff

The very same dialog may also be opened with a link that's present in the notification toolbar.

editor diff

Delete Resources

You may delete any resource that is listed in the resource tree by choosing "Delete" in the context menu.

Follow logs

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.

logs

Data and Telemetry

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

Release notes

See the change log.

Contributing

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.

Feedback & Questions

If you discover an issue please file a bug and we will fix it as soon as possible.

UI Testing

You can perform UI testing by running the following command:

./gradlew clean runIdeForUiTests -PideaVersion=IC-2020.2 & ./gradlew integrationTest

License

EPL 2.0, See LICENSE for more information.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Kotlin 94.1%
  • Java 5.7%
  • Other 0.2%