cdk-aurora-globaldatabase is an AWS CDK construct library that provides Cross Region Create Global Aurora RDS Databases.
Project description
cdk-aurora-globaldatabase
cdk-aurora-globaldatabase
is an AWS CDK construct library that allows you to create Amazon Aurora Global Databases with AWS CDK in Typescript or Python.
Why
Amazon Aurora Global Databases is designed for multi-regional Amazon Aurora Database clusters that span across different AWS regions. Due to the lack of native cloudformation support, it has been very challenging to build with cloudformation or AWS CDK with the upstream aws-rds
construct.
cdk-aurora-globaldatabase
aims to offload the heavy-lifting and helps you provision and deploy cross-regional Amazon Aurora Global Databases simply with just a few CDK statements.
Now Try It !!!
Sample for Mysql
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
from ..index import GolbalAuroraRDSMaster, InstanceTypeEnum, GolbalAuroraRDSSlaveInfra
from aws_cdk.core import App, Stack, CfnOutput
import aws_cdk.aws_ec2 as ec2
# new app .
mock_app = App()
# setting two region env config .
env_singapro = {"account": process.env.CDK_DEFAULT_ACCOUNT, "region": "ap-southeast-1"}
env_tokyo = {"account": process.env.CDK_DEFAULT_ACCOUNT, "region": "ap-northeast-1"}
# create stack main .
stack_m = Stack(mock_app, "testing-stackM", env=env_tokyo)
vpc_public = ec2.Vpc(stack_m, "defaultVpc",
nat_gateways=0,
max_azs=3,
subnet_configuration=[SubnetConfiguration(
cidr_mask=26,
name="masterVPC2",
subnet_type=ec2.SubnetType.PUBLIC
)]
)
globaldb_m = GolbalAuroraRDSMaster(stack_m, "golbalAuroraRDSMaster",
instance_type=InstanceTypeEnum.R5_LARGE,
vpc=vpc_public,
rds_password="1qaz2wsx"
)
globaldb_m.rds_cluster.connections.allow_default_port_from(ec2.Peer.ipv4(f"{process.env.MYIP}/32"))
# create stack slave infra or you can give your subnet group.
stack_s = Stack(mock_app, "testing-stackS", env=env_singapro)
vpc_public2 = ec2.Vpc(stack_s, "defaultVpc2",
nat_gateways=0,
max_azs=3,
subnet_configuration=[SubnetConfiguration(
cidr_mask=26,
name="secondVPC2",
subnet_type=ec2.SubnetType.PUBLIC
)]
)
globaldb_s = GolbalAuroraRDSSlaveInfra(stack_s, "slaveregion", vpc=vpc_public2, subnet_type=ec2.SubnetType.PUBLIC)
# so we need to wait stack slave created first .
stack_m.add_dependency(stack_s)
CfnOutput(stack_m, "password", value=globaldb_m.rds_password)
# add second region cluster
globaldb_m.add_regional_cluster(stack_m, "addregionalrds",
region="ap-southeast-1",
db_subnet_group_name=globaldb_s.db_subnet_group.db_subnet_group_name
)
Sample for Postgres
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
from ..index import GolbalAuroraRDSMaster, InstanceTypeEnum, GolbalAuroraRDSSlaveInfra
from aws_cdk.core import App, Stack, CfnOutput
import aws_cdk.aws_ec2 as ec2
import aws_cdk.aws_rds as _rds
mock_app = App()
env_singapro = {"account": process.env.CDK_DEFAULT_ACCOUNT, "region": "ap-southeast-1"}
env_tokyo = {"account": process.env.CDK_DEFAULT_ACCOUNT, "region": "ap-northeast-1"}
stack_m = Stack(mock_app, "testing-stackM", env=env_tokyo)
vpc_public = ec2.Vpc(stack_m, "defaultVpc",
nat_gateways=0,
max_azs=3,
subnet_configuration=[SubnetConfiguration(
cidr_mask=26,
name="masterVPC2",
subnet_type=ec2.SubnetType.PUBLIC
)]
)
# Note if you use postgres , need to give the same value in engineVersion and dbClusterpPG's engine .
globaldb_m = GolbalAuroraRDSMaster(stack_m, "golbalAuroraRDSMaster",
instance_type=InstanceTypeEnum.R5_LARGE,
vpc=vpc_public,
rds_password="1qaz2wsx",
engine_version=_rds.DatabaseClusterEngine.aurora_postgres(
version=_rds.AuroraPostgresEngineVersion.VER_11_7
),
db_clusterp_pG=_rds.ParameterGroup(stack_m, "dbClusterparametergroup",
engine=_rds.DatabaseClusterEngine.aurora_postgres(
version=_rds.AuroraPostgresEngineVersion.VER_11_7
),
parameters={
"rds.force_ssl": "1",
"rds.log_retention_period": "10080",
"auto_explain.log_min_duration": "5000",
"auto_explain.log_verbose": "1",
"timezone": "UTC+8",
"shared_preload_libraries": "auto_explain,pg_stat_statements,pg_hint_plan,pgaudit",
"log_connections": "1",
"log_statement": "ddl",
"log_disconnections": "1",
"log_lock_waits": "1",
"log_min_duration_statement": "5000",
"log_rotation_age": "1440",
"log_rotation_size": "102400",
"random_page_cost": "1",
"track_activity_query_size": "16384",
"idle_in_transaction_session_timeout": "7200000"
}
)
)
globaldb_m.rds_cluster.connections.allow_default_port_from(ec2.Peer.ipv4(f"{process.env.MYIP}/32"))
stack_s = Stack(mock_app, "testing-stackS", env=env_singapro)
vpc_public2 = ec2.Vpc(stack_s, "defaultVpc2",
nat_gateways=0,
max_azs=3,
subnet_configuration=[SubnetConfiguration(
cidr_mask=26,
name="secondVPC2",
subnet_type=ec2.SubnetType.PUBLIC
)]
)
globaldb_s = GolbalAuroraRDSSlaveInfra(stack_s, "slaveregion",
vpc=vpc_public2, subnet_type=ec2.SubnetType.PUBLIC
)
stack_m.add_dependency(stack_s)
CfnOutput(stack_m, "password", value=globaldb_m.rds_password)
# add second region cluster
globaldb_m.add_regional_cluster(stack_m, "addregionalrds",
region="ap-southeast-1",
db_subnet_group_name=globaldb_s.db_subnet_group.db_subnet_group_name
)
To deploy
cdk deploy
To destroy
cdk destroy
:clap: Supporters
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file cdk-aurora-globaldatabase-0.1.23.tar.gz
.
File metadata
- Download URL: cdk-aurora-globaldatabase-0.1.23.tar.gz
- Upload date:
- Size: 54.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.7.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5f7f5fffd9f7a018de813596f928a0c6acc5013ebc4e5c2760f04fcfdaa1ac2e |
|
MD5 | 6c3733422d171d47b19ed334a1ba53f9 |
|
BLAKE2b-256 | c091f9e35bd424b4748e151f81a823a5b908a62e496f81ea9a1f672d7b28e169 |
File details
Details for the file cdk_aurora_globaldatabase-0.1.23-py3-none-any.whl
.
File metadata
- Download URL: cdk_aurora_globaldatabase-0.1.23-py3-none-any.whl
- Upload date:
- Size: 52.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.7.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6d149887949c8689e5a95c790b643a91818349330f58ea6c83c70c8a10766594 |
|
MD5 | 79e7368a676ea112c996aae44f547448 |
|
BLAKE2b-256 | 8366bded6849296f27b274d69e55631f4959b913240fa7e2d3aa0200c971e609 |