Creating a PostgreSQL cluster
A PostgreSQL cluster is one or more database hosts between which you can configure replication. Replication is enabled by default in any cluster consisting of more than one host: the master host accepts write requests and duplicates changes on replicas. The transaction is confirmed if the data is written to disk both on the master host and on a certain number of replicas, sufficient to establish a quorum.
Note
- The number of hosts you can create together with a PostgreSQL cluster depends on the selected disk type and host class.
- Available disk types depend on the selected host class.
- If the DB storage is 95% full, the cluster switches to read-only mode. Plan and increase the required storage size in advance.
By default, Managed Service for PostgreSQL sets the maximum number of connections to each PostgreSQL cluster host. This maximum cannot be greater than the value of Max connections.
Warning
Managed Service for PostgreSQL reserves 15 connections for service users per PostgreSQL host. For example, if the cluster has Max connections 100
, you can reserve a maximum of 85 connections for cluster users.
Creating a cluster
To create a Managed Service for PostgreSQL cluster, you need the vpc.user role and the managed-postgresql.editor role or higher. For information on assigning roles, see the Identity and Access Management documentation.
To create a Managed Service for PostgreSQL cluster:
-
In the management console
, select the folder where you want to create a DB cluster. -
Select Managed Service for PostgreSQL.
-
Click Create cluster.
-
Enter a name for the cluster in the Cluster name field. It must be unique within the folder.
-
Select the environment where you want to create the cluster (you cannot change the environment once the cluster is created):
PRODUCTION
: For stable versions of your apps.PRESTABLE
: For testing purposes. The prestable environment is similar to the production environment and likewise covered by the SLA, but it is the first to get new functionalities, improvements, and bug fixes. In the prestable environment, you can test compatibility of new versions with your application.
-
Select the DBMS version.
Note
When you select the host class version
12-1c
(PostgreSQL 12 for 1C), consider the number of users in your 1C:Enterprise installation:- For 50 or more users connecting at the same time, we recommend using
s2.medium
. - For fewer than 50 users,
s2.small
is sufficient.
- For 50 or more users connecting at the same time, we recommend using
-
Select the host class that defines the technical specifications of the VMs where the DB hosts will be deployed. All available options are listed under Host classes. When you change the host class for a cluster, the characteristics of all the already created hosts change too.
-
Under Size of storage:
-
Select the disk type.
Warning
You cannot change disk type after you create a cluster.
The selected type determines the increments in which you can change your disk size:
- Network HDD and SSD storage: In increments of 1 GB.
- Local SSD storage:
- For Intel Broadwell and Intel Cascade Lake: In increments of 100 GB.
- For Intel Ice Lake: In increments of 368 GB.
- Non-replicated SSD storage: In increments of 93 GB.
-
Select the storage size to be used for data and backups. For more information on how backups take up storage space, see Backups.
-
-
(Optional) Under Automatic increase of storage size, specify the settings you need:
-
In the Increase size field, set the conditions to:
- Increase the storage size during the next maintenance window if the storage is more than the specified percent (%) full.
- Increase the storage size right away if the storage is more than the specified percent (%) full.
You can set both conditions, but the threshold for immediate increase must be higher than that for increase during the maintenance window.
-
In the Maximum storage size field, specify the maximum storage size that can be set when increasing the storage size automatically.
As soon as one of the specified conditions is met, the storage size will be increased:
- For network HDDs and SSDs, by the higher value of the two: 20 GB or 20% of the current disk size.
- For non-replicated SSDs, by 93 GB.
- For local SSDs:
- In an Intel Broadwell or Intel Cascade Lake cluster, by 100 GB.
- In an Intel Ice Lake cluster, by 368 GB.
The storage size will be automatically increased on repeated triggers until it reaches the specified maximum. After that, you can specify a new maximum storage size manually.
Warning
- You cannot decrease the storage size.
- While resizing the storage, cluster hosts will be unavailable.
Note
Some PostgreSQL settings depend on the storage size.
If you have set up the storage size to increase within the maintenance window, set up a schedule for the maintenance window.
-
-
Under Database, specify the DB attributes:
-
DB name. The name must be unique within the folder.
A database name may contain Latin letters, numbers, underscores, and hyphens. The maximum name length is 63 characters. The names
postgres
,template0
andtemplate1
are reserved for Managed Service for PostgreSQL. You cannot create databases with these names. -
DB owner username and password. By default, the new user is assigned 50 connections to each host in the cluster.
Note
A username may contain letters, numbers, hyphens and underscores, but must start with a letter (other than
pg_
), number or underscore. The maximum name length is 63 characters.The names
admin
,repl
,monitor
,postgres
,mdb_admin
,mdb_monitor
andmdb_replication
are reserved for Managed Service for PostgreSQL. You cannot create users with these names.The password must be between 8 and 128 characters.
-
Locale for sorting and character set locale. These settings define the rules for sorting strings (
LC_COLLATE
) and classifying characters (LC_CTYPE
). In Managed Service for PostgreSQL, locale settings apply at the individual DB level.PostgreSQL uses locales to support various language standards. The locale you choose affects:
- Sort order in the queries that use the
ORDER BY
operator or standard text data matching operators. - The functions
upper
,lower
,initcap
, and theto_char
family of functions. - Pattern matching operators (
LIKE
,ILIKE
,SIMILAR TO
, regular expressions). - Support of indexes with the
LIKE
operator.
By default, the
C
locale is used. if you use theC
encoding for text data containing non-Latin (for example, Cyrillic) characters, errors might occur in the data sort order and data display in the case of pattern search. If this locale is not suitable for valid processing of tables in your database, select another encoding from the list. However, please keep in mind that a non-standard locale might decrease the database query processing rate.For more information about locale settings, see the PostgreSQL documentation
.You cannot change locale settings after you create a database. However, you can set the sorting locale for columns when creating and modifying individual tables. Learn more in the PostgreSQL documentation
. - Sort order in the queries that use the
-
-
Under Network settings, select:
-
Cloud network for the cluster.
Warning
The cloud network selected for cluster deployment can't be changed. If you need to move your cluster to a different cloud network later, use the restore from a backup feature and specify the desired network for the cluster backup.
-
Security groups for the cluster network traffic. You may also need to set up security groups to connect to the cluster.
-
-
Under Hosts, select the parameters for the DB hosts created with the cluster. By default, each host is created in a separate subnet. To select a specific subnet for the host, click
in the host row.When configuring the host parameters, note that if you selected
local-ssd
ornetwork-ssd-nonreplicated
under Size of storage, you need to add at least three hosts to the cluster.To connect to the host from the internet, enable the Public access setting.
-
Configure additional cluster settings, if required:
-
Backup start time (UTC): Time interval during which the cluster backup starts. Time is specified in 24-hour UTC format. The default time is
22:00 - 23:00
UTC. -
Retention period for automatic backups, days: Retention period for automatic backups. If an automatic backup expires, it is deleted. The default is 7 days. For more information, see Backups.
Changing the retention period affects both new automatic backups and existing backups. For example, the initial retention period was 7 days. The remaining lifetime for a backup with this period is 1 day. When the retention period increases to 9 days, the remaining lifetime for this backup is 3 days.
Automatic cluster backups are stored for a specified number of days whereas manually created ones are stored indefinitely. After a cluster is deleted, all backups persist for 7 days.
-
Maintenance window: Maintenance window settings:
- To enable maintenance at any time, select arbitrary (default).
- To specify the preferred maintenance start time, select by schedule and specify the desired day of the week and UTC hour. For example, you can choose a time when the cluster is least loaded.
Maintenance operations are carried out both on enabled and disabled clusters. They may include updating the DBMS, applying patches, and so on.
-
DataLens access: This option allows you to analyze cluster data in Yandex DataLens.
-
WebSQL access: Enables you to run SQL queries against cluster databases from the Yandex Cloud management console using Yandex WebSQL.
-
Serverless access: Enable this option to allow cluster access from Yandex Cloud Functions. For more information about setting up access, see the Cloud Functions documentation.
-
Statistics sampling: Allows you to use the Performance diagnostics tool in a cluster. If this option is enabled, also set the Sessions sampling interval and Statements sampling interval using the sliders. Both are measured in seconds.
This feature is at the Preview stage.
-
Autofailover: Enable this option so that when the master host changes, the replication source for every replica host is automatically switched over to the new master host. To learn more, see Replication.
If the master host is deleted, a new master will be selected automatically regardless of the value of this option.
Alert
If the Autofailover option is disabled, run the selection of a new master or assign this role to one of the replicas manually if the master host fails.
-
Pooling mode: Select one of the connection pooler modes.
-
Deletion protection: Manages protection of the cluster, its databases, and users against accidental deletion.
By default, the parameter inherits its value from the cluster when creating users and databases. You can also set the value manually; for more information, see the User management and Database management sections.
If the parameter is changed on a running cluster, only users and databases with the Same as cluster protection will inherit the new value.
Enabled deletion protection will not prevent a manual connection with the purpose to delete database contents.
-
-
If required, configure DBMS cluster-level settings.
Note
Some PostgreSQL settings depend on the selected host class or storage size.
-
Click Create cluster.
If you do not have the Yandex Cloud command line interface yet, install and initialize it.
The folder specified in the CLI profile is used by default. You can specify a different folder using the --folder-name
or --folder-id
parameter.
To create a Managed Service for PostgreSQL cluster:
-
Check whether the folder has any subnets for the cluster hosts:
yc vpc subnet list
If there are no subnets in the folder, create the required subnets in Yandex Virtual Private Cloud.
-
View a description of the create cluster CLI command:
yc managed-postgresql cluster create --help
-
Specify cluster parameters in the create command (the list of supported parameters in the example is not exhaustive):
yc managed-postgresql cluster create \ --name <cluster_name> \ --environment <environment> \ --network-name <network_name> \ --host zone-id=<availability_zone>,` `subnet-id=<subnet_ID>,` `assign-public-ip=<internet_access_to_host> \ --resource-preset <host_class> \ --user name=<username>,password=<user_password> \ --database name=<DB_name>,owner=<DB_owner_name> \ --disk-size <storage_size_in_GB> \ --disk-type <network-hdd|network-ssd|network-ssd-nonreplicated|local-ssd> \ --security-group-ids <list_of_security_group_IDs> \ --connection-pooling-mode=<connection_pooler_mode> \ --deletion-protection=<deletion_protection>
Where:
-
environment
:prestable
orproduction
. -
disk-type
: Disk type.Warning
You cannot change disk type after you create a cluster.
-
assign-public-ip
: Internet access to the host,true
orfalse
. -
deletion-protection
: Protection of the cluster, its databases, and users against deletion. It may take either thetrue
orfalse
value.By default, the parameter inherits its value from the cluster when creating users and databases. You can also set the value manually; for more information, see the User management and Database management sections.
You need to specify the
subnet-id
if the selected availability zone has two or more subnets.Warning
The cloud network selected for cluster deployment can't be changed. If you need to move your cluster to a different cloud network later, use the restore from a backup feature and specify the desired network for the cluster backup.
Available connection pooler modes include:
SESSION
,TRANSACTION
, orSTATEMENT
.A database name may contain Latin letters, numbers, underscores, and hyphens. The maximum name length is 63 characters. The names
postgres
,template0
andtemplate1
are reserved for Managed Service for PostgreSQL. You cannot create databases with these names.Note
The password must be between 8 and 128 characters.
Enabled deletion protection will not prevent a manual connection with the purpose to delete database contents.
You can also set the additional
replication-source
option in the--host
parameter to manually manage replication threads.To allow access to the cluster from Yandex Cloud Functions, provide the
--serverless-access
parameter. For more information about setting up access, see the Cloud Functions documentation.To allow access to the cluster from Yandex Query, provide the
--yandexquery-access=true
parameter. This feature is at the Preview stage and available upon request.Note
When creating a cluster, the
anytime
maintenance mode is set by default. You can set a specific maintenance period when updating the cluster settings. -
Terraform
For more information about the provider resources, see the documentation on the Terraform
If you change the configuration files, Terraform automatically detects which part of your configuration is already deployed, and what should be added or removed.
If you don't have Terraform, install it and configure the Yandex Cloud provider.
To create a Managed Service for PostgreSQL cluster:
-
In the configuration file, describe the parameters of the resources you want to create:
-
DB cluster: Description of the cluster and its hosts
-
Database: Description of the cluster DB
-
User: Description of the cluster user
-
Network: Description of the cloud network where a cluster will be located. If you already have a suitable network, you don't have to describe it again.
-
Subnets: Description of the subnets to connect the cluster hosts to. If you already have suitable subnets, you don't have to describe them again.
Warning
The cloud network selected for cluster deployment can't be changed. If you need to move your cluster to a different cloud network later, use the restore from a backup feature and specify the desired network for the cluster backup.
Here is an example of the configuration file structure:
resource "yandex_mdb_postgresql_cluster" "<cluster_name>" { name = "<cluster_name>" environment = "<environment>" network_id = "<network_ID>" security_group_ids = [ "<list_of_security_group_IDs>" ] deletion_protection = <deletion_protection> config { version = "<PostgreSQL_version>" resources { resource_preset_id = "<host_class>" disk_type_id = "<disk_type>" disk_size = <storage_size_in_GB> } pooler_config { pool_discard = <Odyssey_parameter> pooling_mode = "<pooling_mode>" } ... } host { zone = "<availability_zone>" name = "<host_name>" subnet_id = "<subnet_ID>" assign_public_ip = <internet_access_to_host> } } resource "yandex_mdb_postgresql_database" "<DB_name>" { cluster_id = "<cluster_ID>" name = "<DB_name>" owner = "<DB_owner_name>" depends_on = [ yandex_mdb_postgresql_user.<username> ] } resource "yandex_mdb_postgresql_user" "<username>" { cluster_id = "<cluster_ID>" name = "<username>" password = "<user_password>" } resource "yandex_vpc_network" "<network_name>" { name = "<network_name>" } resource "yandex_vpc_subnet" "<subnet_name>" { name = "<subnet_name>" zone = "<availability_zone>" network_id = "<network_ID>" v4_cidr_blocks = ["<range>"] }
Where:
-
environment
: Environment,PRESTABLE
orPRODUCTION
. -
assign_public_ip
: Internet access to the host,true
orfalse
. -
deletion_protection
: Protection of the cluster, its databases, and users against deletion. It may take either thetrue
orfalse
value.By default, the parameter inherits its value from the cluster when creating users and databases. You can also set the value manually; for more information, see the User management and Database management sections.
-
version
: PostgreSQL 11, 11-1c, 12, 12-1c, 13, 13-1c, 14, 14-1c, or 15. -
pool_discard
: Odysseypool_discard
parameter,true
orfalse
. -
pooling_mode
: Pooling mode:SESSION
,TRANSACTION
, orSTATEMENT
.
A database name may contain Latin letters, numbers, underscores, and hyphens. The maximum name length is 63 characters. The names
postgres
,template0
andtemplate1
are reserved for Managed Service for PostgreSQL. You cannot create databases with these names.Note
The password must be between 8 and 128 characters.
Enabled deletion protection will not prevent a manual connection with the purpose to delete database contents.
To set up the maintenance window (for disabled clusters as well), add the
maintenance_window
section to the cluster description:resource "yandex_mdb_postgresql_cluster" "<cluster_name>" { ... maintenance_window { type = <maintenance_type> day = <day_of_week> hour = <hour> } ... }
Where:
type
: Maintenance type. The possible values include:anytime
: Anytime.weekly
: By schedule.
day
: Day of the week for theweekly
type inDDD
format, e.g.,MON
.hour
: Hour of the day for theweekly
type in theHH
format, e.g.,21
.
To set up statistics collection, to the
config
section, add theperformance_diagnostics
section:resource "yandex_mdb_postgresql_cluster" "<cluster_name>" { ... config { ... performance_diagnostics { enabled = <enables statistics collection: true or false> sessions_sampling_interval = <sessions sampling interval> statements_sampling_interval = <statements sampling interval> } ... } ... }
Where:
enabled
: Enable statistics collection,true
orfalse
.sessions_sampling_interval
: Session sampling interval, from1
to86400
seconds.statements_sampling_interval
: Statement sampling interval, from60
to86400
seconds.
For a complete list of available Managed Service for PostgreSQL cluster configuration fields, see the Terraform provider documentation
. -
-
Make sure the settings are correct.
-
Using the command line, navigate to the folder that contains the up-to-date Terraform configuration files with an infrastructure plan.
-
Run the command:
terraform validate
If there are errors in the configuration files, Terraform will point to them.
-
-
Create a cluster.
-
Run the command to view planned changes:
terraform plan
If the resource configuration descriptions are correct, the terminal will display a list of the resources to modify and their parameters. This is a test step. No resources are updated.
-
If you are happy with the planned changes, apply them:
-
Run the command:
terraform apply
-
Confirm the update of resources.
-
Wait for the operation to complete.
-
Time limits
A Terraform provider sets the timeout for Managed Service for PostgreSQL cluster operations:
- Creating a cluster, including restoring from a backup: 30 minutes.
- Editing a cluster: 60 minutes.
- Deleting a cluster: 15 minutes.
Operations exceeding the set timeout are interrupted.
How do I change these limits?Add the
timeouts
block to the cluster description, for example:resource "yandex_mdb_postgresql_cluster" "<cluster_name>" { ... timeouts { create = "1h30m" # 1 hour 30 minutes update = "2h" # 2 hours delete = "30m" # 30 minutes } }
-
To create a Managed Service for PostgreSQL cluster, use the create REST API method for the Cluster resource or the ClusterService/Create gRPC API call and provide the following in the request:
-
ID of the folder to host the cluster in the
folderId
parameter. -
Cluster name in the
name
parameter. -
Cluster environment in the
environment
parameter. -
Network ID in the
networkId
parameter.Warning
The cloud network selected for cluster deployment can't be changed. If you need to move your cluster to a different cloud network later, use the restore from a backup feature and specify the desired network for the cluster backup.
-
Cluster configuration in the
configSpec
parameter. -
Protection of the cluster, its databases, and users against deletion in the
deletionProtection
parameter:true
orfalse
.By default, the parameter inherits its value from the cluster when creating users and databases. You can also set the value manually; for more information, see the User management and Database management sections.
-
Configuration of the cluster hosts in one or more
hostSpecs
parameters. -
Security group IDs in the
securityGroupIds
parameter. -
DB configuration in one or more
databaseSpecs
parameters.A database name may contain Latin letters, numbers, underscores, and hyphens. The maximum name length is 63 characters. The names
postgres
,template0
andtemplate1
are reserved for Managed Service for PostgreSQL. You cannot create databases with these names. -
User settings in one or more
userSpecs
parameters.Note
The password must be between 8 and 128 characters.
To allow connection to cluster hosts from the internet, provide the true
value in the hostSpecs.assignPublicIp
parameter.
To allow cluster access from Yandex Cloud Functions, set true
for the configSpec.access.serverless
parameter. For more information about setting up access, see the Cloud Functions documentation.
To allow cluster access from Yandex Query, set true
for the configSpec.access.yandexQuery
parameter. This feature is at the Preview stage and available upon request.
To enable statistics collection:
- Pass the
true
value in theconfig.performanceDiagnostics.enabled
parameter. - Pass the sessions sampling interval in the
config.performanceDiagnostics.sessionsSamplingInterval
parameter. - Pass the statements sampling interval in the
config.performanceDiagnostics.statementsSamplingInterval
parameter.
Acceptable parameter values:
config.performanceDiagnostics.sessionsSamplingInterval
: From1
to86400
seconds.config.performanceDiagnostics.statementsSamplingInterval
: From60
to86400
seconds.
To enable automatic increase of the storage size, provide the following in your request:
-
Storage utilization percentage to trigger a storage increase in the next maintenance window, in the
configSpec.diskSizeAutoscaling.plannedUsageThreshold
parameter.Use a value between
0
and100
%. The default value is0
(automatic expansion is disabled). -
Storage utilization percentage to trigger an immediate storage increase, in the
configSpec.diskSizeAutoscaling.emergencyUsageThreshold
parameter.Use a value between
0
and100
%. The default value is0
(automatic expansion is disabled). If the value is greater than0
, it cannot be less than the value provided in theconfigSpec.diskSizeAutoscaling.plannedUsageThreshold
parameter. -
Maximum storage size, in bytes, that can be set upon reaching one of the specified utilization percentages, in the
configSpec.diskSizeAutoscaling.diskSizeLimit
parameter.
Warning
- You cannot decrease the storage size.
- While resizing the storage, cluster hosts will be unavailable.
Note
Some PostgreSQL settings depend on the storage size.
Warning
If you specified security group IDs when creating a cluster, you may also need to configure security groups to connect to the cluster.
Creating a cluster copy
You can create a PostgreSQL cluster with the settings of another one created earlier. To do so, you need to import the configuration of the source PostgreSQL cluster to Terraform. Thus you can either create an identical copy or use the imported configuration as the baseline and modify it as needed. Importing is a convenient option when the source PostgreSQL cluster has lots of settings and you need to create a similar one.
To create a PostgreSQL cluster copy:
-
If you do not have Terraform yet, install it.
-
Get the authentication credentials. You can add them to environment variables or specify them later in the provider configuration file.
-
Configure and initialize a provider. There is no need to create a provider configuration file manually, you can download it
. -
Place the configuration file in a separate working directory and specify the parameter values. If you did not add the authentication credentials to environment variables, specify them in the configuration file.
-
In the same working directory, place a
.tf
file with the following contents:resource "yandex_mdb_postgresql_cluster" "old" { }
-
Write the ID of the initial PostgreSQL cluster to the environment variable:
export POSTGRESQL_CLUSTER_ID=<cluster_ID>
You can request the ID with a list of clusters in the folder.
-
Import the settings of the initial PostgreSQL cluster into the Terraform configuration:
terraform import yandex_mdb_postgresql_cluster.old ${POSTGRESQL_CLUSTER_ID}
-
Get the imported configuration:
terraform show
-
Copy it from the terminal and paste it into the
.tf
file. -
Place the file in the new
imported-cluster
directory. -
Modify the copied configuration so that you can create a new cluster from it:
- Specify a new cluster name in the
resource
string and thename
parameter. - Delete the
created_at
,health
,id
, andstatus
parameters. - In the
host
sections, delete thefqdn
androle
parameters. - If the
disk_size_autoscaling
section specifies thedisk_size_limit = 0
parameter value, delete this section. - If the
maintenance_window
section specifies thetype = "ANYTIME"
parameter value, delete thehour
parameter. - (Optional) Make further modifications if you are looking for more customization.
- Specify a new cluster name in the
-
In the
imported-cluster
directory, get the authentication data. -
In the same directory, configure and initialize a provider. There is no need to create a provider configuration file manually, you can download it
. -
Place the configuration file in the
imported-cluster
directory and specify the parameter values. If you did not add the authentication credentials to environment variables, specify them in the configuration file. -
Check that the Terraform configuration files are correct:
terraform validate
If there are any errors in the configuration files, Terraform will point them out.
-
Create the required infrastructure:
-
Run the command to view planned changes:
terraform plan
If the resource configuration descriptions are correct, the terminal will display a list of the resources to modify and their parameters. This is a test step. No resources are updated.
-
If you are happy with the planned changes, apply them:
-
Run the command:
terraform apply
-
Confirm the update of resources.
-
Wait for the operation to complete.
-
All the required resources will be created in the specified folder. You can check resource availability and their settings in the management console
. -
Time limits
A Terraform provider sets the timeout for Managed Service for PostgreSQL cluster operations:
- Creating a cluster, including restoring from a backup: 30 minutes.
- Editing a cluster: 60 minutes.
- Deleting a cluster: 15 minutes.
Operations exceeding the set timeout are interrupted.
Add the timeouts
block to the cluster description, for example:
resource "yandex_mdb_postgresql_cluster" "<cluster_name>" {
...
timeouts {
create = "1h30m" # 1 hour 30 minutes
update = "2h" # 2 hours
delete = "30m" # 30 minutes
}
}
Examples
Creating a single-host cluster
To create a cluster with a single host, provide a single --host
parameter.
Create a Managed Service for PostgreSQL cluster with the following test characteristics:
- Name:
mypg
- Environment:
Production
- Network:
default
- Security group:
enp6saqnq4ie244g67sb
s2.micro
host in theb0rcctk2rvtr********
subnet in theru-central1-a
availability zone: 1- Network SSD storage (
network-ssd
): 20 GB - User:
user1
, with theuser1user1
password - Database:
db1
owned byuser1
- Protection of the cluster, its DBs, and users against accidental deletion: Enabled
Run the following command:
yc managed-postgresql cluster create \
--name mypg \
--environment production \
--network-name default \
--resource-preset s2.micro \
--host zone-id=ru-central1-a,subnet-id=b0rcctk2rvtr******** \
--disk-type network-ssd \
--disk-size 20 \
--user name=user1,password=user1user1 \
--database name=db1,owner=user1 \
--security-group-ids enp6saqnq4ie244g67sb \
--deletion-protection=true
Create a Managed Service for PostgreSQL cluster and a network for it with the following test characteristics:
-
Name:
mypg
-
Version:
15
-
Environment:
PRESTABLE
-
Cloud ID:
b1gq90dgh25bebiu75o
-
Folder ID:
b1gia87mbaomkfvsleds
-
New network:
mynet
. -
New security group:
pgsql-sg
allowing connections to the cluster from the internet via port6432
. -
s2.micro
host in the newmysubnet
subnet, in theru-central1-a
availability zone: 1. Themysubnet
subnet will have a range of10.5.0.0/24
. -
Network SSD storage (
network-ssd
): 20 GB -
User:
user1
, with theuser1user1
password -
Database:
db1
owned byuser1
-
Protection of the cluster, its DBs, and users against accidental deletion: Enabled
The configuration file for this cluster is as follows:
resource "yandex_mdb_postgresql_cluster" "mypg" {
name = "mypg"
environment = "PRESTABLE"
network_id = yandex_vpc_network.mynet.id
security_group_ids = [ yandex_vpc_security_group.pgsql-sg.id ]
deletion_protection = true
config {
version = 15
resources {
resource_preset_id = "s2.micro"
disk_type_id = "network-ssd"
disk_size = "20"
}
}
host {
zone = "ru-central1-a"
name = "mypg-host-a"
subnet_id = yandex_vpc_subnet.mysubnet.id
}
}
resource "yandex_mdb_postgresql_database" "db1" {
cluster_id = yandex_mdb_postgresql_cluster.mypg.id
name = "db1"
owner = "user1"
}
resource "yandex_mdb_postgresql_user" "user1" {
cluster_id = yandex_mdb_postgresql_cluster.mypg.id
name = "user1"
password = "user1user1"
}
resource "yandex_vpc_network" "mynet" {
name = "mynet"
}
resource "yandex_vpc_subnet" "mysubnet" {
name = "mysubnet"
zone = "ru-central1-a"
network_id = yandex_vpc_network.mynet.id
v4_cidr_blocks = ["10.5.0.0/24"]
}
resource "yandex_vpc_security_group" "pgsql-sg" {
name = "pgsql-sg"
network_id = yandex_vpc_network.mynet.id
ingress {
description = "PostgreSQL"
port = 6432
protocol = "TCP"
v4_cidr_blocks = [ "0.0.0.0/0" ]
}
}
Managing database connection parameters using Connection Manager
If your cloud or folder has access to Connection Manager public preview, a new connection entity will appear in your folder after you create a cluster. You can use it to manage database connection parameters.
Passwords and other sensitive data will be stored in a Yandex Lockbox secret. To see which secrets store connection information for your cluster, select Lockbox in the list of services in your folder. You will find you cluster's ID on the Secrets page in the secret dependencies column.
You can also use Connection Manager to configure access to connections.