AWS::OpenSearchService::DomainThe AWS::OpenSearchService::Domain resource creates an Amazon OpenSearch Service domain.
import { CfnDomain } from 'aws-cdk-lib/aws-opensearchservice';Or use the module namespace:
import * as opensearchservice from 'aws-cdk-lib/aws-opensearchservice';
// opensearchservice.CfnDomainConfiguration passed to the constructor as CfnDomainProps.
accessPoliciesOptionalanyAn AWS Identity and Access Management ( IAM ) policy document that specifies who can access the OpenSearch Service domain and their permissions. For more information, see [Configuring access policies](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/ac.html#ac-creating) in the *Amazon OpenSearch Service Developer Guide* .
advancedOptionsOptional{ [key: string]: string } | IResolvableAdditional options to specify for the OpenSearch Service domain. For more information, see [AdvancedOptions](https://docs.aws.amazon.com/opensearch-service/latest/APIReference/API_CreateDomain.html#API_CreateDomain_RequestBody) in the OpenSearch Service API reference.
advancedSecurityOptionsOptionalIResolvable | AdvancedSecurityOptionsInputPropertySpecifies options for fine-grained access control and SAML authentication. If you specify advanced security options, you must also enable node-to-node encryption ( [NodeToNodeEncryptionOptions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-opensearchservice-domain-nodetonodeencryptionoptions.html) ) and encryption at rest ( [EncryptionAtRestOptions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-opensearchservice-domain-encryptionatrestoptions.html) ). You must also enable `EnforceHTTPS` within [DomainEndpointOptions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-opensearchservice-domain-domainendpointoptions.html) , which requires HTTPS for all traffic to the domain.
aimlOptionsOptionalIResolvable | AIMLOptionsPropertyContainer for parameters required to enable all machine learning features.
clusterConfigOptionalIResolvable | ClusterConfigPropertyContainer for the cluster configuration of a domain.
cognitoOptionsOptionalIResolvable | CognitoOptionsPropertyConfigures OpenSearch Service to use Amazon Cognito authentication for OpenSearch Dashboards.
deploymentStrategyOptionsOptionalIResolvable | DeploymentStrategyOptionsPropertydomainArnOptionalstringdomainEndpointOptionsOptionalIResolvable | DomainEndpointOptionsPropertySpecifies additional options for the domain endpoint, such as whether to require HTTPS for all traffic or whether to use a custom endpoint rather than the default endpoint.
domainNameOptionalstringA name for the OpenSearch Service domain. The name must have a minimum length of 3 and a maximum length of 28. If you don't specify a name, CloudFormation generates a unique physical ID and uses that ID for the domain name. For more information, see [Name Type](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-name.html) . Required when creating a new domain. > If you specify a name, you can't perform updates that require replacement of this resource. You can perform updates that require no or some interruption. If you must replace the resource, specify a new name.
ebsOptionsOptionalIResolvable | EBSOptionsPropertyThe configurations of Amazon Elastic Block Store (Amazon EBS) volumes that are attached to data nodes in the OpenSearch Service domain. For more information, see [EBS volume size limits](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/limits.html#ebsresource) in the *Amazon OpenSearch Service Developer Guide* .
encryptionAtRestOptionsOptionalIResolvable | EncryptionAtRestOptionsPropertyWhether the domain should encrypt data at rest, and if so, the AWS key to use. See [Encryption of data at rest for Amazon OpenSearch Service](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/encryption-at-rest.html) . If no encryption at rest options were initially specified in the template, updating this property by adding it causes no interruption. However, if you change this property after it's already been set within a template, the domain is deleted and recreated in order to modify the property.
engineVersionOptionalstringThe version of OpenSearch to use. The value must be in the format `OpenSearch_X.Y` or `Elasticsearch_X.Y` . If not specified, the latest version of OpenSearch is used. For information about the versions that OpenSearch Service supports, see [Supported versions of OpenSearch and Elasticsearch](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/what-is.html#choosing-version) in the *Amazon OpenSearch Service Developer Guide* . If you set the [EnableVersionUpgrade](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-updatepolicy.html#cfn-attributes-updatepolicy-upgradeopensearchdomain) update policy to `true` , you can update `EngineVersion` without interruption. When `EnableVersionUpgrade` is set to `false` , or is not specified, updating `EngineVersion` results in [replacement](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-update-behaviors.html#update-replacement) .
identityCenterOptionsOptionalIResolvable | IdentityCenterOptionsPropertyConfiguration options for controlling IAM Identity Center integration within a domain.
ipAddressTypeOptionalstringChoose either dual stack or IPv4 as your IP address type. Dual stack allows you to share domain resources across IPv4 and IPv6 address types, and is the recommended option. If you set your IP address type to dual stack, you can't change your address type later.
logPublishingOptionsOptionalIResolvable | { [key: string]: IResolvable | LogPublishingOptionProperty }An object with one or more of the following keys: `SEARCH_SLOW_LOGS` , `ES_APPLICATION_LOGS` , `INDEX_SLOW_LOGS` , `AUDIT_LOGS` , depending on the types of logs you want to publish. Each key needs a valid `LogPublishingOption` value. For the full syntax, see the [examples](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-opensearchservice-domain.html#aws-resource-opensearchservice-domain--examples) .
nodeToNodeEncryptionOptionsOptionalIResolvable | NodeToNodeEncryptionOptionsPropertySpecifies whether node-to-node encryption is enabled. See [Node-to-node encryption for Amazon OpenSearch Service](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/ntn.html) .
offPeakWindowOptionsOptionalIResolvable | OffPeakWindowOptionsPropertyOptions for a domain's off-peak window, during which OpenSearch Service can perform mandatory configuration changes on the domain.
skipShardMigrationWaitOptionalboolean | IResolvablesnapshotOptionsOptionalIResolvable | SnapshotOptionsProperty*DEPRECATED* . The automated snapshot configuration for the OpenSearch Service domain indexes.
softwareUpdateOptionsOptionalIResolvable | SoftwareUpdateOptionsPropertyService software update options for the domain.
tagsOptionalCfnTag[]An arbitrary set of tags (key–value pairs) to associate with the OpenSearch Service domain.
vpcOptionsOptionalIResolvable | VPCOptionsPropertyThe virtual private cloud (VPC) configuration for the OpenSearch Service domain. For more information, see [Launching your Amazon OpenSearch Service domains within a VPC](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/vpc.html) in the *Amazon OpenSearch Service Developer Guide* . If you remove this entity altogether, along with its associated properties, it causes a replacement. You might encounter this scenario if you're updating your security configuration from a VPC to a public endpoint.
This L1 construct maps directly to the following CloudFormation resource type.
Our bi-weekly newsletter teaches hands-on AWS fundamentals. No certification fluff - just practical knowledge.
Subscribe to Newsletteraws-opensearchserviceAWS::OpenSearchService::Domain