Processes kubectl outputs to enable vim-like navigation in a buffer for your cluster.
Navigate your cluster in a buffer, using hierarchy where possible (backspace for up, enter for down) e.g. root -> deplyoment -> pod -> container
Exec into containers
In the pod view, select a pod by pressing<cr>
and then again <cr>
on the container you want to exec into
Aliases (fallback view)
A fallback view that directs custom resources and has basic functionality such desc, edit, del- kubectl
- curl
- neovim >= 0.10
Install the plugin with your preferred package manager:
return {
{
"ramilito/kubectl.nvim",
config = function()
require("kubectl").setup()
end,
},
}
We expose open, close and toggle to bind against:
vim.keymap.set("n", "<leader>k", '<cmd>lua require("kubectl").toggle()<cr>', { noremap = true, silent = true })
You can override the plugin's keymaps using the <Plug>
mappings:
Default Mappings
-- default mappings
local group = vim.api.nvim_create_augroup("kubectl_mappings", { clear = true })
vim.api.nvim_create_autocmd("FileType", {
group = group,
pattern = "k8s_*",
callback = function(ev)
local k = vim.keymap.set
local opts = { buffer = ev.buf }
-- Global
k("n", "g?", "<Plug>(kubectl.help)", opts) -- Help float
k("n", "gr", "<Plug>(kubectl.refresh)", opts) -- Refresh view
k("n", "gs", "<Plug>(kubectl.sort)", opts) -- Sort by column
k("n", "gD", "<Plug>(kubectl.delete)", opts) -- Delete resource
k("n", "gd", "<Plug>(kubectl.describe)", opts) -- Describe resource
k("n", "gy", "<Plug>(kubectl.yaml)", opts) -- View yaml
k("n", "ge", "<Plug>(kubectl.edit)", opts) -- Edit resource
k("n", "<C-l>", "<Plug>(kubectl.filter_label)", opts) -- Filter labels
k("n", "<BS>", "<Plug>(kubectl.go_up)", opts) -- Go back to previous view
k("v", "<C-f>", "<Plug>(kubectl.filter_term)", opts) -- Filter selected text
k("n", "<CR>", "<Plug>(kubectl.select)", opts) -- Resource select action (different on each view)
k("n", "<Tab>", "<Plug>(kubectl.tab)", opts) -- Tab completion (ascending, when applicable)
k("n", "<S-Tab>", "<Plug>(kubectl.shift_tab)", opts) -- Tab completion (descending, when applicable)
k("n", "", "<Plug>(kubectl.quit)", opts) -- Close view (when applicable)
k("n", "gk", "<Plug>(kubectl.kill)", opts) -- Pod/portforward kill
k("n", "<M-h>", "<Plug>(kubectl.toggle_headers)", opts) -- Toggle headers
-- Views
k("n", "<C-a>", "<Plug>(kubectl.alias_view)", opts) -- Aliases view
k("n", "<C-x>", "<Plug>(kubectl.contexts_view)", opts) -- Contexts view
k("n", "<C-f>", "<Plug>(kubectl.filter_view)", opts) -- Filter view
k("n", "<C-n>", "<Plug>(kubectl.namespace_view)", opts) -- Namespaces view
k("n", "gP", "<Plug>(kubectl.portforwards_view)", opts) -- Portforwards view
k("n", "1", "<Plug>(kubectl.view_deployments)", opts) -- Deployments view
k("n", "2", "<Plug>(kubectl.view_pods)", opts) -- Pods view
k("n", "3", "<Plug>(kubectl.view_configmaps)", opts) -- ConfigMaps view
k("n", "4", "<Plug>(kubectl.view_secrets)", opts) -- Secrets view
k("n", "5", "<Plug>(kubectl.view_services)", opts) -- Services view
k("n", "6", "<Plug>(kubectl.view_ingresses)", opts) -- Ingresses view
k("n", "", "<Plug>(kubectl.view_api_resources)", opts) -- API-Resources view
k("n", "", "<Plug>(kubectl.view_clusterrolebinding)", opts) -- ClusterRoleBindings view
k("n", "", "<Plug>(kubectl.view_crds)", opts) -- CRDs view
k("n", "", "<Plug>(kubectl.view_cronjobs)", opts) -- CronJobs view
k("n", "", "<Plug>(kubectl.view_daemonsets)", opts) -- DaemonSets view
k("n", "", "<Plug>(kubectl.view_events)", opts) -- Events view
k("n", "", "<Plug>(kubectl.view_helm)", opts) -- Helm view
k("n", "", "<Plug>(kubectl.view_jobs)", opts) -- Jobs view
k("n", "", "<Plug>(kubectl.view_nodes)", opts) -- Nodes view
k("n", "", "<Plug>(kubectl.view_overview)", opts) -- Overview view
k("n", "", "<Plug>(kubectl.view_pv)", opts) -- PersistentVolumes view
k("n", "", "<Plug>(kubectl.view_pvc)", opts) -- PersistentVolumeClaims view
k("n", "", "<Plug>(kubectl.view_sa)", opts) -- ServiceAccounts view
k("n", "", "<Plug>(kubectl.view_top_nodes)", opts) -- Top view for nodes
k("n", "", "<Plug>(kubectl.view_top_pods)", opts) -- Top view for pods
-- Deployment/DaemonSet actions
k("n", "grr", "<Plug>(kubectl.rollout_restart)", opts) -- Rollout restart
k("n", "gss", "<Plug>(kubectl.scale)", opts) -- Scale workload
k("n", "gi", "<Plug>(kubectl.set_image)", opts) -- Set image (only if 1 container)
-- Pod/Container logs
k("n", "gl", "<Plug>(kubectl.logs)", opts) -- Logs view
k("n", "gh", "<Plug>(kubectl.history)", opts) -- Change logs --since= flag
k("n", "f", "<Plug>(kubectl.follow)", opts) -- Follow logs
k("n", "gw", "<Plug>(kubectl.wrap)", opts) -- Toggle wrap log lines
k("n", "gp", "<Plug>(kubectl.prefix)", opts) -- Toggle container name prefix
k("n", "gt", "<Plug>(kubectl.timestamps)", opts) -- Toggle timestamps prefix
k("n", "gpp", "<Plug>(kubectl.previous_logs)", opts) -- Toggle show previous logs
-- Node actions
k("n", "gC", "<Plug>(kubectl.cordon)", opts) -- Cordon node
k("n", "gU", "<Plug>(kubectl.uncordon)", opts) -- Uncordon node
k("n", "gR", "<Plug>(kubectl.drain)", opts) -- Drain node
-- Top actions
k("n", "gn", "<Plug>(kubectl.top_nodes)", opts) -- Top nodes
k("n", "gp", "<Plug>(kubectl.top_pods)", opts) -- Top pods
-- CronJob actions
k("n", "gss", "<Plug>(kubectl.suspend_cronjob)", opts) -- Suspend CronJob
k("n", "gc", "<Plug>(kubectl.create_job)", opts) -- Create Job from CronJob
k("n", "gp", "<Plug>(kubectl.portforward)", opts) -- Pods/Services portforward
k("n", "gx", "<Plug>(kubectl.browse)", opts) -- Ingress view
k("n", "gy", "<Plug>(kubectl.yaml)", opts) -- Helm view
end,
})
For overriding the default mappings when using lazy.nvim
check out our wiki page.
{
log_level = vim.log.levels.INFO,
auto_refresh = {
enabled = true,
interval = 300, -- milliseconds
},
diff = {
bin = "kubediff" -- or any other binary
},
kubectl_cmd = { cmd = "kubectl", env = {}, args = {}, persist_context_change = false },
namespace = "All",
namespace_fallback = {}, -- If you have limited access you can list all the namespaces here
hints = true,
context = true,
heartbeat = true,
lineage = {
enabled = false, -- This feature is in beta at the moment
},
logs = {
prefix = true,
timestamps = true,
since = "5m"
},
alias = {
apply_on_select_from_history = true,
max_history = 5,
},
filter = {
apply_on_select_from_history = true,
max_history = 10,
},
float_size = {
-- Almost fullscreen:
-- width = 1.0,
-- height = 0.95, -- Setting it to 1 will cause bottom to be cutoff by statuscolumn
-- For more context aware size:
width = 0.9,
height = 0.8,
-- Might need to tweak these to get it centered when float is smaller
col = 10,
row = 5,
},
obj_fresh = 5, -- highlight if creation newer than number (in minutes)
skew = {
enabled = true
log_level = vim.log.levels.INFO,
}
}
The plugin uses the following highlight groups:
Highlight Groups
The setup function only adds ~1ms to startup. We use kubectl proxy and curl to reduce latency.
We leverage the Kubernetes Informer to efficiently monitor resource updates.
By using the resourceVersion
, we avoid fetching all resources in each loop.
Instead, the Informer provides only the changes, significantly reducing overhead and improving performance.
As we advance to v1.0.0
, our primary goal is to maintain the stability of the
plugin and minimize any breaking changes. We are committed to providing a
reliable and consistent user experience.
This plugins main purpose is to browse the kubernetes state using vim like navigation and keys, similar to oil.nvim for file browsing.