本文整理匯總了Golang中github.com/aws/aws-sdk-go/service/rds.CreateDBInstanceInput.KmsKeyId方法的典型用法代碼示例。如果您正苦於以下問題:Golang CreateDBInstanceInput.KmsKeyId方法的具體用法?Golang CreateDBInstanceInput.KmsKeyId怎麽用?Golang CreateDBInstanceInput.KmsKeyId使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/aws/aws-sdk-go/service/rds.CreateDBInstanceInput
的用法示例。
在下文中一共展示了CreateDBInstanceInput.KmsKeyId方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: resourceAwsDbInstanceCreate
//.........這裏部分代碼省略.........
if attr := d.Get("vpc_security_group_ids").(*schema.Set); attr.Len() > 0 {
var s []*string
for _, v := range attr.List() {
s = append(s, aws.String(v.(string)))
}
opts.VpcSecurityGroupIds = s
}
if attr := d.Get("security_group_names").(*schema.Set); attr.Len() > 0 {
var s []*string
for _, v := range attr.List() {
s = append(s, aws.String(v.(string)))
}
opts.DBSecurityGroups = s
}
if attr, ok := d.GetOk("storage_type"); ok {
opts.StorageType = aws.String(attr.(string))
}
if attr, ok := d.GetOk("db_subnet_group_name"); ok {
opts.DBSubnetGroupName = aws.String(attr.(string))
}
if attr, ok := d.GetOk("iops"); ok {
opts.Iops = aws.Int64(int64(attr.(int)))
}
if attr, ok := d.GetOk("port"); ok {
opts.Port = aws.Int64(int64(attr.(int)))
}
if attr, ok := d.GetOk("availability_zone"); ok {
opts.AvailabilityZone = aws.String(attr.(string))
}
if attr, ok := d.GetOk("publicly_accessible"); ok {
opts.PubliclyAccessible = aws.Bool(attr.(bool))
}
if attr, ok := d.GetOk("monitoring_role_arn"); ok {
opts.MonitoringRoleArn = aws.String(attr.(string))
}
if attr, ok := d.GetOk("monitoring_interval"); ok {
opts.MonitoringInterval = aws.Int64(int64(attr.(int)))
}
if attr, ok := d.GetOk("option_group_name"); ok {
opts.OptionGroupName = aws.String(attr.(string))
}
if attr, ok := d.GetOk("kms_key_id"); ok {
opts.KmsKeyId = aws.String(attr.(string))
}
log.Printf("[DEBUG] DB Instance create configuration: %#v", opts)
var err error
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
_, err = conn.CreateDBInstance(&opts)
if err != nil {
if awsErr, ok := err.(awserr.Error); ok {
if awsErr.Code() == "InvalidParameterValue" && strings.Contains(awsErr.Message(), "ENHANCED_MONITORING") {
return resource.RetryableError(awsErr)
}
}
return resource.NonRetryableError(err)
}
return nil
})
if err != nil {
return fmt.Errorf("Error creating DB Instance: %s", err)
}
}
d.SetId(d.Get("identifier").(string))
log.Printf("[INFO] DB Instance ID: %s", d.Id())
log.Println(
"[INFO] Waiting for DB Instance to be available")
stateConf := &resource.StateChangeConf{
Pending: []string{"creating", "backing-up", "modifying", "resetting-master-credentials",
"maintenance", "renaming", "rebooting", "upgrading"},
Target: []string{"available"},
Refresh: resourceAwsDbInstanceStateRefreshFunc(d, meta),
Timeout: 40 * time.Minute,
MinTimeout: 10 * time.Second,
Delay: 30 * time.Second, // Wait 30 secs before starting
}
// Wait, catching any errors
_, err := stateConf.WaitForState()
if err != nil {
return err
}
return resourceAwsDbInstanceRead(d, meta)
}
示例2:
Context("when has EngineVersion", func() {
BeforeEach(func() {
dbInstanceDetails.EngineVersion = "1.2.3"
createDBInstanceInput.EngineVersion = aws.String("1.2.3")
})
It("does not return error", func() {
err := rdsDBInstance.Create(dbInstanceIdentifier, dbInstanceDetails)
Expect(err).ToNot(HaveOccurred())
})
})
Context("when has KmsKeyID", func() {
BeforeEach(func() {
dbInstanceDetails.KmsKeyID = "test-kms-key-id"
createDBInstanceInput.KmsKeyId = aws.String("test-kms-key-id")
})
It("does not return error", func() {
err := rdsDBInstance.Create(dbInstanceIdentifier, dbInstanceDetails)
Expect(err).ToNot(HaveOccurred())
})
})
Context("when has MasterUsername", func() {
BeforeEach(func() {
dbInstanceDetails.MasterUsername = "test-master-username"
createDBInstanceInput.MasterUsername = aws.String("test-master-username")
})
It("does not return error", func() {