Creating a lifecycle policy
You can only set a lifecycle policy for a repository. To find out the name of a repository, request a list of repositories in the registry.
- In the management console
, select the folder where the registry was created. - In the list of services, select Container Registry.
- Select the registry and click the row with its name.
- Select the repository and click the row with its name.
- In the left-hand panel, click
Lifecycle. - In the top-right corner, click Create.
- Set the lifecycle policy parameters:
- (Optional) Name.
- (Optional) Description.
- Status: Lifecycle policy status after its creation. We do not recommend creating an
ACTIVEpolicy right away. - Under Lifecycle policy rules, add rules:
-
Click Add.
-
Set the rule parameters:
- Tag regexp: Docker image tag for filtering. Java regular expressions are supported. For example, the
test.*regular expression retrieves all images with tags starting withtest. - Untagged: Flag indicating that the rule applies to Docker images without tags.
- Expire period, in days: Time after which the lifecycle policy may apply to the Docker image.
- Retained top: Number of Docker images that are not deleted even if they match the rule.
- (Optional) Description.
- Tag regexp: Docker image tag for filtering. Java regular expressions are supported. For example, the
-
- Click Create.
If you do not have the Yandex Cloud CLI installed yet, install and initialize it.
-
Prepare policy rules and save them to a file named
rules.json.Example of the contents of a file with rules, where:
description: Description of the policy rule.tag_regexp: Docker image tag for filtering. Java regular expressions are supported. For example, thetest.*regular expression retrieves all images with tags starting withtest.untagged: Flag indicating that the rule applies to Docker images without tags.expire_period: Time after which the lifecycle policy may apply to the Docker image. This parameter is formatted as a number and a unit of measure, such ass,m,h, ord(seconds, minutes, hours, or days).expire_periodmust be a multiple of 24 hours.retained_top: Number of Docker images that are not deleted even if they match the rule.
[ { "description": "delete prod Docker images older than 60 days but retain 20 last ones", "tag_regexp": "prod", "expire_period": "60d", "retained_top": 20 }, { "description": "delete all test Docker images except 10 last ones", "tag_regexp": "test.*", "retained_top": 10 }, { "description": "delete all untagged Docker images older than 48 hours", "untagged": true, "expire_period": "48h" } ] -
Create a lifecycle policy by running the command:
yc container repository lifecycle-policy create \ --repository-name crp3cpm16edq********/ubuntu \ --name test-policy \ --description "disabled lifecycle-policy for tests" \ --rules ./rules.jsonWhere:
-
--repository-name: Repository name. -
--rules: Path to the policy description file. -
--description(optional): Lifecycle policy description. -
--name(optional): Policy name. The naming requirements are as follows:- It must be from 2 to 63 characters long.
- It can only contain lowercase Latin letters, numbers, and hyphens.
- It must start with a letter and cannot end with a hyphen.
Note
The default policy is created disabled (
DISABLEDstatus). We do not recommend creating an active policy (--activeflag) right away.Result:
id: crp6lg1868p3******** name: test-policy repository_id: crp3cpm16edq******** ... - description: delete all untagged Docker images older than 48 hours expire_period: 172800s untagged: trueThe
expired_periodparameter value in the response is displayed in seconds. This is a technical constraint, the format will be changed. -
-
Make sure that the policy is created by running the command:
yc container repository lifecycle-policy list --repository-name crp3cpm16edq********/ubuntuWhere
repository-nameis the repository name.Result:
+----------------------+-------------+----------------------+----------+---------------------+-------------------------------+ | ID | NAME | REPOSITORY ID | STATUS | CREATED | DESCRIPTION | +----------------------+-------------+----------------------+----------+---------------------+-------------------------------+ | crp6lg1868p3******** | test-policy | crp3cpm16edq******** | DISABLED | 2020-05-28 15:05:58 | disabled lifecycle-policy for | | | | | | | tests | +----------------------+-------------+----------------------+----------+---------------------+-------------------------------+
If you do not have Terraform yet, install it and configure the Yandex Cloud provider.
-
In the configuration file, describe the parameters of the resources you want to create:
resource "yandex_container_repository_lifecycle_policy" "my_lifecycle_policy" { name = "<policy_name>" status = "<policy_status>" repository_id = "<repository_ID>" rule { description = "<rule_description>" untagged = true tag_regexp = ".*" retained_top = 1 expire_period = "48h" } }Where:
name: Policy name.status: Policy status. It can either betrueorfalse.repository_id: Repository ID.rule: Section with the policy rule. Contains the following parameters:description: Rule description.untagged: If the parameter is set totrue, the rule applies to all Docker images that do not have a tag.tag_regexp: Docker image tag for filtering. Java regular expressions are supported. For example, thetest.*regular expression retrieves all images with tags starting withtest.retained_top: Number of Docker images that will not be deleted even if they match the lifecycle policy rules.expire_period: Time after which the lifecycle policy applies to the Docker image. This parameter comes as a number followed by a unit of measurement:s,m,h, ord(seconds, minutes, hours, or days).expire_periodmust be a multiple of 24 hours.
For more information about the
yandex_container_repository_lifecycle_policyresource parameters in Terraform, see the relevant provider documentation. -
Create resources:
-
In the terminal, go to the directory where you edited the configuration file.
-
Make sure the configuration file is correct using this command:
terraform validateIf the configuration is correct, you will get this message:
Success! The configuration is valid. -
Run this command:
terraform planYou will see a detailed list of resources. No changes will be made at this step. If the configuration contains any errors, Terraform will show them.
-
Apply the changes:
terraform apply -
Type
yesand press Enter to confirm the changes.
-
This will create a lifecycle policy in the specified repository. You can check the new policy and its settings using the management console
yc container repository lifecycle-policy list --registry-id <registry_ID>
To create a lifecycle policy, use the Create method for the LifecyclePolicyService resource.
Tip
You can test the lifecycle policy to check what Docker images comply with the policy rules. Docker images are not actually deleted during dry runs.