-
Notifications
You must be signed in to change notification settings - Fork 254
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #5920 from EnterpriseDB/release-2024-08-07a
Release 2024-08-07a
- Loading branch information
Showing
340 changed files
with
125,905 additions
and
1,363 deletions.
There are no files selected for viewing
40 changes: 0 additions & 40 deletions
40
advocacy_docs/edb-postgres-ai/cloud-service/deployment.mdx
This file was deleted.
Oops, something went wrong.
155 changes: 155 additions & 0 deletions
155
advocacy_docs/edb-postgres-ai/cloud-service/getting_started/backup_and_restore.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,155 @@ | ||
--- | ||
title: "Example - Back up and restore a cluster" | ||
navTitle: "Example - Backup and restore" | ||
description: Understand how to do backups and perform restore using those backups. | ||
indexCards: none | ||
--- | ||
|
||
Cloud Service [automatically and continuously](/edb-postgres-ai/cloud-service/managing_your_cluster/backup_and_restore/) saves backups of your clusters. You can restore your cluster to any point in the past after the initial backup on cluster creation. That functionality is included in the free trial as well. While that means you don't have to do anything to generate backups, it's always sensible to test your backups. | ||
|
||
If you haven't already, [create a cluster](/edb-postgres-ai/cloud-service/using_cluster/cli/create_cluster_cli/) on EDB Postgres AI Console. | ||
|
||
We're going to [add a database](/edb-postgres-ai/cloud-service/using_cluster/postgres_access/database_authentication/#one-database-with-one-application) called "baseball," which we'll populate with some Major League Baseball statistics. | ||
|
||
```sql | ||
create database baseball; | ||
``` | ||
|
||
Now you can switch to your new (and empty) baseball database. You're prompted for the `edb_admin` password you provided when connecting to the cluster. | ||
|
||
```sql | ||
\c baseball | ||
``` | ||
|
||
Normally you use the log files to determine the moment in time that you want to restore. For the purposes of this demonstration, let's change the prompt to include a timestamp to have an accurate timing of our activities. For convenience, we'll use the (almost) ISO-8601 format that the restore command accepts. | ||
|
||
```sql | ||
\set PROMPT1 '%`date +"%Y-%m-%dT%H:%M:%S%z"` %/%R%# ' | ||
``` | ||
|
||
For this demonstration, we're just going to import batter data from the [Baseball Databank](https://github.com/cbwinslow/baseballdatabank), which is in CSV form. While it's easy to import the data using [PostgreSQL's COPY command](https://www.postgresql.org/docs/current/sql-copy.html), we'll need to first define a table to put that data into. Most of the columns are integers, but there are a few strings to consider as well. You can copy and paste this command into your terminal. | ||
|
||
```sql | ||
CREATE TABLE batters ( | ||
id SERIAL, | ||
playerid VARCHAR(9), | ||
yearid INTEGER, | ||
stint INTEGER, | ||
teamid VARCHAR(3), | ||
lgid VARCHAR(2), | ||
g INTEGER, | ||
ab INTEGER, | ||
r INTEGER, | ||
h INTEGER, | ||
"2b" INTEGER, | ||
"3b" INTEGER, | ||
hr INTEGER, | ||
rbi INTEGER, | ||
sb INTEGER, | ||
cs INTEGER, | ||
bb INTEGER, | ||
so INTEGER, | ||
ibb INTEGER, | ||
hbp INTEGER, | ||
sh INTEGER, | ||
sf INTEGER, | ||
gidp INTEGER, | ||
PRIMARY KEY (id) | ||
); | ||
``` | ||
|
||
Now we can populate the table from the internet using the most recent data. | ||
|
||
```sql | ||
\COPY batters(playerid,yearid,stint,teamid,lgid,g,ab,r,h,"2b","3b",hr,rbi,sb,cs,bb,so,ibb,hbp,sh,sf,gidp) FROM PROGRAM 'curl "https://raw.githubusercontent.com/EnterpriseDB/docs/main/product_docs/docs/biganimal/release/free_trial/detail/experiment/data/Batting.csv"' DELIMITER ',' CSV HEADER | ||
``` | ||
|
||
Just to prove there's data loaded, let's look at the home run leaders for the 1998 season. | ||
|
||
```sql | ||
SELECT playerid, yearid, teamid, | ||
rank() OVER (PARTITION BY yearid ORDER BY hr desc) hr_rank, | ||
hr | ||
FROM batters | ||
WHERE yearid = 1998 | ||
ORDER BY hr_rank LIMIT 5; | ||
``` | ||
|
||
Suppose someone wanted to revise history a bit. | ||
|
||
```sql | ||
UPDATE batters | ||
SET hr=0 | ||
where playerid = 'mcgwima01' AND yearid = 1998; | ||
``` | ||
|
||
Note the time so we can restore that data later. Verify the data has been changed by rerunning the 1998 home run leader query. Now go ahead and drop the whole table. | ||
|
||
```sql | ||
DROP TABLE batters; | ||
``` | ||
|
||
You can verify the table is gone by looking at the list of tables. | ||
|
||
```sql | ||
\dt | ||
``` | ||
|
||
Restore the cluster using the timestamp before the time you dropped the table. | ||
|
||
```shell | ||
biganimal cluster restore --id p-xxxxxxxxxxx --from-deleted --restore-point 2022-03-31T02:39:40+0000 | ||
__OUTPUT__ | ||
✔ New Name for Restored Cluster, Leave empty to continue with source cluster data: █ | ||
Restored Cluster Password: ************* | ||
Region: US East 1 | ||
Instance Type: r5.large(2vCPU, 16GB RAM) | ||
Volume Type: General Purpose SSD (GP3) | ||
Volume Properties: gp3 (1 Gi - 16384 Gi, 3000 IOPS, 125 MiB/s tput) | ||
✔ Specify database configuration, for example "application_name=sample_app&array_nulls=true". Leave empty to continue with source cluster data: █ | ||
High Availability: Keep Existing | ||
Networking: Keep Existing | ||
Add IP Range to allow network traffic to your cluster from the public Internet: Keep Existing | ||
Are you sure you want to Restore Cluster ? [y|n]: y | ||
Restore Cluster operation is started | ||
Cluster ID is "p-yyyyyyyyyy" | ||
To check current state, run: biganimal show-clusters --id p-yyyyyyyyyy | ||
``` | ||
|
||
!!! Note Optional arguments for the CLI | ||
|
||
We're only providing the information we have handy to the restore command: the ID of the cluster, the fact that | ||
the cluster is deleted, and the timestamp for the restore point. The CLI will prompt for additional information, | ||
such as the password or the region to restore to, and allow you to enter or select from a list as appropriate. | ||
|
||
If you know ahead of time the options you'll need, you can provide all of them using parameters, and the command | ||
will run non-interactively. The values for the other parameters you don't specify will be inherited from the source cluster. | ||
|
||
Check the status of the new cluster from the command line. | ||
|
||
```shell | ||
biganimal cluster show | ||
``` | ||
|
||
Once provisioning is complete, you'll want to grab the new connection information. The hostname changed! | ||
|
||
```shell | ||
biganimal cluster show-connection --id p-yyyyyyyyyy | ||
``` | ||
|
||
Log in to the new cluster. Be sure to use the new hostname, and use the edb_admin password you provided when restoring the cluster. | ||
|
||
Verify that the batters table was restored: | ||
|
||
```sql | ||
select playerid, yearid, teamid, | ||
rank() OVER (PARTITION BY yearid ORDER BY hr desc) hr_rank, | ||
hr | ||
from batters | ||
where yearid = 1998 | ||
order by hr_rank limit 5; | ||
``` | ||
|
||
## Further reading | ||
|
||
[Cloud Service CLI reference](/edb-postgres-ai/cloud-service/using_cluster/cli/) and [Backing up and restoring](/edb-postgres-ai/cloud-service/managing_your_cluster/backup_and_restore/) in the full version documentation. |
Oops, something went wrong.
61889f7
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🎉 Published on https://edb-docs-staging.netlify.app as production
🚀 Deployed on https://66b378d5c10ec200aaaffedf--edb-docs-staging.netlify.app
61889f7
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🎉 Published on https://edb-docs.netlify.app as production
🚀 Deployed on https://66b3783583a4db0407b1b9ec--edb-docs.netlify.app