Tagging Amazon RDS resources
An Amazon RDS tag is a name-value pair that you define and associate with an Amazon RDS resource such as a DB instance or DB snapshot. The name is referred to as the key. Optionally, you can supply a value for the key.
You can use the AWS Management Console, the AWS CLI, or the Amazon RDS API to add, list, and delete tags on Amazon RDS resources. When using the CLI or API, make sure to provide the Amazon Resource Name (ARN) for the RDS resource to work with. For more information about constructing an ARN, see Constructing an ARN for Amazon RDS.
You can use tags to add metadata to your Amazon RDS resources. You can use the tags to add your own notations about database instances, snapshots, Aurora clusters, and so on. Doing so can help you to document your Amazon RDS resources. You can also use the tags with automated maintenance procedures.
In particular, you can use these tags with IAM policies. You can use them to manage access to Amazon RDS resources and to control what actions can be applied to those resources. You can also use these tags to track costs by grouping expenses for similarly tagged resources.
You can tag the following Amazon RDS resources:
- DB instances 
- DB clusters 
- Aurora global clusters 
- DB cluster endpoints 
- Read replicas 
- DB snapshots 
- DB cluster snapshots 
- Reserved DB instances 
- Event subscriptions 
- DB option groups 
- DB parameter groups 
- DB cluster parameter groups 
- DB subnet groups 
- RDS Proxies 
- RDS Proxy endpoints 
- Blue/green deployments 
- Zero-ETL integrations 
Note
When you tag a DB instance, Amazon RDS automatically applies those tags to the associated Performance Insights resources. Currently, you can't tag RDS Proxies and RDS Proxy endpoints by using the AWS Management Console.
Topics
Why use Amazon RDS resource tags?
You can use tags to do the following:
- 
        Categorize your RDS resources by application, project, department, environment, and so on. For example, you could use a tag key to define a category, where the tag value is an item in this category. You might create the tag environment=prod. Or you might define a tag key ofprojectand a tag value ofSalix, which indicates that an Amazon RDS resource is assigned to the Salix project.
- 
        Automate resource management tasks. For example, you could create a maintenance window for instances tagged environment=prodthat differs from the window for instances taggedenvironment=test. You could also configure automatic DB snapshots for instances taggedenvironment=prod.
- 
        Control access to RDS resources within an IAM policy. You can do this by using the global aws:ResourceTag/condition key. For example, a policy might allow only users in thetag-keyDBAdmingroup to modify DB instances tagged withenvironment=prod. For information about managing access to tagged resources with IAM policies, see Identity and access management for Amazon RDS and Controlling access to AWS resources in the AWS Identity and Access Management User Guide.
- 
        Monitor resources based on a tag. For example, you can create an Amazon CloudWatch dashboard for DB instances tagged with environment=prod.
- 
        Track costs by grouping expenses for similarly tagged resources. For example, if you tag RDS resources associated with the Salix project with project=Salix, you can generate cost reports for and allocate expenses to this project. For more information, see How AWS billing works with tags in Amazon RDS.
How Amazon RDS resource tags work
AWS doesn't apply any semantic meaning to your tags. Tags are interpreted strictly as character strings.
Topics
Tag sets in Amazon RDS
Every Amazon RDS resource has a container called a tag set. The container includes all the tags that are assigned to the resource. A resource has exactly one tag set.
A tag set contains 0—50 tags. If you add a tag to an RDS resource with the same key as an existing resource tag, the new value overwrites the old.
Tag structure in Amazon RDS
The structure of an RDS tag is as follows:
- Tag key
- 
            The key is the required name of the tag. The string value must be 1—128 Unicode characters in length and cannot be prefixed with aws:orrds:. The string can contain only the set of Unicode letters, digits, whitespace,_,.,:,/,=,+,-, and@. The Java regex is"^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-@]*)$". Tag keys are case-sensitive. Thus, the keysprojectandProjectare distinct.A key is unique to a tag set. For example, you cannot have a key-pair in a tag set with the key the same but with different values, such as project=Trinityandproject=Xanadu.
- Tag value
- 
            The value is an optional string value of the tag. The string value must be 1—256 Unicode characters in length. The string can contain only the set of Unicode letters, digits, whitespace, _,.,:,/,=,+,-, and@. The Java regex is"^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-@]*)$". Tag values are case-sensitive. Thus, the valuesprodandProdare distinct.Values don't need to be unique in a tag set and can be null. For example, you can have a key-value pair in a tag set of project=Trinityandcost-center=Trinity.
Amazon RDS resources eligible for tagging
You can tag the following Amazon RDS resources:
- 
          DB instances 
- 
          DB clusters 
- 
          DB cluster endpoints 
- 
          Read replicas 
- 
          DB snapshots 
