Terraform module which create a MySql database based on Alibaba Cloud RDS Service.
terraform-alicloud-rds-mysql
English | 简体中文
Terraform module which creates RDS-MySQL database and sets CMS alarm for it on Alibaba Cloud.
These types of resources are supported:
- Alicloud_db_instance
- Alicloud_db_account
- Alicloud_db_database
- Alicloud_db_backup_policy
- Alicloud_cms_alarm
This module requires Terraform 0.12 and Terraform Provider Alicloud 1.56.0+.
For new instance
module "mysql" {
source = "terraform-alicloud-modules/rds-mysql/alicloud"
region = "cn-hangzhou"
profile = "Your-Profile-Name"
###############
#Rds Instance#
###############
engine_version = "5.7"
connection_prefix = "developmentabc"
vswitch_id = "vsw-bp1tili2u5kxxxxxx"
instance_storage = 20
period = 1
instance_type = "rds.mysql.s2.large"
instance_name = "myDBInstance"
instance_charge_type = "Postpaid"
security_ips = [
"11.193.54.0/24",
"121.43.18.0/24"
]
tags = {
Created = "Terraform"
Environment = "dev"
}
###############
#backup_policy#
###############
preferred_backup_period = ["Monday", "Wednesday"]
preferred_backup_time = "00:00Z-01:00Z"
backup_retention_period = 7
log_backup_retention_period = 7
enable_backup_log = true
###########
#databases#
###########
account_name = "account_name1"
account_password = "1234abc"
account_type = "Normal"
account_privilege = "ReadWrite"
databases = [
{
name = "dbuserv1"
character_set = "utf8"
description = "db1"
},
{
name = "dbuserv2"
character_set = "utf8"
description = "db2"
},
]
#############
# cms_alarm
#############
alarm_rule_name = "CmsAlarmForMysql"
alarm_rule_statistics = "Average"
alarm_rule_period = 300
alarm_rule_operator = "<="
alarm_rule_threshold = 35
alarm_rule_triggered_count = 2
alarm_rule_contact_groups = ["MySQL", "AccCms"]
}
For existing instance
module "mysql" {
source = "terraform-alicloud-modules/rds-mysql/alicloud"
region = "cn-beijing"
profile = "Your-Profile-Name"
#################
# Rds Instance
#################
existing_instance_id="rm-2ze9tmt47xxxxxxx"
################
# Backup Policy
################
create_backup_policy =true
preferred_backup_period = ["Monday", "Wednesday"]
preferred_backup_time = "00:00Z-01:00Z"
backup_retention_period = 7
log_backup_retention_period = 7
enable_backup_log = true
##############
# connection
##############
allocate_public_connection = false
connection_prefix = "mysqlconnection"
###########
#databases#
###########
account_privilege = "ReadWrite"
databases = [
{
name = "mysqldb"
character_set = "utf8"
description = "db1"
}
]
#################
# Rds Database account
#################
account_name = "account_name"
account_password = "yourpassword123"
tags = {
Env = "Private"
Location = "Secret"
}
#############
# cms_alarm
#############
alarm_rule_name = "CmsAlarmForMysql"
alarm_rule_statistics = "Average"
alarm_rule_period = 300
alarm_rule_operator = "<="
alarm_rule_threshold = 35
alarm_rule_triggered_count = 2
alarm_rule_contact_groups = ["MySQL", "AccCms"]
enable_alarm_rule=true
}
- database
- mysql-5.5-high-availability
- mysql-5.6-enterprise
- mysql-5.6-high-availability
- mysql-5.7-basic
- mysql-5.7-enterprise
- mysql-5.7-high-availability
- mysql-8.0-basic
- mysql-8.0-enterprise
- mysql-8.0-high-availability
- This module using AccessKey and SecretKey are from
profile
andshared_credentials_file
. If you have not set them yet, please install aliyun-cli and configure it.
If you have any problems when using this module, please opening a provider issue and let us know.
Note: There does not recommend to open an issue on this repo.
Created and maintained by Yi Jincheng([email protected]) and He Guimin(@xiaozhu36, [email protected])
Apache 2 Licensed. See LICENSE for full details.