Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add kubectl-limitrange plugin to Krew index #4182

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

mfenerich
Copy link

@mfenerich mfenerich commented Nov 1, 2024

Title: Add kubectl-limitrange plugin to Krew index

Description:

This PR adds the kubectl-limitrange plugin to the Krew plugin index.

Plugin Name: kubectl-limitrange

Plugin Repository: https://github.com/mfenerich/kubectl-lr

Overview

kubectl-limitrange is a kubectl plugin that simplifies the creation of LimitRange resources in Kubernetes namespaces. It provides an easy and efficient way to set CPU and memory limits, helping cluster administrators enforce resource constraints and optimize cluster performance.

Key Features

  • Easy Creation of LimitRanges: Streamlines the process of creating LimitRange resources without the need to write YAML manifests manually.
  • Configurable Resource Limits: Allows users to specify minimum and maximum CPU and memory limits according to their requirements.
  • Namespace Support: Can target specific namespaces, making it flexible for multi-tenant environments.
  • Cross-Platform Availability: Binaries are available for macOS (darwin), Linux, and Windows on amd64 architectures.

Why This Plugin Should Be Accepted

  • Enhances Productivity: Automates repetitive tasks, saving time and reducing the potential for human error in resource configuration.
  • Promotes Best Practices: Encourages the use of LimitRanges, which are essential for resource management and ensuring fair resource allocation among pods.
  • Community Benefit: Fills a gap in the current plugin ecosystem by providing a dedicated tool for managing LimitRanges.

Compliance with Krew Guidelines

  • Manifest Validation: The plugin manifest has been validated and complies with Krew's plugin manifest specification.
  • License: The plugin is open-sourced under the Apache License 2.0, aligning with Krew's licensing requirements.
  • Naming Convention: The plugin name follows the kubectl-<plugin-name> format, adhering to the recommended naming conventions.

Testing and Verification

  • Installation: Successfully tested installation via Krew on macOS and Linux systems.
  • Functionality: Verified that the plugin correctly creates LimitRange resources with specified CPU and memory limits.
  • Documentation: Usage instructions and examples are provided in the plugin's README.

Example Usage

# Create a LimitRange in the 'development' namespace with custom limits
kubectl limitrange create limitrange --namespace=development --cpu-min=100m --cpu-max=500m --memory-min=128Mi --memory-max=1Gi

Related Links

@ahmetb
Copy link
Member

ahmetb commented Nov 1, 2024

🤖 Beep beep! I’m a robot speaking on behalf of @ahmetb. 🤖


Thanks for submitting your kubectl plugin to Krew!
One of the krew-index maintainers will review it soon. Note that the reviews for new plugin submissions may take a few days.

In the meanwhile, here are a few tips to make your plugin manifest better:

  • Make sure your plugin follows the best practices.
  • Eliminate redundant wording form shortDescription (it should be max 50 characters).
  • Try to word wrap your description to 80-character lines (no usage examples, please).

Thanks for your patience!
/kind new-plugin

@k8s-ci-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by: mfenerich
Once this PR has been reviewed and has the lgtm label, please assign chriskim06 for approval. For more information see the Kubernetes Code Review Process.

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@k8s-ci-robot k8s-ci-robot added the cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. label Nov 1, 2024
@k8s-ci-robot k8s-ci-robot added kind/new-plugin size/M Denotes a PR that changes 30-99 lines, ignoring generated files. labels Nov 1, 2024
@mfenerich
Copy link
Author

mfenerich commented Jan 4, 2025

Hi @chriskim06 or team,

Just a friendly reminder about this PR – it’s been open for a while, and I’d appreciate it if someone could take a look when time permits. Let me know if there’s anything I can clarify or improve!

Thanks for your time! 😊

@ahmetb
Copy link
Member

ahmetb commented Jan 4, 2025

Hey! I'm thinking if we should accept this as part of the new "create plugins" feature (would be named "create-limitrange" in that case).

We can implement that feature fairly easily and users can call it via "kubectl create limitrange".

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. kind/new-plugin size/M Denotes a PR that changes 30-99 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants