2024. 11. 23. 08:09ㆍ클라우드/GCP
Task 1. Prepare the source database for migration
data:image/s3,"s3://crabby-images/0397c/0397c65876cfe17ebb23bc12ec5d7b6479216a94" alt=""
sudo apt install postgresql-13-pglogical |
data:image/s3,"s3://crabby-images/5c2a1/5c2a199ca0b2ccd35a9de6f1530cf55e784afe4c" alt=""
sudo su - postgres -c "gsutil cp gs://cloud-training/gsp918/pg_hba_append.conf ." sudo su - postgres -c "gsutil cp gs://cloud-training/gsp918/postgresql_append.conf ." sudo su - postgres -c "cat pg_hba_append.conf >> /etc/postgresql/13/main/pg_hba.conf" sudo su - postgres -c "cat postgresql_append.conf >> /etc/postgresql/13/main/postgresql.conf" sudo systemctl restart postgresql@13-main |
data:image/s3,"s3://crabby-images/66c84/66c8424f006e19513be6cdbfc0a3767ecc62b5b3" alt=""
sudo su - postgres psql |
data:image/s3,"s3://crabby-images/9a45c/9a45ca819f976a937ecdf824409440fdec2af885" alt=""
\c postgres; CREATE EXTENSION pglogical; \c orders; CREATE EXTENSION pglogical; \c gmemegen_db; CREATE EXTENSION pglogical; |
data:image/s3,"s3://crabby-images/ad662/ad6627de6c716c9714c9a20a347ee9f4d0a27812" alt=""
\l |
data:image/s3,"s3://crabby-images/922f4/922f4d9a1a35c681860782d23c0b134f123ef0c5" alt=""
Create the database migration user
CREATE USER migration_admin PASSWORD 'DMS_1s_cool!'; ALTER DATABASE orders OWNER TO migration_admin; ALTER ROLE migration_admin WITH REPLICATION; |
data:image/s3,"s3://crabby-images/5a0eb/5a0ebaefc52c908f6850540fd86b81a54ebfc384" alt=""
\c postgres; |
GRANT USAGE ON SCHEMA pglogical TO migration_admin; GRANT ALL ON SCHEMA pglogical TO migration_admin; GRANT SELECT ON pglogical.tables TO migration_admin; GRANT SELECT ON pglogical.depend TO migration_admin; GRANT SELECT ON pglogical.local_node TO migration_admin; GRANT SELECT ON pglogical.local_sync_status TO migration_admin; GRANT SELECT ON pglogical.node TO migration_admin; GRANT SELECT ON pglogical.node_interface TO migration_admin; GRANT SELECT ON pglogical.queue TO migration_admin; GRANT SELECT ON pglogical.replication_set TO migration_admin; GRANT SELECT ON pglogical.replication_set_seq TO migration_admin; GRANT SELECT ON pglogical.replication_set_table TO migration_admin; GRANT SELECT ON pglogical.sequence_state TO migration_admin; GRANT SELECT ON pglogical.subscription TO migration_admin; |
data:image/s3,"s3://crabby-images/aeb44/aeb44fa9d078bc5495bd26a71ee86ef84674361e" alt=""
\c orders; |
GRANT USAGE ON SCHEMA pglogical TO migration_admin; GRANT ALL ON SCHEMA pglogical TO migration_admin; GRANT SELECT ON pglogical.tables TO migration_admin; GRANT SELECT ON pglogical.depend TO migration_admin; GRANT SELECT ON pglogical.local_node TO migration_admin; GRANT SELECT ON pglogical.local_sync_status TO migration_admin; GRANT SELECT ON pglogical.node TO migration_admin; GRANT SELECT ON pglogical.node_interface TO migration_admin; GRANT SELECT ON pglogical.queue TO migration_admin; GRANT SELECT ON pglogical.replication_set TO migration_admin; GRANT SELECT ON pglogical.replication_set_seq TO migration_admin; GRANT SELECT ON pglogical.replication_set_table TO migration_admin; GRANT SELECT ON pglogical.sequence_state TO migration_admin; GRANT SELECT ON pglogical.subscription TO migration_admin; |
data:image/s3,"s3://crabby-images/baa3f/baa3f14263043cbddf5938dd0e303dc707d96d46" alt=""
GRANT USAGE ON SCHEMA public TO migration_admin; GRANT ALL ON SCHEMA public TO migration_admin; GRANT SELECT ON public.distribution_centers TO migration_admin; GRANT SELECT ON public.inventory_items TO migration_admin; GRANT SELECT ON public.order_items TO migration_admin; GRANT SELECT ON public.products TO migration_admin; GRANT SELECT ON public.users TO migration_admin; |
data:image/s3,"s3://crabby-images/80ec3/80ec394371eec87682026d7d86423f4c7c4d48e4" alt=""
\c gmemegen_db; |
GRANT USAGE ON SCHEMA pglogical TO migration_admin; GRANT ALL ON SCHEMA pglogical TO migration_admin; GRANT SELECT ON pglogical.tables TO migration_admin; GRANT SELECT ON pglogical.depend TO migration_admin; GRANT SELECT ON pglogical.local_node TO migration_admin; GRANT SELECT ON pglogical.local_sync_status TO migration_admin; GRANT SELECT ON pglogical.node TO migration_admin; GRANT SELECT ON pglogical.node_interface TO migration_admin; GRANT SELECT ON pglogical.queue TO migration_admin; GRANT SELECT ON pglogical.replication_set TO migration_admin; GRANT SELECT ON pglogical.replication_set_seq TO migration_admin; GRANT SELECT ON pglogical.replication_set_table TO migration_admin; GRANT SELECT ON pglogical.sequence_state TO migration_admin; GRANT SELECT ON pglogical.subscription TO migration_admin; |
data:image/s3,"s3://crabby-images/e01de/e01de0ba267145301b40d78f028f35dba400ec1f" alt=""
GRANT USAGE ON SCHEMA public TO migration_admin; GRANT ALL ON SCHEMA public TO migration_admin; GRANT SELECT ON public.meme TO migration_admin; |
data:image/s3,"s3://crabby-images/4682a/4682aaf545c83463d0c8855efbbb4bfb3d754401" alt=""
\c orders; \dt |
data:image/s3,"s3://crabby-images/3bc79/3bc79b7d141297e075fe6274c4f83654eccf3a86" alt=""
ALTER TABLE public.distribution_centers OWNER TO migration_admin; ALTER TABLE public.inventory_items OWNER TO migration_admin; ALTER TABLE public.order_items OWNER TO migration_admin; ALTER TABLE public.products OWNER TO migration_admin; ALTER TABLE public.users OWNER TO migration_admin; \dt |
data:image/s3,"s3://crabby-images/0b0fb/0b0fbbf5a1dc5cfb8aa84f8c2b8efad1315fcbae" alt=""
Task 2. Create a Database Migration Service connection profile for a stand-alone PostgreSQL database
data:image/s3,"s3://crabby-images/b9e00/b9e00f0c98b66e3bf2744260e73164023eef8b01" alt=""
Create a new connection profile for the PostgreSQL source instance
data:image/s3,"s3://crabby-images/ae768/ae768d7976ab0618f3cd1c3a63204161130ba238" alt=""
data:image/s3,"s3://crabby-images/c840b/c840b72eeba1d6877e5495b956af9f5b024affa5" alt=""
Task 3. Create and start a continuous migration job
data:image/s3,"s3://crabby-images/4a8f7/4a8f7fe1df30d3d03ad6637988c6ea88de47db97" alt=""
data:image/s3,"s3://crabby-images/aca03/aca0371681abdec3450bdc4661db462eb27523c0" alt=""
data:image/s3,"s3://crabby-images/28e79/28e791d1db546ac40af728fbc3c9e0ec48fe3471" alt=""
Create the destination instance
data:image/s3,"s3://crabby-images/e59b9/e59b909c4bd614b01edf87cab54d4ccca40eb8fc" alt=""
data:image/s3,"s3://crabby-images/ea0f2/ea0f2d3576a33f2a06681d5dcf0f0bd9560b97ed" alt=""
data:image/s3,"s3://crabby-images/777b8/777b8dac9202664d9679aeec7152287471e6d24f" alt=""
data:image/s3,"s3://crabby-images/135b0/135b0e6845532d04ba940c485ef2bcc8f453b590" alt=""
data:image/s3,"s3://crabby-images/2e2d8/2e2d841caa081ad45d13d135c8ce3fe4049a4ace" alt=""
이후 생성될 때까지 대기(꽤 오래 걸림)
Allow access to the postgresql-vm instance from automatically allocated IP range
data:image/s3,"s3://crabby-images/ca85a/ca85a68b7a2e108cea786cfbcc65b14f70f751f4" alt=""
data:image/s3,"s3://crabby-images/21bed/21bedc223a305b850851994e8fe2eda2dd0c8ed9" alt=""
data:image/s3,"s3://crabby-images/4c5eb/4c5ebbd98419101e3af189b76b5f467b46eb20f9" alt=""
In the Destination IP range coloum ,copy the IP range (e.g. 10.107.176.0/24) next to peering-route-xxxxx... route.
data:image/s3,"s3://crabby-images/a27d2/a27d2b418a4fafe35dd00e685333be8d8d5e8110" alt=""
data:image/s3,"s3://crabby-images/7080f/7080fdc943707d5867b24828f3becde13a110e6a" alt=""
sudo nano /etc/postgresql/13/main/pg_hba.conf |
data:image/s3,"s3://crabby-images/8e6c5/8e6c538a57cc433f41f40d1d91f60167968f526f" alt=""
파일 마지막 줄에 다음과 같이 수정
data:image/s3,"s3://crabby-images/96811/968119e9815f733c42796a456eb7fc0669e606eb" alt=""
Ctrl-O, Enter, Ctrl-X 입력하여 저장후 nano 종료( : , esc )
sudo systemctl start postgresql@13-main |
data:image/s3,"s3://crabby-images/d63f2/d63f2fa4be46893a8a93c25dfb20b7b0aa8aa76a" alt=""
Test and start the continuous migration job
In this step, you will test and start the migration job.
Task 4. Confirm the data in Cloud SQL for PostgreSQL
data:image/s3,"s3://crabby-images/77123/7712335d91e7eb4dc361cf9994642d3e5efc1e42" alt=""
클릭
data:image/s3,"s3://crabby-images/01cdb/01cdb453c0f6983209b7c274474064b49954d4a5" alt=""
db 늘어난 것 확인
Connect to the PostgreSQL instance
data:image/s3,"s3://crabby-images/745a7/745a72035aa9efb306bfdbe42cae55f709e47332" alt=""
gcloud sql connect postgresql-cloudsql --user=postgres --quiet |
data:image/s3,"s3://crabby-images/19abc/19abcbe4bac52d1dcbb25ffdd57f6b6b41277d08" alt=""
\c orders; |
select * from distribution_centers; |
data:image/s3,"s3://crabby-images/ddc72/ddc72fccc456b345019327f7e2a79842010299ba" alt=""
Update stand-alone source data to test continuous migration
export VM_NAME=postgresql-vm export PROJECT_ID=$(gcloud config list --format 'value(core.project)') export POSTGRESQL_IP=$(gcloud compute instances describe ${VM_NAME} \ --zone=us-east4-a --format="value(networkInterfaces[0].accessConfigs[0].natIP)") echo $POSTGRESQL_IP psql -h $POSTGRESQL_IP -p 5432 -d orders -U migration_admin |
\c orders; |
insert into distribution_centers values(-80.1918,25.7617,'Miami FL',11); |
\q |
data:image/s3,"s3://crabby-images/651eb/651ebaab1758c7db3111f4654fb15996ea1b9099" alt=""
Connect to the Cloud SQL PostgreSQL database to check that updated data has been migrated
gcloud sql connect postgresql-cloudsql --user=postgres --quiet |
data:image/s3,"s3://crabby-images/778cb/778cb668478a649784de0373c314f5aa21f1333e" alt=""
Review data in Cloud SQL for PostgreSQL database
\c orders; |
select * from distribution_centers; |
data:image/s3,"s3://crabby-images/6f60e/6f60e66c36ff972c344acaeaa41ca290d706b88d" alt=""
Task 5. Promote Cloud SQL to be a stand-alone instance for reading and writing data
data:image/s3,"s3://crabby-images/08100/081004c05b8b91231420a6a2883cda53b51f2df2" alt=""
data:image/s3,"s3://crabby-images/3130b/3130b03977f9167320e75717b2d539a9eddcfc93" alt=""
data:image/s3,"s3://crabby-images/dfcb5/dfcb55a1a1134203fc403c2c2c661dfd51902588" alt=""
data:image/s3,"s3://crabby-images/194ba/194ba802d7b4680b08a2e7362dca9ec53a9dc914" alt=""
Note that postgresql-cloudsql is now a stand-alone instance for reading and writing data.
참고 : https://www.cloudskillsboost.google/focuses/22792?parent=catalog
Database Migration Service를 사용하여 PostgreSQL용 Cloud SQL로 마이그레이션하기 | Google Cloud Skills Boost
이 실습에서는 연속 Database Migration Service 작업과 연결을 위한 VPC 피어링을 사용하여, 가상 머신에서 실행 중인 독립형 PostgreSQL 데이터베이스를 PostgreSQL용 Cloud SQL로 마이그레이션합니다.
www.cloudskillsboost.google
'클라우드 > GCP' 카테고리의 다른 글
17. AlloyDB - Database Fundamentals (0) | 2024.11.25 |
---|---|
16. Connect an App to a Cloud SQL for PostgreSQL Instance (0) | 2024.11.24 |
14. Cloud Composer: Copying BigQuery Tables Across Different Locations (0) | 2024.11.22 |
13. Cloud Logging and Monitoring for BigQuery (0) | 2024.11.21 |
그림으로 배우는 구글 클라우드 101 (2) | 2024.11.20 |