MDAA TS Docs
    Preparing search index...

    A construct for the creation of a compliant Rds Serverless Cluster Specifically, the construct ensures the following:

    • The cluster is encrypted at rest using KMS CMK.
    • SSL must be utilized to connect to the cluster.
    • The cluster is VPC connected and not publicly accessible.

    Hierarchy (View Summary)

    Index

    Constructors

    Properties

    cloudwatchLogGroups: { [engine: string]: ILogGroup }

    The log group is created when cloudwatchLogsExports is set.

    Each export value will create a separate log group.

    clusterEndpoint: Endpoint

    The endpoint to use for read/write operations

    clusterIdentifier: string

    Identifier of the cluster

    clusterReadEndpoint: Endpoint

    Endpoint to use for load-balanced read-only operations.

    clusterResourceIdentifier: string

    The immutable identifier for the cluster; for example: cluster-ABCD1234EFGH5678IJKL90MNOP.

    This AWS Region-unique identifier is used in things like IAM authentication policies.

    connections: Connections

    Access to the network connections

    databaseInsightsMode?: DatabaseInsightsMode

    The database insights mode.

    enableDataApi?: boolean
    engine?: IClusterEngine

    The engine for this Cluster. Never undefined.

    env: ResourceEnvironment

    The environment this resource belongs to. For resources that are created and managed by the CDK (generally, those created by creating new class instances like Role, Bucket, etc.), this is always the same as the environment of the stack they belong to; however, for imported resources (those obtained from static methods like fromRoleArn, fromBucketName, etc.), that might be different than the stack they were imported into.

    hasServerlessInstance?: boolean
    instanceEndpoints: Endpoint[]

    Endpoints which address each individual replica.

    instanceIdentifiers: string[]

    Identifiers of the replicas

    monitoringRole?: IRole

    The IAM role for the enhanced monitoring.

    multiUserRotationApplication: SecretRotationApplication

    Application for multi user rotation to this cluster.

    newCfnProps: CfnDBClusterProps
    node: Node

    The tree node.

    performanceInsightEncryptionKey?: IKey

    The AWS KMS key for encryption of Performance Insights data.

    performanceInsightRetention?: PerformanceInsightRetention

    The amount of time, in days, to retain Performance Insights data.

    performanceInsightsEnabled: boolean

    Whether Performance Insights is enabled at cluster level.

    physicalName: string

    Returns a string-encoded token that resolves to the physical name that should be passed to the CloudFormation resource.

    This value will resolve to one of the following:

    • a concrete value (e.g. "my-awesome-bucket")
    • undefined, when a name should be generated by CloudFormation
    • a concrete name generated automatically during synthesis, in cross-environment scenarios.
    secret?: ISecret

    The secret attached to this cluster

    securityGroups: ISecurityGroup[]
    serverlessV2AutoPauseDuration?: Duration
    serverlessV2MaxCapacity: number
    serverlessV2MinCapacity: number
    singleUserRotationApplication: SecretRotationApplication

    Application for single user rotation of the master password to this cluster.

    stack: Stack

    The stack in which this resource is defined.

    subnetGroup: ISubnetGroup
    vpc: IVpc

    The VPC network to place the cluster in.

    vpcSubnets?: SubnetSelection

    The cluster's subnets.

    PROPERTY_INJECTION_ID: string

    Uniquely identifies this class.

    Accessors

    • get clusterArn(): string

      The ARN of the cluster

      Returns string

    Methods

    • Internal

      Create cluster instances

      Parameters

      • props: DatabaseClusterProps

      Returns InstanceConfig

    • Internal

      Called when this resource is referenced across environments (account/region) to order to request that a physical name will be generated for this resource during synthesis, so the resource can be referenced through its absolute name/arn.

      Returns void

    • Add a new db proxy to this cluster.

      Parameters

      • id: string
      • options: DatabaseProxyOptions

      Returns DatabaseProxy

    • Adds the multi user rotation to this cluster. See Alternating users rotation strategy

      Parameters

      • id: string
      • options: RotationMultiUserOptions

      Returns SecretRotation

    • Adds the single user rotation of the master password to this cluster. See Single user rotation strategy

      Parameters

      • Optionaloptions: RotationSingleUserOptions

      Returns SecretRotation

    • Apply the given removal policy to this resource

      The Removal Policy controls what happens to this resource when it stops being managed by CloudFormation, either because you've removed it from the CDK application or because you've made a change that requires the resource to be replaced.

      The resource can be deleted (RemovalPolicy.DESTROY), or left in your AWS account for data recovery and cleanup later (RemovalPolicy.RETAIN).

      Parameters

      • policy: RemovalPolicy

      Returns void

    • Renders the secret attachment target specifications.

      Returns SecretAttachmentTargetProps

    • Returns string

    • Returns an environment-sensitive token that should be used for the resource's "ARN" attribute (e.g. bucket.bucketArn).

      Normally, this token will resolve to arnAttr, but if the resource is referenced across environments, arnComponents will be used to synthesize a concrete ARN with the resource's physical name. Make sure to reference this.physicalName in arnComponents.

      Parameters

      • arnAttr: string

        The CFN attribute which resolves to the ARN of the resource. Commonly it will be called "Arn" (e.g. resource.attrArn), but sometimes it's the CFN resource's ref.

      • arnComponents: ArnComponents

        The format of the ARN of this resource. You must reference this.physicalName somewhere within the ARN in order for cross-environment references to work.

      Returns string

    • Returns an environment-sensitive token that should be used for the resource's "name" attribute (e.g. bucket.bucketName).

      Normally, this token will resolve to nameAttr, but if the resource is referenced across environments, it will be resolved to this.physicalName, which will be a concrete name.

      Parameters

      • nameAttr: string

        The CFN attribute which resolves to the resource's name. Commonly this is the resource's ref.

      Returns string

    • Grant the given identity connection access to the Cluster.

      Parameters

      • grantee: IGrantable

        the Principal to grant the permissions to

      • dbUser: string

        the name of the database user to allow connecting

      Returns Grant

    • Grant the given identity to access the Data API.

      Parameters

      • grantee: IGrantable

      Returns Grant

    • Return the given named metric for this DBCluster

      Parameters

      • metricName: string
      • Optionalprops: MetricOptions

      Returns Metric

    • This value is represented as a percentage. It's calculated as the value of the ServerlessDatabaseCapacity metric divided by the maximum ACU value of the DB cluster.

      If this metric approaches a value of 100.0, the DB instance has scaled up as high as it can. Consider increasing the maximum ACU setting for the cluster.

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The percentage of CPU utilization.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The number of database connections in use.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The average number of deadlocks in the database per second.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The amount of time that the instance has been running, in seconds.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The amount of available random access memory, in bytes.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The amount of local storage available, in bytes.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The amount of network throughput received from clients by each instance, in bytes per second.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The amount of network throughput both received from and transmitted to clients by each instance, in bytes per second.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The amount of network throughput sent to clients by each instance, in bytes per second.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • As a cluster-level metric, it represents the average of the ServerlessDatabaseCapacity values of all the Aurora Serverless v2 DB instances in the cluster.

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The total amount of backup storage in bytes consumed by all Aurora snapshots outside its backup retention window.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The total amount of backup storage in bytes for which you are billed.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The amount of storage used by your Aurora DB instance, in bytes.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The number of billed read I/O operations from a cluster volume, reported at 5-minute intervals.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • The number of write disk I/O operations to the cluster volume, reported at 5-minute intervals.

      Average over 5 minutes

      Parameters

      • Optionalprops: MetricOptions

      Returns Metric

    • Returns a string representation of this construct.

      Returns string

    • Import an existing DatabaseCluster from properties

      Parameters

      • scope: Construct
      • id: string
      • attrs: DatabaseClusterAttributes

      Returns IDatabaseCluster

    • Lookup an existing DatabaseCluster using clusterIdentifier.

      Parameters

      • scope: Construct
      • id: string
      • options: DatabaseClusterLookupOptions

      Returns IDatabaseCluster

    • Checks if x is a construct.

      Use this method instead of instanceof to properly detect Construct instances, even when the construct library is symlinked.

      Explanation: in JavaScript, multiple copies of the constructs library on disk are seen as independent, completely different libraries. As a consequence, the class Construct in each copy of the constructs library is seen as a different class, and an instance of one class will not test as instanceof the other class. npm install will not create installations like this, but users may manually symlink construct libraries together or use a monorepo tool: in those cases, multiple copies of the constructs library can be accidentally installed, and instanceof will behave unpredictably. It is safest to avoid using instanceof, and using this type-testing method instead.

      Parameters

      • x: any

        Any object

      Returns x is Construct

      true if x is an object created from a class which extends Construct.

    • Returns true if the construct was created by CDK, and false otherwise

      Parameters

      • construct: IConstruct

      Returns boolean

    • Check whether the given construct is a Resource

      Parameters

      • construct: IConstruct

      Returns construct is Resource