Skip to content

Latest commit

 

History

History
133 lines (109 loc) · 5.06 KB

api-request-recommendation-apply.md

File metadata and controls

133 lines (109 loc) · 5.06 KB

Container Request Recommendation Apply/Plan APIs

{% hint style="warning" %} This feature is in beta. Please read the documentation carefully. {% endhint %}

The Apply/Plan APIs for request recommendations takes Kubecost's calculated container request recommendations and applies them to your cluster.

Prerequisites

To use the Plan/Apply APIs, you must first enable Kubecost's Cluster Controller. The Cluster Controller contains Kubecost's automation features (including the APIs described in this document), and thus has write permission to certain resources on your cluster.

APIs

Apply has dry-run semantics, meaning it is a two-step process:

  1. Plan what will happen (Plan API)
  2. Execute the plan (Apply API)

Plan API

{% swagger method="post" path="/cluster/requestsizer/planV2" baseUrl="http://" summary="Plan API" %} {% swagger-description %} It expects a request with a body that is identical to a response from the request right-sizing recommendation API. {% endswagger-description %} {% endswagger %}

{% hint style="info" %} The versions of the Request Right-Sizing Recommendation API and the Plan API need to match to produce a successful right-sizing plan. For example, if you choose to use the deprecated Request Right Sizing Recommendation API V1 (which is not officially supported), you must use /plan, not /planV2. The outputs generated by /plan and /planV2 should be identical. {% endhint %}

Examine the cURL example below. The API response can be inspected to see what Kubecost will attempt to do before running the apply step. The plan may do less than the recommendation, see Current Limitations.

{% tabs %} {% tab title="Request" %} {% code overflow="wrap" %}

# Make to `kubectl port-forward -n kubecost service/kubecost-cost-analyzer 9090` or replace 'localhost:9090' with your Kubecost address

curl -XGET 'http://localhost:9090/model/savings/requestSizing' \
    -d 'window=2d' \
    |
    curl -H "Content-Type: application/json" \
        -XPOST \
        --data-binary @- \
        'http://localhost:9090/cluster/requestsizer/plan'

{% endcode %} {% endtab %}

{% tab title="Response" %}

{
  "cluster-name": {
    "namespace-name": [
      {
        "Name": "controller-name-X",
        "Kind": "controller-kind-X",
        "ContainerPlans": {
          "container-name-X": {
            "TargetCPURequestMillicores": 0.00,
            "TargetRAMRequestBytes": 0.00,
          },
          ...
        }
      },
      ...
    ],
    ...
  },
  ...
}

{% endtab %} {% endtabs %}

Apply API

{% swagger method="get" path="/cluster/requestsizer/apply" baseUrl="http://kubecost.example.com" summary="Apply API" %} {% swagger-description %} It expects a request with a body that is identical to a response from the Plan API. {% endswagger-description %} {% endswagger %}

{% hint style="info" %} The Apply API accepts outputs from both /plan and /planV2 endpoints. There is no need to specify the version in your endpoint. {% endhint %}

In the cURL example below, the API response includes the original plan, plus some metadata:

{% tabs %} {% tab title="Request" %} {% code overflow="wrap" %}

# Make to `kubectl port-forward -n kubecost service/kubecost-cost-analyzer 9090`
# or replace 'localhost:9090' with 'kubecost.example.com'

curl -XGET 'http://localhost:9090/model/savings/requestSizing' \
    -d 'window=2d' \
    |
    curl -H "Content-Type: application/json" \
        -XPOST \
        --data-binary @- \
        'http://localhost:9090/cluster/requestsizer/plan' \
    |
    curl -H "Content-Type: application/json" \
        -XPOST \
        --data-binary @- \
        'http://localhost:9090/cluster/requestsizer/apply'

{% endcode %} {% endtab %}

{% tab title="Response" %}

{
  "TimeInitiated": "",
  "TimeFinished": "",
  
  "Errors": ["error message here"],
  "Warnings": ["non-failure warnings here"],
  "FromPlan": <the plan passed as argument>
}

{% endtab %} {% endtabs %}

Current Limitations

  • The Apply APIs only "size down," i.e. they will never increase a container requests, only lower them. This is currently done out of an abundance of caution while the APIs are being tested. This is to prevent a well-running cluster to scale up and run out of capacity, even if setting the requests to a higher level would provide better availability guarantees.
  • The Apply APIs only support some controller kinds (Deployments, DaemonSets, StatefulSets, ReplicaSets) at the moment. This is planned to increase soon and is subject to change.
  • The Apply APIs do not support sizing pods without a controller. This is also planned to change.
  • The Apply APIs do not support clusters other than the "local" cluster (the cluster that the instance of Kubecost you are interacting with via HTTP is running on).