Skip to content
πŸ“¦ Package manager for "kubectl plugins"
Branch: master
Clone or download
corneliusweig and k8s-ci-robot More integration tests (#208)
* Add further integration tests

Missing subcommand: upgrade

* Add test for `krew list`

* Be consistent with the number of lines

0 plugins -> empty string (instead of 2 lines)
1 plugin -> 1 line (instead of 2 lines)
2 plugins -> 2 lines (instead of 3 lines)

* Determine the correct krew binary for integration tests

* Remove instructions where integration tests are run with a non-standard build

* Check for existence of the krew binary when running integration tests

* Trim krew output in integration tests

* Test improvements

- clarify logic for `krew list` test
- check error case for `krew info`
- make `krew version` test more resilient against formatting changes

* Split good and bad test cases for `krew info`
Latest commit 95a9ad7 Jun 11, 2019


Build Status Code Coverage Go Report Card LICENSE Releases

krew is the package manager for kubectl plugins.

What is krew?

krew is a tool that makes it easy to use kubectl plugins. krew helps you discover plugins, install and manage them on your machine. It is similar to tools like apt, dnf or brew.

  • For kubectl users: krew helps you find, install and manage kubectl plugins in a consistent way.
  • For plugin developers: krew helps you package and distribute your plugins on multiple platforms and makes them discoverable.

krew is easy to use:

kubectl krew search                 # show all plugins
kubectl krew install view-secret    # install a plugin named "view-secret"
kubectl view-secret                 # use the plugin
kubectl krew upgrade                # upgrade installed plugins
kubectl krew uninstall view-secret  # uninstall a plugin

Read the User Guide for detailed documentation.


⚠️ Warning: krew is only compatible with kubectl v1.12 or higher.

macOS and Linux:

Bash and ZSH

  1. Make sure that git is installed.

  2. Run this command in your terminal to download and install krew:

      set -x; cd "$(mktemp -d)" &&
      curl -fsSLO "{tar.gz,yaml}" &&
      tar zxvf krew.tar.gz &&
      ./krew-"$(uname | tr '[:upper:]' '[:lower:]')_amd64" install \
        --manifest=krew.yaml --archive=krew.tar.gz
  3. Add $HOME/.krew/bin directory to your PATH environment variable. To do this, update your .bashrc or .zshrc file and append the following line:

    export PATH="${KREW_ROOT:-$HOME/.krew}/bin:$PATH"

    and restart your shell.


  1. Make sure that git is installed.

  2. Run this command in your terminal to download and install krew:

      set -x; cd "(mktemp -d)" &&
      curl -fsSLO "{tar.gz,yaml}" &&
      tar zxvf krew.tar.gz &&
      set KREWNAME krew-(uname | tr '[:upper:]' '[:lower:]')_amd64 &&
      ./$KREWNAME install \
        --manifest=krew.yaml --archive=krew.tar.gz &&
      set -e KREWNAME
  3. Add $HOME/.krew/bin directory to your PATH environment variable. To do this, update your file and append the following line:

    set -gx PATH $PATH $HOME/.krew/bin

    and restart your shell.


  1. Make sure git is installed on your system.

  2. Download and krew.yaml from the Releases page.

  3. Extract the archive to a directory, navigate to the directory.

  4. Launch a command-line window (cmd.exe) in that directory.

  5. Run the following command to install krew (pass the correct paths to krew.yaml and below):

    .\krew-windows_amd64.exe install --manifest=krew.yaml
  6. Add %USERPROFILE%\.krew\bin to your PATH environment variable (how?)

Verifying installation

Run kubectl plugin list command to see installed plugins. This command should show kubectl-krew in the results. You can now use kubectl krew command.

Upgrading krew

Since krew itself is installed as a "kubectl plugin" managed by krew, it can be upgraded like a plugin by running the kubectl krew upgrade command.


  • Users:
  • Plugin Developers:
  • Krew Developers:

Visit ./docs for all documentation.


Please check out the Issue Tracker to see the plan of record for new features and changes.


Bug reports

  • If you have a problem with the Krew itself, please file an issue in this repository.
  • If you're having a problem with a particular plugin's installation or upgrades, file an issue at krew-index repository.
  • If you're having an issue with an installed plugin, file an issue for the repository the plugin's source code is hosted at.

Communication channels


Interested in contributing to Krew? Please refer to our Contributing Guidelines for more details

Code of Conduct

Participation in the Kubernetes community is governed by the Kubernetes Code of Conduct.

You can’t perform that action at this time.