ves-io-schema-healthcheck-API-Create

Examples of creating healthcheck

Usecase:

Create healthcheck-productpage to check health of productpage in bookinfo application

Request using vesctl:

vesctl configuration create healthcheck -i healthcheck.yaml

where file healthcheck.yaml has following contents (healthcheck.CreateRequest):

RequestJSON:

{
    "metadata": {
        "name": "healthcheck-productpage",
        "namespace": "documentation"
    },
    "spec": {
        "http_health_check": {
            "host_header": "productpage.internal.bookinfo.com",
            "path": "/healthcheck"
        },
        "timeout": 3,
        "interval": 10,
        "unhealthy_threshold": 3,
        "healthy_threshold": 2,
        "jitter_percent": 20
    }
}

vesctl yaml response:

ResponseJSON:

{
    "metadata": {
        "name": "healthcheck-productpage",
        "namespace": "documentation",
        "labels": {},
        "annotations": {},
        "description": "",
        "disable": false
    },
    "system_metadata": {
        "uid": "0badcaed-6394-4b60-b296-a7eb5203a2bc",
        "creation_timestamp": "2022-09-23T13:12:24.235061948Z",
        "deletion_timestamp": null,
        "modification_timestamp": null,
        "initializers": null,
        "finalizers": [],
        "tenant": "acmecorp",
        "creator_class": "examplesvc",
        "creator_id": "examplesvc",
        "object_index": 0,
        "owner_view": null,
        "labels": {}
    },
    "spec": {
        "http_health_check": {
            "host_header": "productpage.internal.bookinfo.com",
            "path": "/healthcheck",
            "headers": {},
            "request_headers_to_remove": [],
            "use_http2": false
        },
        "timeout": 3,
        "interval": 10,
        "jitter": 0,
        "unhealthy_threshold": 3,
        "healthy_threshold": 2,
        "jitter_percent": 20
    }
}

Request using curl:

curl -X 'POST' -d '{"metadata":{"name":"healthcheck-productpage","namespace":"documentation"},"spec":{"http_health_check":{"host_header":"productpage.internal.bookinfo.com","path":"/healthcheck"},"timeout":3,"interval":10,"unhealthy_threshold":3,"healthy_threshold":2,"jitter_percent":20}}' -H 'Content-Type: application/json' -H 'X-Volterra-Useragent: v1/pgm=_tmp_go-build243329498_b001_apidocs.test/host=docker-desktop' 'https://acmecorp.console.ves.volterra.io/api/config/namespaces/documentation/healthchecks'

curl response:

HTTP/1.1 200 OK
Content-Length: 989
Content-Type: application/json
Date: Fri, 23 Sep 2022 13:12:24 GMT
Vary: Accept-Encoding

{
  "metadata": {
    "name": "healthcheck-productpage",
    "namespace": "documentation",
    "labels": {
    },
    "annotations": {
    },
    "description": "",
    "disable": false
  },
  "system_metadata": {
    "uid": "0badcaed-6394-4b60-b296-a7eb5203a2bc",
    "creation_timestamp": "2022-09-23T13:12:24.235061948Z",
    "deletion_timestamp": null,
    "modification_timestamp": null,
    "initializers": null,
    "finalizers": [
    ],
    "tenant": "acmecorp",
    "creator_class": "examplesvc",
    "creator_id": "examplesvc",
    "object_index": 0,
    "owner_view": null,
    "labels": {
    }
  },
  "spec": {
    "http_health_check": {
      "host_header": "productpage.internal.bookinfo.com",
      "path": "/healthcheck",
      "headers": {
      },
      "request_headers_to_remove": [
      ],
      "use_http2": false
    },
    "timeout": 3,
    "interval": 10,
    "jitter": 0,
    "unhealthy_threshold": 3,
    "healthy_threshold": 2,
    "jitter_percent": 20
  }
}