Class Database


  • public class Database
    extends com.pulumi.resources.CustomResource
    Provides a Lightsail Database. Amazon Lightsail is a service to provide easy virtual private servers with custom software already setup. See [What is Amazon Lightsail?](https://lightsail.aws.amazon.com/ls/docs/getting-started/article/what-is-amazon-lightsail) for more information. > **Note:** Lightsail is currently only supported in a limited number of AWS Regions, please see ["Regions and Availability Zones"](https://aws.amazon.com/about-aws/global-infrastructure/regional-product-services/) for more details ## Example Usage ### Basic mysql blueprint <!--Start PulumiCodeChooser -->
     
     package generated_program;
     
     import com.pulumi.Context;
     import com.pulumi.Pulumi;
     import com.pulumi.core.Output;
     import com.pulumi.aws.lightsail.Database;
     import com.pulumi.aws.lightsail.DatabaseArgs;
     import java.util.List;
     import java.util.ArrayList;
     import java.util.Map;
     import java.io.File;
     import java.nio.file.Files;
     import java.nio.file.Paths;
     
     public class App {
         public static void main(String[] args) {
             Pulumi.run(App::stack);
         }
     
         public static void stack(Context ctx) {
             var test = new Database("test", DatabaseArgs.builder()
                 .relationalDatabaseName("test")
                 .availabilityZone("us-east-1a")
                 .masterDatabaseName("testdatabasename")
                 .masterPassword("testdatabasepassword")
                 .masterUsername("test")
                 .blueprintId("mysql_8_0")
                 .bundleId("micro_1_0")
                 .build());
     
         }
     }
     
     
    <!--End PulumiCodeChooser --> ### Basic postrgres blueprint <!--Start PulumiCodeChooser -->
     
     package generated_program;
     
     import com.pulumi.Context;
     import com.pulumi.Pulumi;
     import com.pulumi.core.Output;
     import com.pulumi.aws.lightsail.Database;
     import com.pulumi.aws.lightsail.DatabaseArgs;
     import java.util.List;
     import java.util.ArrayList;
     import java.util.Map;
     import java.io.File;
     import java.nio.file.Files;
     import java.nio.file.Paths;
     
     public class App {
         public static void main(String[] args) {
             Pulumi.run(App::stack);
         }
     
         public static void stack(Context ctx) {
             var test = new Database("test", DatabaseArgs.builder()
                 .relationalDatabaseName("test")
                 .availabilityZone("us-east-1a")
                 .masterDatabaseName("testdatabasename")
                 .masterPassword("testdatabasepassword")
                 .masterUsername("test")
                 .blueprintId("postgres_12")
                 .bundleId("micro_1_0")
                 .build());
     
         }
     }
     
     
    <!--End PulumiCodeChooser --> ### Custom backup and maintenance windows Below is an example that sets a custom backup and maintenance window. Times are specified in UTC. This example will allow daily backups to take place between 16:00 and 16:30 each day. This example also requires any maintiance tasks (anything that would cause an outage, including changing some attributes) to take place on Tuesdays between 17:00 and 17:30. An action taken against this database that would cause an outage will wait until this time window to make the requested changes. <!--Start PulumiCodeChooser -->
     
     package generated_program;
     
     import com.pulumi.Context;
     import com.pulumi.Pulumi;
     import com.pulumi.core.Output;
     import com.pulumi.aws.lightsail.Database;
     import com.pulumi.aws.lightsail.DatabaseArgs;
     import java.util.List;
     import java.util.ArrayList;
     import java.util.Map;
     import java.io.File;
     import java.nio.file.Files;
     import java.nio.file.Paths;
     
     public class App {
         public static void main(String[] args) {
             Pulumi.run(App::stack);
         }
     
         public static void stack(Context ctx) {
             var test = new Database("test", DatabaseArgs.builder()
                 .relationalDatabaseName("test")
                 .availabilityZone("us-east-1a")
                 .masterDatabaseName("testdatabasename")
                 .masterPassword("testdatabasepassword")
                 .masterUsername("test")
                 .blueprintId("postgres_12")
                 .bundleId("micro_1_0")
                 .preferredBackupWindow("16:00-16:30")
                 .preferredMaintenanceWindow("Tue:17:00-Tue:17:30")
                 .build());
     
         }
     }
     
     
    <!--End PulumiCodeChooser --> ### Final Snapshots To enable creating a final snapshot of your database on deletion, use the `final_snapshot_name` argument to provide a name to be used for the snapshot. <!--Start PulumiCodeChooser -->
     
     package generated_program;
     
     import com.pulumi.Context;
     import com.pulumi.Pulumi;
     import com.pulumi.core.Output;
     import com.pulumi.aws.lightsail.Database;
     import com.pulumi.aws.lightsail.DatabaseArgs;
     import java.util.List;
     import java.util.ArrayList;
     import java.util.Map;
     import java.io.File;
     import java.nio.file.Files;
     import java.nio.file.Paths;
     
     public class App {
         public static void main(String[] args) {
             Pulumi.run(App::stack);
         }
     
         public static void stack(Context ctx) {
             var test = new Database("test", DatabaseArgs.builder()
                 .relationalDatabaseName("test")
                 .availabilityZone("us-east-1a")
                 .masterDatabaseName("testdatabasename")
                 .masterPassword("testdatabasepassword")
                 .masterUsername("test")
                 .blueprintId("postgres_12")
                 .bundleId("micro_1_0")
                 .preferredBackupWindow("16:00-16:30")
                 .preferredMaintenanceWindow("Tue:17:00-Tue:17:30")
                 .finalSnapshotName("MyFinalSnapshot")
                 .build());
     
         }
     }
     
     
    <!--End PulumiCodeChooser --> ### Apply Immediately To enable applying changes immediately instead of waiting for a maintiance window, use the `apply_immediately` argument. <!--Start PulumiCodeChooser -->
     
     package generated_program;
     
     import com.pulumi.Context;
     import com.pulumi.Pulumi;
     import com.pulumi.core.Output;
     import com.pulumi.aws.lightsail.Database;
     import com.pulumi.aws.lightsail.DatabaseArgs;
     import java.util.List;
     import java.util.ArrayList;
     import java.util.Map;
     import java.io.File;
     import java.nio.file.Files;
     import java.nio.file.Paths;
     
     public class App {
         public static void main(String[] args) {
             Pulumi.run(App::stack);
         }
     
         public static void stack(Context ctx) {
             var test = new Database("test", DatabaseArgs.builder()
                 .relationalDatabaseName("test")
                 .availabilityZone("us-east-1a")
                 .masterDatabaseName("testdatabasename")
                 .masterPassword("testdatabasepassword")
                 .masterUsername("test")
                 .blueprintId("postgres_12")
                 .bundleId("micro_1_0")
                 .applyImmediately(true)
                 .build());
     
         }
     }
     
     
    <!--End PulumiCodeChooser --> ## Blueprint Ids A list of all available Lightsail Blueprints for Relational Databases the [aws lightsail get-relational-database-blueprints](https://docs.aws.amazon.com/cli/latest/reference/lightsail/get-relational-database-blueprints.html) aws cli command. ### Examples - `mysql_8_0` - `postgres_12` ### Prefix A Blueprint ID starts with a prefix of the engine type. ### Suffix A Blueprint ID has a sufix of the engine version. ## Bundles A list of all available Lightsail Bundles for Relational Databases the [aws lightsail get-relational-database-bundles](https://docs.aws.amazon.com/cli/latest/reference/lightsail/get-relational-database-bundles.html) aws cli command. ### Examples - `small_1_0` - `small_ha_1_0` - `large_1_0` - `large_ha_1_0` ### Prefix A Bundle ID starts with one of the below size prefixes: - `micro_` - `small_` - `medium_` - `large_` ### Infixes (Optional for HA Database) A Bundle Id can have the following infix added in order to use the HA option of the selected bundle. - `ha_` ### Suffix A Bundle ID ends with one of the following suffix: `1_0` ## Import Using `pulumi import`, import Lightsail Databases using their name. For example: ```sh $ pulumi import aws:lightsail/database:Database foo 'bar' ```
    • Nested Class Summary

      • Nested classes/interfaces inherited from class com.pulumi.resources.CustomResource

        com.pulumi.resources.CustomResource.CustomResourceInternal
      • Nested classes/interfaces inherited from class com.pulumi.resources.Resource

        com.pulumi.resources.Resource.LazyField<T extends java.lang.Object>, com.pulumi.resources.Resource.LazyFields, com.pulumi.resources.Resource.ResourceInternal
    • Field Summary

      • Fields inherited from class com.pulumi.resources.Resource

        childResources, remote
    • Constructor Summary

      Constructors 
      Constructor Description
      Database​(java.lang.String name)  
      Database​(java.lang.String name, DatabaseArgs args)  
      Database​(java.lang.String name, DatabaseArgs args, com.pulumi.resources.CustomResourceOptions options)  
    • Method Summary

      All Methods Static Methods Instance Methods Concrete Methods 
      Modifier and Type Method Description
      com.pulumi.core.Output<java.lang.Boolean> applyImmediately()  
      com.pulumi.core.Output<java.lang.String> arn()  
      com.pulumi.core.Output<java.lang.String> availabilityZone()  
      com.pulumi.core.Output<java.util.Optional<java.lang.Boolean>> backupRetentionEnabled()  
      com.pulumi.core.Output<java.lang.String> blueprintId()  
      com.pulumi.core.Output<java.lang.String> bundleId()  
      com.pulumi.core.Output<java.lang.String> caCertificateIdentifier()  
      com.pulumi.core.Output<java.lang.Integer> cpuCount()  
      com.pulumi.core.Output<java.lang.String> createdAt()  
      com.pulumi.core.Output<java.lang.Double> diskSize()  
      com.pulumi.core.Output<java.lang.String> engine()  
      com.pulumi.core.Output<java.lang.String> engineVersion()  
      com.pulumi.core.Output<java.util.Optional<java.lang.String>> finalSnapshotName()  
      static Database get​(java.lang.String name, com.pulumi.core.Output<java.lang.String> id, DatabaseState state, com.pulumi.resources.CustomResourceOptions options)
      Get an existing Host resource's state with the given name, ID, and optional extra properties used to qualify the lookup.
      com.pulumi.core.Output<java.lang.String> masterDatabaseName()  
      com.pulumi.core.Output<java.lang.String> masterEndpointAddress()  
      com.pulumi.core.Output<java.lang.Integer> masterEndpointPort()  
      com.pulumi.core.Output<java.lang.String> masterPassword()  
      com.pulumi.core.Output<java.lang.String> masterUsername()  
      com.pulumi.core.Output<java.lang.String> preferredBackupWindow()  
      com.pulumi.core.Output<java.lang.String> preferredMaintenanceWindow()  
      com.pulumi.core.Output<java.util.Optional<java.lang.Boolean>> publiclyAccessible()  
      com.pulumi.core.Output<java.lang.Double> ramSize()  
      com.pulumi.core.Output<java.lang.String> relationalDatabaseName()  
      com.pulumi.core.Output<java.lang.String> secondaryAvailabilityZone()  
      com.pulumi.core.Output<java.util.Optional<java.lang.Boolean>> skipFinalSnapshot()  
      com.pulumi.core.Output<java.lang.String> supportCode()  
      com.pulumi.core.Output<java.util.Optional<java.util.Map<java.lang.String,​java.lang.String>>> tags()  
      com.pulumi.core.Output<java.util.Map<java.lang.String,​java.lang.String>> tagsAll()  
      • Methods inherited from class com.pulumi.resources.CustomResource

        getId, id, idFuture
      • Methods inherited from class com.pulumi.resources.Resource

        getChildResources, getResourceName, getResourceType, getUrn, pulumiChildResources, pulumiResourceName, pulumiResourceType, urn
      • Methods inherited from class java.lang.Object

        clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Constructor Detail

      • Database

        public Database​(java.lang.String name)
        Parameters:
        name - The _unique_ name of the resulting resource.
      • Database

        public Database​(java.lang.String name,
                        DatabaseArgs args)
        Parameters:
        name - The _unique_ name of the resulting resource.
        args - The arguments to use to populate this resource's properties.
      • Database

        public Database​(java.lang.String name,
                        DatabaseArgs args,
                        @Nullable
                        com.pulumi.resources.CustomResourceOptions options)
        Parameters:
        name - The _unique_ name of the resulting resource.
        args - The arguments to use to populate this resource's properties.
        options - A bag of options that control this resource's behavior.
    • Method Detail

      • applyImmediately

        public com.pulumi.core.Output<java.lang.Boolean> applyImmediately()
        Returns:
        When true , applies changes immediately. When false , applies changes during the preferred maintenance window. Some changes may cause an outage.
      • arn

        public com.pulumi.core.Output<java.lang.String> arn()
        Returns:
        The ARN of the Lightsail instance (matches `id`).
      • availabilityZone

        public com.pulumi.core.Output<java.lang.String> availabilityZone()
        Returns:
        The Availability Zone in which to create your new database. Use the us-east-2a case-sensitive format.
      • backupRetentionEnabled

        public com.pulumi.core.Output<java.util.Optional<java.lang.Boolean>> backupRetentionEnabled()
        Returns:
        When true, enables automated backup retention for your database. When false, disables automated backup retention for your database. Disabling backup retention deletes all automated database backups. Before disabling this, you may want to create a snapshot of your database.
      • blueprintId

        public com.pulumi.core.Output<java.lang.String> blueprintId()
        Returns:
        The blueprint ID for your new database. A blueprint describes the major engine version of a database. You can get a list of database blueprints IDs by using the AWS CLI command: `aws lightsail get-relational-database-blueprints`
      • bundleId

        public com.pulumi.core.Output<java.lang.String> bundleId()
        Returns:
        The bundle ID for your new database. A bundle describes the performance specifications for your database (see list below). You can get a list of database bundle IDs by using the AWS CLI command: `aws lightsail get-relational-database-bundles`.
      • caCertificateIdentifier

        public com.pulumi.core.Output<java.lang.String> caCertificateIdentifier()
        Returns:
        The certificate associated with the database.
      • cpuCount

        public com.pulumi.core.Output<java.lang.Integer> cpuCount()
        Returns:
        The number of vCPUs for the database.
      • createdAt

        public com.pulumi.core.Output<java.lang.String> createdAt()
        Returns:
        The timestamp when the instance was created.
      • diskSize

        public com.pulumi.core.Output<java.lang.Double> diskSize()
        Returns:
        The size of the disk for the database.
      • engine

        public com.pulumi.core.Output<java.lang.String> engine()
        Returns:
        The database software (for example, MySQL).
      • engineVersion

        public com.pulumi.core.Output<java.lang.String> engineVersion()
        Returns:
        The database engine version (for example, 5.7.23).
      • finalSnapshotName

        public com.pulumi.core.Output<java.util.Optional<java.lang.String>> finalSnapshotName()
        Returns:
        The name of the database snapshot created if skip final snapshot is false, which is the default value for that parameter.
      • masterDatabaseName

        public com.pulumi.core.Output<java.lang.String> masterDatabaseName()
        Returns:
        The name of the master database created when the Lightsail database resource is created.
      • masterEndpointAddress

        public com.pulumi.core.Output<java.lang.String> masterEndpointAddress()
        Returns:
        The master endpoint fqdn for the database.
      • masterEndpointPort

        public com.pulumi.core.Output<java.lang.Integer> masterEndpointPort()
        Returns:
        The master endpoint network port for the database.
      • masterPassword

        public com.pulumi.core.Output<java.lang.String> masterPassword()
        Returns:
        The password for the master user of your new database. The password can include any printable ASCII character except "/", """, or "@".
      • masterUsername

        public com.pulumi.core.Output<java.lang.String> masterUsername()
        Returns:
        The master user name for your new database.
      • preferredBackupWindow

        public com.pulumi.core.Output<java.lang.String> preferredBackupWindow()
        Returns:
        The daily time range during which automated backups are created for your new database if automated backups are enabled. Must be in the hh24:mi-hh24:mi format. Example: `16:00-16:30`. Specified in Coordinated Universal Time (UTC).
      • preferredMaintenanceWindow

        public com.pulumi.core.Output<java.lang.String> preferredMaintenanceWindow()
        Returns:
        The weekly time range during which system maintenance can occur on your new database. Must be in the ddd:hh24:mi-ddd:hh24:mi format. Specified in Coordinated Universal Time (UTC). Example: `Tue:17:00-Tue:17:30`
      • publiclyAccessible

        public com.pulumi.core.Output<java.util.Optional<java.lang.Boolean>> publiclyAccessible()
        Returns:
        Specifies the accessibility options for your new database. A value of true specifies a database that is available to resources outside of your Lightsail account. A value of false specifies a database that is available only to your Lightsail resources in the same region as your database.
      • ramSize

        public com.pulumi.core.Output<java.lang.Double> ramSize()
        Returns:
        The amount of RAM in GB for the database.
      • relationalDatabaseName

        public com.pulumi.core.Output<java.lang.String> relationalDatabaseName()
        Returns:
        The name to use for your new Lightsail database resource. Names be unique within each AWS Region in your Lightsail account.
      • secondaryAvailabilityZone

        public com.pulumi.core.Output<java.lang.String> secondaryAvailabilityZone()
        Returns:
        Describes the secondary Availability Zone of a high availability database. The secondary database is used for failover support of a high availability database.
      • skipFinalSnapshot

        public com.pulumi.core.Output<java.util.Optional<java.lang.Boolean>> skipFinalSnapshot()
        Returns:
        Determines whether a final database snapshot is created before your database is deleted. If true is specified, no database snapshot is created. If false is specified, a database snapshot is created before your database is deleted. You must specify the final relational database snapshot name parameter if the skip final snapshot parameter is false.
      • supportCode

        public com.pulumi.core.Output<java.lang.String> supportCode()
        Returns:
        The support code for the database. Include this code in your email to support when you have questions about a database in Lightsail. This code enables our support team to look up your Lightsail information more easily.
      • tags

        public com.pulumi.core.Output<java.util.Optional<java.util.Map<java.lang.String,​java.lang.String>>> tags()
        Returns:
        A map of tags to assign to the resource. To create a key-only tag, use an empty string as the value.
      • tagsAll

        public com.pulumi.core.Output<java.util.Map<java.lang.String,​java.lang.String>> tagsAll()
        Returns:
        A map of tags assigned to the resource, including those inherited from the provider `default_tags` configuration block.
      • get

        public static Database get​(java.lang.String name,
                                   com.pulumi.core.Output<java.lang.String> id,
                                   @Nullable
                                   DatabaseState state,
                                   @Nullable
                                   com.pulumi.resources.CustomResourceOptions options)
        Get an existing Host resource's state with the given name, ID, and optional extra properties used to qualify the lookup.
        Parameters:
        name - The _unique_ name of the resulting resource.
        id - The _unique_ provider ID of the resource to lookup.
        state -
        options - Optional settings to control the behavior of the CustomResource.