Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kubermatic/fubectl
Reduces repetitive interactions with kubectl
https://github.com/kubermatic/fubectl
cli kubectl kubernetes
Last synced: 5 days ago
JSON representation
Reduces repetitive interactions with kubectl
- Host: GitHub
- URL: https://github.com/kubermatic/fubectl
- Owner: kubermatic
- License: apache-2.0
- Created: 2018-02-05T20:39:20.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2025-01-28T13:27:03.000Z (23 days ago)
- Last Synced: 2025-02-07T23:18:47.061Z (12 days ago)
- Topics: cli, kubectl, kubernetes
- Language: Go
- Homepage:
- Size: 1.26 MB
- Stars: 885
- Watchers: 19
- Forks: 63
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: code-of-conduct.md
Awesome Lists containing this project
README
# fubectl
Because it's fancy-kubectl !## Prerequisites?
* [fzf](https://github.com/junegunn/fzf)
* [kubectl](https://github.com/kubernetes/kubernetes)
* [kubectl tree](https://github.com/ahmetb/kubectl-tree)
* [kubectl neat](https://github.com/itaysk/kubectl-neat) - only for kexp to work
* [jq](https://stedolan.github.io/jq/)## Installation
You can directly download the [`fubectl.source`](https://rawgit.com/kubermatic/fubectl/main/fubectl.source)
and save it in some directory.Download:
```bash
curl -LO https://rawgit.com/kubermatic/fubectl/main/fubectl.source
```then add to your .bashrc/.zshrc file:
```bash
[ -f /fubectl.source ] && source /fubectl.source
```Alternatively you can install fubectl using the ZSH plugin manager of your
choice.## What can it do?
### `k` – alias for kubectl
Like g for git but 233% more effective!
Examples:
- `k get nodes`
- `k get pods`
- `k version --short`Usage:
data:image/s3,"s3://crabby-images/0fc92/0fc928c692cae320fd01fc3c4941852c171cf958" alt="kGif"---
### `kw` – alias for 'watch kubectl'
Examples:
- `kw nodes`
- `kw pods`
- `kw nodes,pods,services`---
### `kall` – All pods in all namespaces
Get all pods
Usage:
data:image/s3,"s3://crabby-images/2f826/2f826120db94e4be87b5b34ad8af9ca4b9549476" alt="kGif"---
### `kwall` – Watch all pods in all namespaces
Watch all pods in all namespaces every 2 seconds.
Usage:
data:image/s3,"s3://crabby-images/4422d/4422dae579ace302b2938941dc3e94346ed201d8" alt="kGif"---
### `kdes` – Describe a resource
Examples:
- `kdes pod`
- `kdes service`
- `kdes nodes`Usage:
data:image/s3,"s3://crabby-images/7aab0/7aab027ea0cff45605353782ab620408aa7e1223" alt="kGif"---
### `kdel` – Delete a resource
Examples:
- `kdel pod`
- `kdel secret`
- `kdel pvc`Usage:
data:image/s3,"s3://crabby-images/caa68/caa68487e0d59a822b27fab947f4f638ce54b995" alt="kGif"---
### `klog` – Print the logs for a container in a pod
Examples:
- `klog` - Print the last 10 lines
- `klog 100` - Print the last 100 lines
- `klog 250 -f` - Print the last 250 lines and follow the output, like `tail -f`
- `klog 50 -p` - Print the last 50 lines of the previous containerUsage:
data:image/s3,"s3://crabby-images/2eae8/2eae8784a6fb2f92812fd2bb85ef5b2469b3413b" alt="kGif"---
### `kex` – Execute a command in a container
Examples:
- `kex bash` - Start a bash in a container
- `kex date` - Print the date in a containerUsage:
data:image/s3,"s3://crabby-images/13d01/13d014dffcdb9c1603f169252964adb9f43f2ab3" alt="kGif"---
### `kfor` – Forward one or more local ports to a pod
Examples:
- `kfor 8000` - Forwards port 8000 to a pod
- `kfor 8000:80` Fowards local port 8000 to a pod's port 80Usage:
data:image/s3,"s3://crabby-images/32d6d/32d6df20c5a8033a2f1a4812d69b6d5ab8bf2765" alt="kGif"---
### `ksearch` – Search for string in resources
Examples:
- `// TODO`Usage:
data:image/s3,"s3://crabby-images/f31d8/f31d8d05009fc604657c782329d75cd1fa49c05a" alt="kGif"---
### `kcl` – Displays one or many contexts from the kubeconfig file
Context list
Usage:
data:image/s3,"s3://crabby-images/413d1/413d192837b403dbf059cf02ca0377fa17668ce9" alt="kGif"---
### `kcs` – Sets the current context
Usage:
data:image/s3,"s3://crabby-images/3fb92/3fb92c547f9e93df40d48e02079a4aede1db0444" alt="kGif"---
### `kcns` – Switch the default namespace
`kcns` - Set the current default namespace from list
`kcns kube-system` - Set kube-system as default namespace immediatelyUsage:
data:image/s3,"s3://crabby-images/7710d/7710d9a30950ccf2d3e866c5f1493dc9d69417a6" alt="kGif"
---### `kdebug` – Start a debugging Pod in a Cluster
Usage:
data:image/s3,"s3://crabby-images/0f09c/0f09c75f87c5c9d8084460dac73d39420776a376" alt="kGif"---
### `kp` – Open the Kubernetes dashboard
Opens `localhost:8001/ui` in your browser and runs `kubectl proxy`
---
## Extra!
Do you want to have the current kubecontext in your prompt?:
```bash
export PS1="\[$(kube_ctx_name)\] $PS1"
```for the current namespace (this is currently slow, because it calls kubectl every time):
```bash
export PS1="\[$(kube_ctx_namespace)\] $PS1"
```## Customization
`fubectl` can be customized via following environment variables
* `FUBECTL_WATCH_CMD` – alterative `watch` command, e.g. [viddy](https://github.com/sachaos/viddy)
* `FUBECTL_NO_KCL` – disable `kcl` alias, since it may conflict with [KCL language CLI](https://www.kcl-lang.io/)## Troubleshooting
If you encounter issues [file an issue][1] or talk to us on the [#fubectl channel][12] on the [Kubermatic Slack][15].
## Contributing
Thanks for taking the time to join our community and start contributing!
Feedback and discussion are available on [Kubermatic Slack][15].
### Before you start
* Please familiarize yourself with the [Code of Conduct][4] before contributing.
* See [CONTRIBUTING.md][2] for instructions on the developer certificate of origin that we require.### Pull requests
* We welcome pull requests. Feel free to dig through the [issues][1] and jump in.
[1]: https://github.com/kubermatic/fubectl/issues
[2]: https://github.com/kubermatic/fubectl/blob/main/CONTRIBUTING.md
[4]: https://github.com/kubermatic/fubectl/blob/main/code-of-conduct.md[12]: https://kubermatic.slack.com/messages/fubectl
[15]: http://slack.kubermatic.io/