Skip to content

Commit

Permalink
Merge pull request #1350 from msvinaykumar/bulkApiDocumentationUpdate
Browse files Browse the repository at this point in the history
bulk API documentation Update
  • Loading branch information
dinogun authored Oct 18, 2024
2 parents cce96ae + 04352ac commit 02886da
Showing 1 changed file with 58 additions and 0 deletions.
58 changes: 58 additions & 0 deletions design/BulkAPI.md
Original file line number Diff line number Diff line change
Expand Up @@ -252,3 +252,61 @@ resource optimization in Kubernetes environments. Below is a breakdown of the JS
- **Type**: `String (ISO 8601 format) or null`
- **Description**: End timestamp of the job. If the job is still in progress, this will be `null`.

**Note: Experiment Name:**

- **Naming Pattern:** Experiment names are currently formed using the following pattern:
`datasource_name|cluster_name|namespace|workload_name(workload_type)|container_name`
- **Example:** For a Prometheus datasource, if the cluster is named `prod-cluster`, namespace is `default`, workload
is `nginx` (of type `Deployment`), and container is `nginx-container`, the experiment name would be:
`Prometheus|prod-cluster|default|nginx(Deployment)|nginx-container`

# Bulk Service Configuration

*Note: Configuration is subject to change.*

## Datasource

- **Description:** Provide the details about the datasource during Kruize configuration. This is essential for
generating accurate resource optimization recommendations.
- **Example:** During configuration, the datasource could be Prometheus or Thanos, based on the setup for your
Kubernetes cluster.
- Comprehensive configuration details and an example are available at the
following [link](https://github.com/kruize/autotune/blob/cce96ae68876d6ed2afe505bab04efd1567c8239/manifests/crc/default-db-included-installation/openshift/kruize-crc-openshift.yaml#L133).

```yaml
apiVersion: v1
kind: ConfigMap
metadata:
name: kruizeconfig
namespace: openshift-tuning
data:
kruizeconfigjson: |
{
"datasource": [
{
"name": "prometheus-1",
"provider": "prometheus",
"serviceName": "prometheus-k8s",
"namespace": "openshift-monitoring",
"url": "",
"authentication": {
"type": "bearer",
"credentials": {
"tokenFilePath": "/var/run/secrets/kubernetes.io/serviceaccount/token"
}
}
}
]
}
```
## Limits
- **Default Limit:** Currently, the Bulk service supports only **1000 experiments** by default.
- **Increasing the Limit:** You can increase this limit by setting the environment variable `bulkapilimit`.
- **Job Failure on Exceeding Limit:** If the number of experiments exceeds the set limit, the job will fail.

## Bulk API Threads

- **Control Mechanism:** The number of threads used for bulk API operations can be controlled using the environment
variable `bulkThreadPoolSize`.

0 comments on commit 02886da

Please sign in to comment.