- 
          DB cluster snapshots 
- 
          Reserved DB instances 
- 
          Event subscriptions 
- 
          DB option groups 
- 
          DB parameter groups 
- 
          DB cluster parameter groups 
- 
          DB subnet groups 
- 
          RDS Proxies 
- 
          RDS Proxy endpoints NoteCurrently, you can't tag RDS Proxies and RDS Proxy endpoints by using the AWS Management Console. 
- 
          Blue/green deployments 
- 
          Zero-ETL integrations (preview) 
How AWS billing works with tags in Amazon RDS
Use tags to organize your AWS bill to reflect your own cost structure. To do this, sign up to get your AWS account bill with tag key values included. Then, to see the cost of combined resources, organize your billing information according to resources with the same tag key values. For example, you can tag several resources with a specific application name, and then organize your billing information to see the total cost of that application across several services. For more information, see Using Cost Allocation Tags in the AWS Billing User Guide.
How cost allocation tags work with DB snapshots
You can add a tag to a DB snapshot. However, your bill won't reflect this grouping. For cost allocation tags to apply to DB snapshots, the following conditions must be met:
- 
            The tags must be attached to the parent DB instance. 
- 
            The parent DB instance must exist in the same AWS account as the DB snapshot. 
- 
            The parent DB instance must exist in the same AWS Region as the DB snapshot. 
DB snapshots are considered orphaned if they don't exist in the same Region as the parent DB instance, or if the parent DB instance is deleted. Orphaned DB snapshots don't support cost allocation tags. Costs for orphaned snapshots are aggregated in a single untagged line item. Cross-account DB snapshots aren't considered orphaned when the following conditions are met:
- 
            They exist in the same Region as the parent DB instance. 
- 
            The parent DB instance is owned by the source account. NoteIf the parent DB instance is owned by a different account, cost allocation tags don't apply to cross-account snapshots in the destination account. 
Best practices for tagging Amazon RDS resources
When you use tags, we recommend that you adhere to the following best practices:
- 
        Document conventions for tag use that are followed by all teams in your organization. In particular, ensure the names are both descriptive and consistent. For example, standardize on the format environment:prodrather than tagging some resources withenv:production.ImportantDo not store personally identifiable information (PII) or other confidential or sensitive information in tags. 
- 
        Automate tagging to ensure consistency. For example, you can use the following techniques: - 
            Include tags in an AWS CloudFormation template. When you create resources with the template, the resources are tagged automatically. 
- 
            Define and apply tags using AWS Lambda functions. 
- 
            Create an SSM document that includes steps to add tags to your RDS resources. 
 
- 
            
- 
        Use tags only when necessary. You can add up to 50 tags for a single RDS resource, but a best practice is to avoid unnecessary tag proliferation and complexity. 
- 
        Review tags periodically for relevance and accuracy. Remove or modify outdated tags as needed. 
- 
        Consider creating tags with the AWS Tag Editor in the AWS Management Console. You can use the Tag Editor to add tags to multiple supported AWS resources, including RDS resources, at the same time. For more information, see Tag Editor in the AWS Resource Groups User Guide. 
Copying tags to DB snapshots
When you create or restore a DB instance, you can specify that the tags from the DB instance are copied to snapshots of the DB instance. Copying tags ensures that the metadata for the DB snapshots matches that of the source DB instance. It also ensures that any access policies for the DB snapshots also match those of the source DB instance.
You can specify that tags are copied to DB snapshots for the following actions:
- Creating a DB instance 
- Restoring a DB instance 
- Creating a read replica 
- Copying a DB snapshot 
To copy tags for the preceding actions, choose Copy tags to snapshots
      in the AWS Management Console, or specify --copy-tags-to-snapshot in the AWS CLI. While copying a DB snapshot, you can only copy the associated tags if copying the DB snapshot 
      in the same account. You can't copy tags when copying a DB snapshot across accounts.
In most cases, tags aren't copied by default. However, when you restore a DB instance from a DB snapshot, RDS checks whether you specify new tags. If yes, the new tags are added to the restored DB instance. If there are no new tags, and the DB snapshot is in the same account as the source DB instance, RDS adds the tags from the source DB instance at the time of snapshot creation to the restored DB instance. RDS does not add tags from the source DB instance if the DB snapshot is copied to and restored in a different account.
To prevent tags from source DB instances from being added to restored DB instances, we recommend that you specify new tags when restoring a DB instance.
Note
In some cases, you might include a value for the --tags parameter of the create-db-snapshot AWS CLI command. Or you might supply at least
                one tag to the CreateDBSnapshot API operation. In these cases,
                RDS doesn't copy tags from the source DB instance to the new DB snapshot. This functionality applies even if the source
                DB instance has the --copy-tags-to-snapshot (CopyTagsToSnapshot) option turned on.
