UNPKG

@aws-sdk/client-route-53

Version:

AWS SDK for JavaScript Route 53 Client for Node.js, Browser and React Native

213 lines (212 loc) 12.2 kB
import { Command as $Command } from "@smithy/smithy-client"; import { MetadataBearer as __MetadataBearer } from "@smithy/types"; import { CreateHealthCheckRequest, CreateHealthCheckResponse } from "../models/models_0"; import { Route53ClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../Route53Client"; /** * @public */ export type { __MetadataBearer }; export { $Command }; /** * @public * * The input for {@link CreateHealthCheckCommand}. */ export interface CreateHealthCheckCommandInput extends CreateHealthCheckRequest { } /** * @public * * The output of {@link CreateHealthCheckCommand}. */ export interface CreateHealthCheckCommandOutput extends CreateHealthCheckResponse, __MetadataBearer { } declare const CreateHealthCheckCommand_base: { new (input: CreateHealthCheckCommandInput): import("@smithy/smithy-client").CommandImpl<CreateHealthCheckCommandInput, CreateHealthCheckCommandOutput, Route53ClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes>; new (__0_0: CreateHealthCheckCommandInput): import("@smithy/smithy-client").CommandImpl<CreateHealthCheckCommandInput, CreateHealthCheckCommandOutput, Route53ClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes>; getEndpointParameterInstructions(): import("@smithy/middleware-endpoint").EndpointParameterInstructions; }; /** * <p>Creates a new health check.</p> * <p>For information about adding health checks to resource record sets, see <a href="https://docs.aws.amazon.com/Route53/latest/APIReference/API_ResourceRecordSet.html#Route53-Type-ResourceRecordSet-HealthCheckId">HealthCheckId</a> in <a href="https://docs.aws.amazon.com/Route53/latest/APIReference/API_ChangeResourceRecordSets.html">ChangeResourceRecordSets</a>. </p> * <p> * <b>ELB Load Balancers</b> * </p> * <p>If you're registering EC2 instances with an Elastic Load Balancing (ELB) load * balancer, do not create Amazon Route 53 health checks for the EC2 instances. When you * register an EC2 instance with a load balancer, you configure settings for an ELB health * check, which performs a similar function to a Route 53 health check.</p> * <p> * <b>Private Hosted Zones</b> * </p> * <p>You can associate health checks with failover resource record sets in a private hosted * zone. Note the following:</p> * <ul> * <li> * <p>Route 53 health checkers are outside the VPC. To check the health of an * endpoint within a VPC by IP address, you must assign a public IP address to the * instance in the VPC.</p> * </li> * <li> * <p>You can configure a health checker to check the health of an external resource * that the instance relies on, such as a database server.</p> * </li> * <li> * <p>You can create a CloudWatch metric, associate an alarm with the metric, and * then create a health check that is based on the state of the alarm. For example, * you might create a CloudWatch metric that checks the status of the Amazon EC2 * <code>StatusCheckFailed</code> metric, add an alarm to the metric, and then * create a health check that is based on the state of the alarm. For information * about creating CloudWatch metrics and alarms by using the CloudWatch console, * see the <a href="https://docs.aws.amazon.com/AmazonCloudWatch/latest/DeveloperGuide/WhatIsCloudWatch.html">Amazon * CloudWatch User Guide</a>.</p> * </li> * </ul> * @example * Use a bare-bones client and the command you need to make an API call. * ```javascript * import { Route53Client, CreateHealthCheckCommand } from "@aws-sdk/client-route-53"; // ES Modules import * // const { Route53Client, CreateHealthCheckCommand } = require("@aws-sdk/client-route-53"); // CommonJS import * const client = new Route53Client(config); * const input = { // CreateHealthCheckRequest * CallerReference: "STRING_VALUE", // required * HealthCheckConfig: { // HealthCheckConfig * IPAddress: "STRING_VALUE", * Port: Number("int"), * Type: "HTTP" || "HTTPS" || "HTTP_STR_MATCH" || "HTTPS_STR_MATCH" || "TCP" || "CALCULATED" || "CLOUDWATCH_METRIC" || "RECOVERY_CONTROL", // required * ResourcePath: "STRING_VALUE", * FullyQualifiedDomainName: "STRING_VALUE", * SearchString: "STRING_VALUE", * RequestInterval: Number("int"), * FailureThreshold: Number("int"), * MeasureLatency: true || false, * Inverted: true || false, * Disabled: true || false, * HealthThreshold: Number("int"), * ChildHealthChecks: [ // ChildHealthCheckList * "STRING_VALUE", * ], * EnableSNI: true || false, * Regions: [ // HealthCheckRegionList * "us-east-1" || "us-west-1" || "us-west-2" || "eu-west-1" || "ap-southeast-1" || "ap-southeast-2" || "ap-northeast-1" || "sa-east-1", * ], * AlarmIdentifier: { // AlarmIdentifier * Region: "us-east-1" || "us-east-2" || "us-west-1" || "us-west-2" || "ca-central-1" || "eu-central-1" || "eu-central-2" || "eu-west-1" || "eu-west-2" || "eu-west-3" || "ap-east-1" || "me-south-1" || "me-central-1" || "ap-south-1" || "ap-south-2" || "ap-southeast-1" || "ap-southeast-2" || "ap-southeast-3" || "ap-northeast-1" || "ap-northeast-2" || "ap-northeast-3" || "eu-north-1" || "sa-east-1" || "cn-northwest-1" || "cn-north-1" || "af-south-1" || "eu-south-1" || "eu-south-2" || "us-gov-west-1" || "us-gov-east-1" || "us-iso-east-1" || "us-iso-west-1" || "us-isob-east-1" || "ap-southeast-4" || "il-central-1" || "ca-west-1" || "ap-southeast-5" || "mx-central-1" || "ap-southeast-7", // required * Name: "STRING_VALUE", // required * }, * InsufficientDataHealthStatus: "Healthy" || "Unhealthy" || "LastKnownStatus", * RoutingControlArn: "STRING_VALUE", * }, * }; * const command = new CreateHealthCheckCommand(input); * const response = await client.send(command); * // { // CreateHealthCheckResponse * // HealthCheck: { // HealthCheck * // Id: "STRING_VALUE", // required * // CallerReference: "STRING_VALUE", // required * // LinkedService: { // LinkedService * // ServicePrincipal: "STRING_VALUE", * // Description: "STRING_VALUE", * // }, * // HealthCheckConfig: { // HealthCheckConfig * // IPAddress: "STRING_VALUE", * // Port: Number("int"), * // Type: "HTTP" || "HTTPS" || "HTTP_STR_MATCH" || "HTTPS_STR_MATCH" || "TCP" || "CALCULATED" || "CLOUDWATCH_METRIC" || "RECOVERY_CONTROL", // required * // ResourcePath: "STRING_VALUE", * // FullyQualifiedDomainName: "STRING_VALUE", * // SearchString: "STRING_VALUE", * // RequestInterval: Number("int"), * // FailureThreshold: Number("int"), * // MeasureLatency: true || false, * // Inverted: true || false, * // Disabled: true || false, * // HealthThreshold: Number("int"), * // ChildHealthChecks: [ // ChildHealthCheckList * // "STRING_VALUE", * // ], * // EnableSNI: true || false, * // Regions: [ // HealthCheckRegionList * // "us-east-1" || "us-west-1" || "us-west-2" || "eu-west-1" || "ap-southeast-1" || "ap-southeast-2" || "ap-northeast-1" || "sa-east-1", * // ], * // AlarmIdentifier: { // AlarmIdentifier * // Region: "us-east-1" || "us-east-2" || "us-west-1" || "us-west-2" || "ca-central-1" || "eu-central-1" || "eu-central-2" || "eu-west-1" || "eu-west-2" || "eu-west-3" || "ap-east-1" || "me-south-1" || "me-central-1" || "ap-south-1" || "ap-south-2" || "ap-southeast-1" || "ap-southeast-2" || "ap-southeast-3" || "ap-northeast-1" || "ap-northeast-2" || "ap-northeast-3" || "eu-north-1" || "sa-east-1" || "cn-northwest-1" || "cn-north-1" || "af-south-1" || "eu-south-1" || "eu-south-2" || "us-gov-west-1" || "us-gov-east-1" || "us-iso-east-1" || "us-iso-west-1" || "us-isob-east-1" || "ap-southeast-4" || "il-central-1" || "ca-west-1" || "ap-southeast-5" || "mx-central-1" || "ap-southeast-7", // required * // Name: "STRING_VALUE", // required * // }, * // InsufficientDataHealthStatus: "Healthy" || "Unhealthy" || "LastKnownStatus", * // RoutingControlArn: "STRING_VALUE", * // }, * // HealthCheckVersion: Number("long"), // required * // CloudWatchAlarmConfiguration: { // CloudWatchAlarmConfiguration * // EvaluationPeriods: Number("int"), // required * // Threshold: Number("double"), // required * // ComparisonOperator: "GreaterThanOrEqualToThreshold" || "GreaterThanThreshold" || "LessThanThreshold" || "LessThanOrEqualToThreshold", // required * // Period: Number("int"), // required * // MetricName: "STRING_VALUE", // required * // Namespace: "STRING_VALUE", // required * // Statistic: "Average" || "Sum" || "SampleCount" || "Maximum" || "Minimum", // required * // Dimensions: [ // DimensionList * // { // Dimension * // Name: "STRING_VALUE", // required * // Value: "STRING_VALUE", // required * // }, * // ], * // }, * // }, * // Location: "STRING_VALUE", // required * // }; * * ``` * * @param CreateHealthCheckCommandInput - {@link CreateHealthCheckCommandInput} * @returns {@link CreateHealthCheckCommandOutput} * @see {@link CreateHealthCheckCommandInput} for command's `input` shape. * @see {@link CreateHealthCheckCommandOutput} for command's `response` shape. * @see {@link Route53ClientResolvedConfig | config} for Route53Client's `config` shape. * * @throws {@link HealthCheckAlreadyExists} (client fault) * <p> The health check you're attempting to create already exists. Amazon Route 53 returns * this error when you submit a request that has the following values:</p> * <ul> * <li> * <p>The same value for <code>CallerReference</code> as an existing health check, * and one or more values that differ from the existing health check that has the * same caller reference.</p> * </li> * <li> * <p>The same value for <code>CallerReference</code> as a health check that you * created and later deleted, regardless of the other settings in the * request.</p> * </li> * </ul> * * @throws {@link InvalidInput} (client fault) * <p>The input is not valid.</p> * * @throws {@link TooManyHealthChecks} (client fault) * <p>This health check can't be created because the current account has reached the limit * on the number of active health checks.</p> * <p>For information about default limits, see <a href="https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/DNSLimitations.html">Limits</a> in the * <i>Amazon Route 53 Developer Guide</i>.</p> * <p>For information about how to get the current limit for an account, see <a href="https://docs.aws.amazon.com/Route53/latest/APIReference/API_GetAccountLimit.html">GetAccountLimit</a>. To request a higher limit, <a href="http://aws.amazon.com/route53-request">create a case</a> with the Amazon Web Services Support * Center.</p> * <p>You have reached the maximum number of active health checks for an Amazon Web Services account. To request a higher limit, <a href="http://aws.amazon.com/route53-request">create a case</a> with the Amazon Web Services Support * Center.</p> * * @throws {@link Route53ServiceException} * <p>Base exception class for all service exceptions from Route53 service.</p> * * @public */ export declare class CreateHealthCheckCommand extends CreateHealthCheckCommand_base { /** @internal type navigation helper, not in runtime. */ protected static __types: { api: { input: CreateHealthCheckRequest; output: CreateHealthCheckResponse; }; sdk: { input: CreateHealthCheckCommandInput; output: CreateHealthCheckCommandOutput; }; }; }