If you take this approach, you can create a copy of a DB instance from a DB snapshot.
        This approach avoids adding tags that don't apply to the new DB instance. You create your DB
        snapshot using the AWS CLI create-db-snapshot command (or the
          CreateDBSnapshot RDS API operation). After you create your DB snapshot, you
        can add tags as described later in this topic.
Adding and deleting tags in Amazon RDS
You can do the following:
- 
          Create tags when you create a resource, for example, when you run the AWS CLI command create-db-instance.
- 
          Add tags to an existing resource using the command add-tags-to-resource.
- 
          List tags associated with a specific resource using the command list-tags-for-resource.
- 
          Update tags using the command add-tags-to-resource.
- 
          Remove tags from a resource using the command remove-tags-from-resource.
The following procedures show how you can perform typical tagging operations on resources related to DB instances. Note that tags are cached for authorization purposes. For this reason, when you add or update tags on Amazon RDS resources, several minutes can pass before the modifications are available.
The process to tag an Amazon RDS resource is similar for all resources. The following procedure shows how to tag an Amazon RDS DB instance.
To add a tag to a DB instance
- 
              Sign in to the AWS Management Console and open the Amazon RDS console at https://console.aws.amazon.com/rds/ . 
- 
              In the navigation pane, choose Databases. NoteTo filter the list of DB instances in the Databases pane, enter a text string for Filter databases. Only DB instances that contain the string appear. 
- 
              Choose the name of the DB instance that you want to tag to show its details. 
- 
              In the details section, scroll down to the Tags section. 
- 
              Choose Add. The Add tags window appears.   
- 
              Enter a value for Tag key and Value. 
- 
              To add another tag, you can choose Add another Tag and enter a value for its Tag key and Value. Repeat this step as many times as necessary. 
- 
              Choose Add. 
To delete a tag from a DB instance
- 
              Sign in to the AWS Management Console and open the Amazon RDS console at https://console.aws.amazon.com/rds/ . 
- 
              In the navigation pane, choose Databases. NoteTo filter the list of DB instances in the Databases pane, enter a text string in the Filter databases box. Only DB instances that contain the string appear. 
- 
              Choose the name of the DB instance to show its details. 
- 
              In the details section, scroll down to the Tags section. 
- Choose the tag you want to delete.   
- 
              Choose Delete, and then choose Delete in the Delete tags window. 
You can add, list, or remove tags for a DB instance using the AWS CLI.
- To add one or more tags to an Amazon RDS resource, use the AWS CLI command - add-tags-to-resource.
- To list the tags on an Amazon RDS resource, use the AWS CLI command - list-tags-for-resource.
- To remove one or more tags from an Amazon RDS resource, use the AWS CLI command - remove-tags-from-resource.
To learn more about how to construct the required ARN, see Constructing an ARN for Amazon RDS.
You can add, list, or remove tags for a DB instance using the Amazon RDS API.
- To add a tag to an Amazon RDS resource, use the - AddTagsToResourceoperation.
- To list tags that are assigned to an Amazon RDS resource, use the - ListTagsForResource.
- To remove tags from an Amazon RDS resource, use the - RemoveTagsFromResourceoperation.
To learn more about how to construct the required ARN, see Constructing an ARN for Amazon RDS.
When working with XML using the Amazon RDS API, tags use the following schema:
<Tagging> <TagSet> <Tag> <Key>Project</Key> <Value>Trinity</Value> </Tag> <Tag> <Key>User</Key> <Value>Jones</Value> </Tag> </TagSet> </Tagging>
The following table provides a list of the allowed XML tags and their characteristics.
            Values for Key and Value are case-sensitive. For example,
            project=Trinity and PROJECT=Trinity are distinct tags. 
| Tagging element | Description | 
|---|---|
| TagSet | A tag set is a container for all tags assigned to an Amazon RDS resource. There can be only one tag set per resource. You work with a TagSet only through the Amazon RDS API. | 
| Tag | A tag is a user-defined key-value pair. There can be from 1 to 50 tags in a tag set. | 
| Key | A key is the required name of the tag. For restrictions, see Tag structure in Amazon RDS. The string value can be from 1 to 128 Unicode characters in length and
                      cannot be prefixed with  Keys must be unique to a tag set. For example, you cannot have a key-pair in a tag set with the key the same but with different values, such as project/Trinity and project/Xanadu. | 
| Value | A value is the optional value of the tag. For restrictions, see Tag structure in Amazon RDS. The string value can be from 1 to 256 Unicode characters in length and
                      cannot be prefixed with  Values do not have to be unique in a tag set and can be null. For example, you can have a key-value pair in a tag set of project/Trinity and cost-center/Trinity. |