์ด ํ์ด์ง์์๋ Cloud SQL ์ธ์คํด์ค์ ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋๋ ๋ฐฉ๋ฒ์ ์ค๋ช ํฉ๋๋ค.
์ธ๋ถ ๊ตฌ๋ ์์ ๋ํด ๊ฒ์์๋ก ์๋ํ๋๋ก Cloud SQL ์ธ์คํด์ค๋ฅผ ์ค์ ํ๋ ค๋ฉด ์ธ๋ถ ๋ณต์ ๋ณธ ๊ตฌ์ฑ์ ์ฐธ์กฐํ์ธ์.
์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ์ผ๋ฐ์ ์ธ ์ํฉ์์ ๊ฑฐ์ ์ค์๊ฐ์ผ๋ก ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋ณ๊ฒฝ์ฌํญ์ ๋ฐ์ํ๋ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ์ฌ๋ณธ์ ๋๋ค. ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ์ฌ์ฉํ์ฌ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ์ฝ๊ธฐ ์์ฒญ์ด๋ ๋ถ์ ํธ๋ํฝ์ ์คํ๋ก๋ํฉ๋๋ค.
๋ํ ์ฌํด ๋ณต๊ตฌ๋ฅผ ์ํด ๋ฆฌ์ ๋ง์ด๊ทธ๋ ์ด์ ์ ์ํํ ์ ์์ต๋๋ค. ๋ณต์ ๋ณธ์ด ๋ฆฌ์ ๊ฐ ๋ณต์ ๋ณธ์ธ ๊ฒฝ์ฐ ๋ค๋ฅธ ๋ฆฌ์ ์ผ๋ก ์ฅ์ ์กฐ์น๋ฅผ ์ํํ ์ ์์ต๋๋ค. ํนํ ๋ณต์ ๋ณธ์ ๋ ๋ฆฝํ ์ธ์คํด์ค๋ก ์น๊ฒฉํ ์ ์์ต๋๋ค(์ด ๊ฒฝ์ฐ ๊ธฐ์กด ๋ณต์ ๋ณธ์ ํด๋น ์ธ์คํด์ค๋ฅผ ๊ธฐ๋ณธ ์ธ์คํด์ค๋ก ๊ฐ์ฃผํ์ง ์์).
๋ณต์ ์๋ ๋ฐฉ์์ ๋ํ ์์ธํ ๋ด์ฉ์ Cloud SQL์ ๋ณต์ ๋ฅผ ์ฐธ์กฐํ์ธ์.
์์ํ๊ธฐ ์ ์
์ด ์ธ์คํด์ค์ ์ฒซ ๋ฒ์งธ ๋ณต์ ๋ณธ์ ๋ง๋๋ ๊ฒฝ์ฐ ์ธ์คํด์ค๊ฐ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ์๊ตฌ์ฌํญ์ ์ถฉ์กฑํ๋์ง ํ์ธํฉ๋๋ค. ์์ธํ ์์๋ณด๊ธฐ
์ฝ๊ธฐ ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ
์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ค ๋๋ ๋ค์ ์ฌํญ์ ๊ณ ๋ คํ์ธ์.- ๊ธฐ๋ณธ ์ธ์คํด์ค๋น ์ต๋ 8๊ฐ์ ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ค ์ ์์ต๋๋ค.
- ๋ฒ์ ์ ์ง์ ํ์ง ์์ผ๋ฉด Cloud SQL Enterprise ๋ฒ์ ์ด ๊ธฐ๋ณธ๊ฐ์ ๋๋ค.
- ์ฝ๊ธฐ ๋ณต์ ๋ณธ ๋๋ ์ฐ์ ๋ณต์ ๋ณธ์ ๋ง๋ค ๋ ๊ธฐ๋ณธ ์ธ์คํด์ค๊ฐ Cloud SQL Enterprise Plus ๋ฒ์ ์ธ์คํด์ค์ธ ๊ฒฝ์ฐ ์ฌ์ฉํ ๋ฒ์ ๊ณผ ๋ฑ๊ธ์ ํ์ํด์ผ ํฉ๋๋ค.
์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋๋ ๋จ๊ณ๋ ์๋์ ๊ฐ์ต๋๋ค.
Console
-
Google Cloud ์ฝ์์์ Cloud SQL ์ธ์คํด์ค ํ์ด์ง๋ก ์ด๋ํฉ๋๋ค.
- ๋ณต์ ๋ณธ์ ๋ง๋ค ์ธ์คํด์ค๋ฅผ ์ฐพ์ ํ ๋ฑ๋ก์ ๋ณด ์์ ์๋
more actions
๋ฉ๋ด๋ฅผ ์ฝ๋๋ค. - ์ฝ๊ธฐ ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ๋ฅผ ์ ํํฉ๋๋ค.
ํด๋น ์ ํ ์ต์ ์ด ํ์๋์ง ์์ผ๋ฉด ์ธ์คํด์ค๊ฐ ๋ณต์ ๋ณธ์ธ ๊ฒ์ ๋๋ค. ๋ณต์ ๋ณธ์ ๋ณต์ ๋ณธ์ ๋ง๋ค ์ ์์ต๋๋ค.
์ธ์คํด์ค ๋ง์ถค์ค์ ์น์ ์์ ๋ณต์ ๋ณธ์ ์ค์ ์ ์ ๋ฐ์ดํธํฉ๋๋ค. ๊ตฌ์ฑ ์ต์ ํ์๋ฅผ ํด๋ฆญํ์ฌ ์ค์ ๊ทธ๋ฃน์ ํ์ํฉ๋๋ค. ๊ทธ๋ฐ ๋ค์ ์ํ๋ ๊ทธ๋ฃน์ ํผ์ณ ์ค์ ์ ๊ฒํ ํ๊ณ ๋ง์ถค์ค์ ํฉ๋๋ค. ์ ํํ ๋ชจ๋ ์ต์ ์ ์์ฝ์ด ์ค๋ฅธ์ชฝ์ ํ์๋ฉ๋๋ค. ์ด ์ค์ ์ ๋ง์ถค์ค์ ํ๋ ๊ฒ์ ์ ํ์ฌํญ์ ๋๋ค. ๋ง์ถค์ค์ ์ด ์ํ๋์ง ์๋ ๋ชจ๋ ๊ฒฝ์ฐ์ ๊ธฐ๋ณธ๊ฐ์ด ํ ๋น๋ฉ๋๋ค.
๊ฐ ์ค์ ์ ๋ํ ์์ธํ ๋ด์ฉ์ ์ธ์คํด์ค ์ค์ ์ ๋ณด ํ์ด์ง๋ฅผ ์ฐธ์กฐํ์ธ์.
- ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ๋ฅผ ํด๋ฆญํฉ๋๋ค.
Cloud SQL์ด ๋ฐฑ์ ์ ๋ง๋ค๊ณ , ํ์ํ ๊ฒฝ์ฐ ๋ณต์ ๋ณธ์ ๋ง๋ญ๋๋ค. ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋ํ ์ธ์คํด์ค ํ์ด์ง๋ก ๋์๊ฐ๋๋ค.
gcloud
๋ณต์ ๋ณธ์ ๋ง๋ญ๋๋ค.
gcloud sql instances create REPLICA_NAME \ --master-instance-name=PRIMARY_INSTANCE_NAME
ํ์ํ ๊ฒฝ์ฐ --tier
ํ๋ผ๋ฏธํฐ๋ฅผ ์ฌ์ฉํ์ฌ ๋ค๋ฅธ ๋ฑ๊ธ ํฌ๊ธฐ๋ฅผ ์ง์ ํ ์ ์์ต๋๋ค.
--region
ํ๋ผ๋ฏธํฐ๋ฅผ ์ฌ์ฉํ์ฌ ๋ค๋ฅธ ๋ฆฌ์ ์ ์ง์ ํ ์ ์์ต๋๋ค.
๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋ด๋ถ IP ์ฃผ์๋ง ์์ผ๋ฉด ๋ช
๋ น์ด์ --no-assign-ip
๋งค๊ฐ๋ณ์๋ฅผ ์ถ๊ฐํฉ๋๋ค.
๋ค๋ฅธ ์ธ์คํด์ค ์ค์ ์ ๋งค๊ฐ๋ณ์๋ฅผ ๋ ์ถ๊ฐํ ์ ์์ต๋๋ค. ์์ธํ ๋ด์ฉ์ gcloud sql instances create๋ฅผ ์ฐธ์กฐํ์ธ์.
๋ณต์ ๋ณธ์ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋์ผํ VPC ๋คํธ์ํฌ์ ๋ง๋ค์ด์ผ ํฉ๋๋ค. ๋ํ ์ด VPC ๋คํธ์ํฌ์ allocated-ip-range-name
์ ์ง์ ํ ์ ์์ต๋๋ค. ๋ฒ์๊ฐ ์ง์ ๋์ง ์์ผ๋ฉด ๋ณต์ ๋ณธ์ด ๋ฌด์์ ๋ฒ์๋ก ์์ฑ๋ฉ๋๋ค.
Terraform
์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ค๋ ค๋ฉด Terraform ๋ฆฌ์์ค๋ฅผ ์ฌ์ฉํฉ๋๋ค.
REST v1beta4
์ธ์คํด์ค ๋ฆฌ์์ค์ insert
๋ฉ์๋๋ฅผ ์ฌ์ฉํ์ฌ ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ญ๋๋ค. region๊ณผ databaseVersion ์์ฑ์ด ๋ง์คํฐ์ ๊ฐ์์ผ ํฉ๋๋ค.
์์ฒญ ๋ฐ์ดํฐ๋ฅผ ์ฌ์ฉํ๊ธฐ ์ ์ ๋ค์์ ๋ฐ๊ฟ๋๋ค.
- project-id: ํ๋ก์ ํธ ID
- database-version: Enum ๋ฒ์ ๋ฌธ์์ด(์: SQLSERVER_2017_ENTERPRISE)
- primary-instance-name: ๊ธฐ๋ณธ ์ธ์คํด์ค ์ด๋ฆ
- primary-instance-region: ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋ฆฌ์
- replica-region: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ๋ฆฌ์
- replica-name: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ์ด๋ฆ
- machine-type: ๋จธ์ ์ ํ์ ์ด๊ฑฐํ ๋ฌธ์์ด (์: 'db-custom-1-3840')
HTTP ๋ฉ์๋ ๋ฐ URL:
POST https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances
JSON ์์ฒญ ๋ณธ๋ฌธ:
{ "masterInstanceName": "primary-instance-name", "project": "project-id", "databaseVersion": "database-version", "name": "replica-name", "region": "replica-region", "settings": { "tier": "machine-type", "settingsVersion": 0, } }
์์ฒญ์ ๋ณด๋ด๋ ค๋ฉด ๋ค์ ์ต์ ์ค ํ๋๋ฅผ ํผ์นฉ๋๋ค.
๋ค์๊ณผ ๋น์ทํ JSON ์๋ต์ด ํ์๋ฉ๋๋ค.
Private Service Connect๊ฐ ์ฌ์ฉ ์ค์ ๋ ์ธ์คํด์ค์ ์ฝ๊ธฐ ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ
Private Service Connect๊ฐ ์ฌ์ฉ ์ค์ ๋ ์ธ์คํด์ค์ ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ค๋ ค๋ฉด gcloud CLI ๋๋ API๋ฅผ ์ฌ์ฉํฉ๋๋ค. ์ด ๋ณต์ ๋ณธ์ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๊ฐ์ ๋ฆฌ์ ๋๋ ๋ค๋ฅธ ๋ฆฌ์ (๋ฆฌ์ ๊ฐ ์ฝ๊ธฐ ๋ณต์ ๋ณธ)์ ๋ง๋ค ์ ์์ต๋๋ค.
๋ค๋ฅธ ์ฐ๊ฒฐ ์ ํ์ ์ธ์คํด์ค์์ ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ณต์ ํ ์ ์์ต๋๋ค. ์๋ฅผ ๋ค์ด Private Service Connect๊ฐ ์ฌ์ฉ ์ค์ ๋ ์ธ์คํด์ค๋ ๋ค๋ฅธ Private Service Connect ์ธ์คํด์ค์์๋ง ๋ณต์ ํ ์ ์์ต๋๋ค. ๋ํ ์ธ๋ถ IP ์ฐ๊ฒฐ์ ์ง์ํ๋ ์ธ์คํด์ค ๋๋ ๋น๊ณต๊ฐ ์๋น์ค ์ก์ธ์ค๋ก ๊ตฌ์ฑ๋ ์ธ์คํด์ค์์ ๋ณต์ ํ ์ ์์ต๋๋ค.
gcloud
์ธ์คํด์ค์ ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ค๋ ค๋ฉด gcloud sql instances create
๋ช
๋ น์ด๋ฅผ ์ฌ์ฉํฉ๋๋ค.
gcloud sql instances create REPLICA_INSTANCE_NAME \ --master-instance-name=PRIMARY_INSTANCE_NAME \ --project=PROJECT_ID \ --region=REGION_NAME \ --enable-private-service-connect \ --allowed-psc-projects=ALLOWED_PROJECTS \ --availability-type=AVAILABILITY_TYPE \ --no-assign-ip
๋ค์์ ๋ฐ๊ฟ๋๋ค.
- REPLICA_INSTANCE_NAME: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ์ด๋ฆ์ ๋๋ค.
- PRIMARY_INSTANCE_NAME: ๊ธฐ๋ณธ ์ธ์คํด์ค ์ด๋ฆ์ ๋๋ค.
- PROJECT_ID: ์ธ์คํด์ค๊ฐ ํฌํจ๋ Google Cloud ํ๋ก์ ํธ์ ID ๋๋ ํ๋ก์ ํธ ๋ฒํธ
- REGION_NAME: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ๋ฆฌ์ ์ด๋ฆ์ ๋๋ค.
ALLOWED_PROJECTS: ํ์ฉ๋๋ ํ๋ก์ ํธ ID ๋๋ ์ซ์์ ๋ชฉ๋ก(์ผํ๋ก ๊ตฌ๋ถ). ํ๋ก์ ํธ๊ฐ ์ด ๋ชฉ๋ก์ ํฌํจ๋์ง ์์ ๊ฒฝ์ฐ ์ด๋ฅผ ์ฌ์ฉํ์ฌ ์ธ์คํด์ค๋ฅผ ๋ง๋ค๊ณ Private Service Connect๋ฅผ ์ฌ์ฉ ์ค์ ํ ์ ์์ต๋๋ค.
Cloud SQL์ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ํ์ฉ๋๋ ํ๋ก์ ํธ๋ฅผ ๋ณต์ ๋ณธ์ผ๋ก ๋ณต์ฌํ์ง ์์ต๋๋ค. ๋ณต์ ๋ณธ๋ง๋ค Private Service Connect ์๋ํฌ์ธํธ๋ฅผ ๋ง๋ค์ด์ผ ํฉ๋๋ค. Cloud SQL ์ธ์ฆ ํ๋ก์ ๋๋ Cloud SQL ์ธ์ด ์ปค๋ฅํฐ๋ฅผ ์ฌ์ฉํ๋ ๊ฒฝ์ฐ ๋ณต์ ๋ณธ์ DNS ์์ญ๊ณผ DNS ๋ ์ฝ๋๋ฅผ ๋ง๋ค์ด์ผ ํฉ๋๋ค.
- AVAILABILITY_TYPE: ์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ์ ์ฌ์ฉ ์ค์ ํฉ๋๋ค. ์ด ๋งค๊ฐ๋ณ์์ ๋ํด ๋ค์ ๊ฐ ์ค ํ๋๋ฅผ ์ง์ ํฉ๋๋ค.
REGIONAL
: ๊ณ ๊ฐ์ฉ์ฑ์ ์ฌ์ฉ ์ค์ ํ๋ฉฐ, ํ๋ก๋์ ์ธ์คํด์ค์ ๊ถ์ฅ๋ฉ๋๋ค. ์ธ์คํด์ค๋ ์ ํํ ๋ฆฌ์ ๋ด์ ๋ค๋ฅธ ์์ญ์ผ๋ก ์ฅ์ ์กฐ์น๋ฉ๋๋ค.ZONAL
: ์ฅ์ ์กฐ์น ๊ธฐ๋ฅ์ ์ ๊ณตํ์ง ์์ต๋๋ค. ์ด ์ค์ ์ด ๊ธฐ๋ณธ ์ค์ ์ ๋๋ค.
์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ ์ค์ ๋ฐ ์ญ์ ์ ๋ํ ์์ธํ ๋ด์ฉ์ ๊ธฐ์กด ์ธ์คํด์ค๋ฅผ ๊ณ ๊ฐ์ฉ์ฑ์ผ๋ก ๊ตฌ์ฑ ๋ฐ ์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ ๋นํ์ฑํ๋ฅผ ์ฐธ์กฐํ์ธ์.
REST v1
์์ฒญ ๋ฐ์ดํฐ๋ฅผ ์ฌ์ฉํ๊ธฐ ์ ์ ๋ค์์ ๋ฐ๊ฟ๋๋ค.
- PRIMARY_INSTANCE_NAME: ๊ธฐ๋ณธ ์ธ์คํด์ค ์ด๋ฆ์ ๋๋ค.
- PROJECT_ID: ์ธ์คํด์ค๊ฐ ํฌํจ๋ Google Cloud ํ๋ก์ ํธ์ ID ๋๋ ํ๋ก์ ํธ ๋ฒํธ
- REPLICA_INSTANCE_NAME: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ์ด๋ฆ
- REGION_NAME: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ๋ฆฌ์ ์ด๋ฆ์ ๋๋ค.
- MACHINE_TYPE: ์ธ์คํด์ค์ ๋จธ์ ์ ํ์ ๋๋ค.
- AVAILABILITY_TYPE: ์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ์ ์ฌ์ฉ ์ค์ ํฉ๋๋ค. ์ด ๋งค๊ฐ๋ณ์์ ๋ํด ๋ค์ ๊ฐ ์ค ํ๋๋ฅผ ์ง์ ํฉ๋๋ค.
REGIONAL
: ๊ณ ๊ฐ์ฉ์ฑ์ ์ฌ์ฉ ์ค์ ํ๋ฉฐ, ํ๋ก๋์ ์ธ์คํด์ค์ ๊ถ์ฅ๋ฉ๋๋ค. ์ธ์คํด์ค๋ ์ ํํ ๋ฆฌ์ ๋ด์ ๋ค๋ฅธ ์์ญ์ผ๋ก ์ฅ์ ์กฐ์น๋ฉ๋๋ค.ZONAL
: ์ฅ์ ์กฐ์น ๊ธฐ๋ฅ์ ์ ๊ณตํ์ง ์์ต๋๋ค. ์ด ์ค์ ์ด ๊ธฐ๋ณธ ์ค์ ์ ๋๋ค.
์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ ์ค์ ๋ฐ ์ญ์ ์ ๋ํ ์์ธํ ๋ด์ฉ์ ๊ธฐ์กด ์ธ์คํด์ค๋ฅผ ๊ณ ๊ฐ์ฉ์ฑ์ผ๋ก ๊ตฌ์ฑ ๋ฐ ์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ ๋นํ์ฑํ๋ฅผ ์ฐธ์กฐํ์ธ์.
ALLOWED_PROJECTS: ํ์ฉ๋๋ ํ๋ก์ ํธ ID ๋๋ ์ซ์์ ๋ชฉ๋ก(์ผํ๋ก ๊ตฌ๋ถ). ํ๋ก์ ํธ๊ฐ ์ด ๋ชฉ๋ก์ ํฌํจ๋์ง ์์ ๊ฒฝ์ฐ ์ด๋ฅผ ์ฌ์ฉํ์ฌ ์ธ์คํด์ค๋ฅผ ๋ง๋ค๊ณ Private Service Connect๋ฅผ ์ฌ์ฉ ์ค์ ํ ์ ์์ต๋๋ค.
Cloud SQL์ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ํ์ฉ๋๋ ํ๋ก์ ํธ๋ฅผ ๋ณต์ ๋ณธ์ผ๋ก ๋ณต์ฌํ์ง ์์ต๋๋ค. ๋ณต์ ๋ณธ๋ง๋ค Private Service Connect ์๋ํฌ์ธํธ๋ฅผ ๋ง๋ค์ด์ผ ํฉ๋๋ค. Cloud SQL ์ธ์ฆ ํ๋ก์ ๋๋ Cloud SQL ์ธ์ด ์ปค๋ฅํฐ๋ฅผ ์ฌ์ฉํ๋ ๊ฒฝ์ฐ ๋ณต์ ๋ณธ์ DNS ์์ญ๊ณผ DNS ๋ ์ฝ๋๋ฅผ ๋ง๋ค์ด์ผ ํฉ๋๋ค.
HTTP ๋ฉ์๋ ๋ฐ URL:
POST https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances
JSON ์์ฒญ ๋ณธ๋ฌธ:
{ "masterInstanceName": "PRIMARY_INSTANCE_NAME", "project": "PROJECT_ID", "databaseVersion": "SQLSERVER_2019_STANDARD", "name": "REPLICA_INSTANCE_NAME", "region": "REGION_NAME", "kind": "sql#instance", "settings": { "tier": "MACHINE_TYPE", "availabilityType": "AVAILABILITY_TYPE", "settingsVersion": 0, "ipConfiguration": { "ipv4Enabled": false, "pscConfig": { "allowedConsumerProjects": [ALLOWED_PROJECTS], "pscEnabled": true } }, "kind": "sql#settings", "pricingPlan": "PER_USE", "replicationType": "ASYNCHRONOUS", "tier": "MACHINE_TYPE" } }
์์ฒญ์ ๋ณด๋ด๋ ค๋ฉด ๋ค์ ์ต์ ์ค ํ๋๋ฅผ ํผ์นฉ๋๋ค.
๋ค์๊ณผ ๋น์ทํ JSON ์๋ต์ด ํ์๋ฉ๋๋ค.
{ "kind": "sql#operation", "targetLink": "https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/REPLICA_INSTANCE_NAME", "status": "PENDING", "user": "user@example.com", "insertTime": "2020-01-16T02:32:12.281Z", "operationType": "CREATE_REPLICA", "name": "OPERATION_ID", "targetId": "REPLICA_INSTANCE_NAME", "selfLink": "https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/operations/OPERATION_ID", "targetProject": "PROJECT_ID" }
REST v1beta4
์์ฒญ ๋ฐ์ดํฐ๋ฅผ ์ฌ์ฉํ๊ธฐ ์ ์ ๋ค์์ ๋ฐ๊ฟ๋๋ค.
- PRIMARY_INSTANCE_NAME: ๊ธฐ๋ณธ ์ธ์คํด์ค ์ด๋ฆ์ ๋๋ค.
- PROJECT_ID: ์ธ์คํด์ค๊ฐ ํฌํจ๋ Google Cloud ํ๋ก์ ํธ์ ID ๋๋ ํ๋ก์ ํธ ๋ฒํธ
- REPLICA_INSTANCE_NAME: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ์ด๋ฆ
- REGION_NAME: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ๋ฆฌ์ ์ด๋ฆ์ ๋๋ค.
- MACHINE_TYPE: ์ธ์คํด์ค์ ๋จธ์ ์ ํ์ ๋๋ค.
- AVAILABILITY_TYPE: ์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ์ ์ฌ์ฉ ์ค์ ํฉ๋๋ค. ์ด ๋งค๊ฐ๋ณ์์ ๋ํด ๋ค์ ๊ฐ ์ค ํ๋๋ฅผ ์ง์ ํฉ๋๋ค.
REGIONAL
: ๊ณ ๊ฐ์ฉ์ฑ์ ์ฌ์ฉ ์ค์ ํ๋ฉฐ, ํ๋ก๋์ ์ธ์คํด์ค์ ๊ถ์ฅ๋ฉ๋๋ค. ์ธ์คํด์ค๋ ์ ํํ ๋ฆฌ์ ๋ด์ ๋ค๋ฅธ ์์ญ์ผ๋ก ์ฅ์ ์กฐ์น๋ฉ๋๋ค.ZONAL
: ์ฅ์ ์กฐ์น ๊ธฐ๋ฅ์ ์ ๊ณตํ์ง ์์ต๋๋ค. ์ด ์ค์ ์ด ๊ธฐ๋ณธ ์ค์ ์ ๋๋ค.
์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ ์ค์ ๋ฐ ์ญ์ ์ ๋ํ ์์ธํ ๋ด์ฉ์ ๊ธฐ์กด ์ธ์คํด์ค๋ฅผ ๊ณ ๊ฐ์ฉ์ฑ์ผ๋ก ๊ตฌ์ฑ ๋ฐ ์ธ์คํด์ค์ ๊ณ ๊ฐ์ฉ์ฑ ๋นํ์ฑํ๋ฅผ ์ฐธ์กฐํ์ธ์.
ALLOWED_PROJECTS: ํ์ฉ๋๋ ํ๋ก์ ํธ ID ๋๋ ์ซ์์ ๋ชฉ๋ก(์ผํ๋ก ๊ตฌ๋ถ). ํ๋ก์ ํธ๊ฐ ์ด ๋ชฉ๋ก์ ํฌํจ๋์ง ์์ ๊ฒฝ์ฐ ์ด๋ฅผ ์ฌ์ฉํ์ฌ ์ธ์คํด์ค๋ฅผ ๋ง๋ค๊ณ Private Service Connect๋ฅผ ์ฌ์ฉ ์ค์ ํ ์ ์์ต๋๋ค.
Cloud SQL์ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ํ์ฉ๋๋ ํ๋ก์ ํธ๋ฅผ ๋ณต์ ๋ณธ์ผ๋ก ๋ณต์ฌํ์ง ์์ต๋๋ค. ๋ณต์ ๋ณธ๋ง๋ค Private Service Connect ์๋ํฌ์ธํธ๋ฅผ ๋ง๋ค์ด์ผ ํฉ๋๋ค. Cloud SQL ์ธ์ฆ ํ๋ก์ ๋๋ Cloud SQL ์ธ์ด ์ปค๋ฅํฐ๋ฅผ ์ฌ์ฉํ๋ ๊ฒฝ์ฐ ๋ณต์ ๋ณธ์ DNS ์์ญ๊ณผ DNS ๋ ์ฝ๋๋ฅผ ๋ง๋ค์ด์ผ ํฉ๋๋ค.
HTTP ๋ฉ์๋ ๋ฐ URL:
PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances
JSON ์์ฒญ ๋ณธ๋ฌธ:
{ "masterInstanceName": "PRIMARY_INSTANCE_NAME", "project": "PROJECT_ID", "databaseVersion": "SQLSERVER_2019_STANDARD", "name": "REPLICA_INSTANCE_NAME", "region": "REGION_NAME", "kind": "sql#instance", "settings": { "tier": "MACHINE_TYPE", "availabilityType": "AVAILABILITY_TYPE", "settingsVersion": 0, "ipConfiguration": { "ipv4Enabled": false, "pscConfig": { "allowedConsumerProjects": [ALLOWED_PROJECTS], "pscEnabled": true } }, "kind": "sql#settings", "pricingPlan": "PER_USE", "replicationType": "ASYNCHRONOUS", "tier": "MACHINE_TYPE" } }
์์ฒญ์ ๋ณด๋ด๋ ค๋ฉด ๋ค์ ์ต์ ์ค ํ๋๋ฅผ ํผ์นฉ๋๋ค.
๋ค์๊ณผ ๋น์ทํ JSON ์๋ต์ด ํ์๋ฉ๋๋ค.
{ "kind": "sql#operation", "targetLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/REPLICA_INSTANCE_NAME", "status": "PENDING", "user": "user@example.com", "insertTime": "2020-01-16T02:32:12.281Z", "operationType": "CREATE_REPLICA", "name": "OPERATION_ID", "targetId": "REPLICA_INSTANCE_NAME", "selfLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/operations/OPERATION_ID", "targetProject": "PROJECT_ID" }
์ฐ์ ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ
์ด ์น์ ์์๋ ์ฐ์ ๋ณต์ ๋ณธ์ ๋ง๋ค๊ณ ๊ด๋ฆฌํ๋ ๋ฐฉ๋ฒ์ ์ค๋ช ํฉ๋๋ค.
์ฐ์ ๋ณต์ ๋ณธ ์๋ ๋ฐฉ์์ ๋ํ ์์ธํ ๋ด์ฉ์ ์ฐ์ ๋ณต์ ๋ณธ์ ์ฐธ์กฐํ์ธ์.
์์ํ๊ธฐ ์ ์
๊ธฐ๋ณธ ์ธ์คํด์ค์๋ ์ฐ์ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ด ์์ด์ผ ํฉ๋๋ค. ๋ค์ ์น์ ์์๋ ๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ ๋ง๋๋ ๋จ๊ณ๋ฅผ ์ ๊ณตํฉ๋๋ค.
๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ ๋จ๊ณ
์ฐ์ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ ๋ง๋ค ๋๋ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋ค๋ฅธ ๋ฆฌ์ ์ ๋ณต์ ๋ณธ์ ๋ง๋ค์ด์ผ ํฉ๋๋ค.
cascadable-replica
ํ๋๊ทธ๋ฅผ ์ค์ ํ์ฌ ๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ ๊ตฌ์ฑํฉ๋๋ค.
gcloud
--master-instance-name
ํ๋๊ทธ๋ฅผ ์ฌ์ฉํ์ฌ ๊ธฐ๋ณธ ์ธ์คํด์ค๋ฅผ ์ง์ ํ๊ณ --cascadable-replica
ํ๋๊ทธ๋ฅผ ์ฌ์ฉํ์ฌ ์ ๋ณต์ ๋ณธ์ ๋ง๋ญ๋๋ค.
gcloud sql instances create REPLICA_NAME \ --master-instance-name=PRIMARY_INSTANCE_NAME \ --cascadable-replica \ --region=REGION
๋ค์์ ๋ฐ๊ฟ๋๋ค.
- REPLICA_NAME: ๋ง๋ค๋ ค๋ ๋ณต์ ๋ณธ์ ๊ณ ์ ID
- PRIMARY_INSTANCE_NAME: ๊ธฐ๋ณธ ์ธ์คํด์ค ์ด๋ฆ์ ๋๋ค.
- REGION: ์ ๋ณต์ ๋ณธ์ ๋ง๋ค๋ ค๋ ๋ฆฌ์ ์ ๋๋ค. ์ด ๋ฆฌ์ ์ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋ฆฌ์ ๊ณผ ๋ฌ๋ผ์ผ ํฉ๋๋ค.
๋ณต์ ๋ณธ์ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋์ผํ VPC ๋คํธ์ํฌ์ ๋ง๋ค์ด์ผ ํฉ๋๋ค. ํด๋น VPC ๋คํธ์ํฌ์์ ํ ๋น๋ IP ๋ฒ์ ์ด๋ฆ์ ์ง์ ํ ์๋ ์์ต๋๋ค. ๋ฒ์๊ฐ ์ง์ ๋์ง ์์ผ๋ฉด ๋ณต์ ๋ณธ์ด ๋ฌด์์ ๋ฒ์๋ก ์์ฑ๋ฉ๋๋ค.
๋ค๋ฅธ ์ธ์คํด์ค ์ค์ ์ ๋งค๊ฐ๋ณ์๋ฅผ ๋ ์ถ๊ฐํ ์ ์์ต๋๋ค. ์๋ฅผ ๋ค๋ฉด ๋ค์๊ณผ ๊ฐ์ต๋๋ค.
--tier
๋งค๊ฐ๋ณ์๋ฅผ ์ฌ์ฉํ์ฌ ๋ค๋ฅธ ๋จธ์ ๋ฑ๊ธ ํฌ๊ธฐ๋ฅผ ์ง์ ํ ์ ์์ต๋๋ค.-
๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋น๊ณต๊ฐ IP ์ฃผ์๋ง ์์ผ๋ฉด ๋ช
๋ น์ด์
--no-assign-ip
๋งค๊ฐ๋ณ์๋ฅผ ์ถ๊ฐํฉ๋๋ค.
์ธ์คํด์ค ์ค์ ์ ๋งค๊ฐ๋ณ์๋ฅผ ์ถ๊ฐํ๋ ๋ฐฉ๋ฒ์ ๊ดํ ์์ธํ ๋ด์ฉ์ gcloud sql instances create๋ฅผ ์ฐธ๊ณ ํ์ธ์.
๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ด ์์ฑ๋ ํ ๊ณ์ธตํ ๋ณต์ ๋ณธ์ ๋ง๋ค ์ ์์ต๋๋ค.
curl
- ๊ธฐ๋ณธ ์ธ์คํด์ค ์๋์ ๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ ๋ง๋ค๋ ค๋ฉด ๋ค์ JSON ์ฝ๋ ์ํ์ ์์ ํ๊ณ
request.json
ํ์ผ์ ์ ์ฅํฉ๋๋ค.์์ฒญ ๋ฐ์ดํฐ๋ฅผ ์ฌ์ฉํ๊ธฐ ์ ์ ๋ค์์ ๋ฐ๊ฟ๋๋ค.
- PROJECT_ID: ํ๋ก์ ํธ ID์ ๋๋ค.
- DATABASE_VERSION: ๋ฐ์ดํฐ๋ฒ ์ด์ค ๋ฒ์ ์ ์ด๊ฑฐํ ๋ฌธ์์ด์
๋๋ค. ์๋ฅผ ๋ค๋ฉด
SQLSERVER_2017_ENTERPRISE.
์ ๋๋ค. - PRIMARY_INSTANCE_NAME: ๊ธฐ๋ณธ ์ธ์คํด์ค ์ด๋ฆ์ ๋๋ค.
- PRIMARY_INSTANCE_REGION: ๊ธฐ๋ณธ ์ธ์คํด์ค์ ๋ฆฌ์
- REPLICA_REGION: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ๋ฆฌ์
- REPLICA_NAME: ๋ณต์ ๋ณธ ์ธ์คํด์ค์ ์ด๋ฆ
- MACHINE_TYPE: ๋จธ์ ์ ํ์ ์ด๊ฑฐํ ๋ฌธ์์ด ์๋ฅผ ๋ค๋ฉด
db-custom-2-3840
์ ๋๋ค.
{ "masterInstanceName": "PRIMARY_INSTANCE_NAME", "project": "PROJECT_ID", "databaseVersion": "DATABASE_VERSION" "name": "REPLICA_NAME", "region": "REPLICA_REGION", "settings": { "tier": "MACHINE_TYPE", "settingsVersion": 0, } "replicaConfiguration": { "cascadableReplica": true } }
replicaConfiguration
์น์ ์์cascadadableReplica
ํ๋๊ฐtrue
๋ก ์ค์ ๋์ด ์๋์ง ํ์ธํฉ๋๋ค.- ๋ค์ ๋ช
๋ น์ด๋ฅผ ์คํํฉ๋๋ค.
curl -X POST -H "Authorization: Bearer "$(gcloud auth print-access-token) -H "Content-Type: application/json; charset=utf-8" -d @request.json "https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances"
๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ด ์์ฑ๋ ํ ๊ณ์ธตํ ๋ณต์ ๋ณธ์ ๋ง๋ค ์ ์์ต๋๋ค.
์ฐ์ ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ ๋จ๊ณ
์ฐ์ ๋ณต์ ๋ณธ์ ๋ง๋ค ๋๋ ์ฐ์ ๋ณต์ ๋ณธ๊ณผ ๋์ผํ ๋ฆฌ์ ์ ๋ณต์ ๋ณธ์ ๋ง๋ค์ด์ผ ํฉ๋๋ค.โmaster-instance-name
๋งค๊ฐ๋ณ์์ ๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ ์ด๋ฆ์ ์ ๊ณตํ์ฌ ๊ณ์ธตํ ๋ณต์ ๋ณธ์ ๊ตฌ์ฑํฉ๋๋ค.
Console
-
Google Cloud ์ฝ์์์ Cloud SQL ์ธ์คํด์ค ํ์ด์ง๋ก ์ด๋ํฉ๋๋ค.
- ๋ง๋ค๋ ค๋ ๋ณต์ ๋ณธ์ ์์ ์์ ์ญํ ์ ํ ๋ณต์ ๋ณธ์ ๋ณต์ ๋ณธ ํญ์ ํด๋ฆญํฉ๋๋ค.
- ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ๋ฅผ ํด๋ฆญํฉ๋๋ค.
- ์ฝ๊ธฐ ๋ณต์ ๋ณธ ๋ง๋ค๊ธฐ ํ์ด์ง์์ ์ธ์คํด์ค ID๋ฅผ ๋น๋กฏํด ์ด๋ฆ, ๋ฆฌ์ , ์์ญ ๋ฑ์ ๊ธฐํ ๊ตฌ์ฑ ์ต์ ์ ์ ๋ฐ์ดํธํฉ๋๋ค.
- ๋ง๋ค๊ธฐ๋ฅผ ํด๋ฆญํฉ๋๋ค.
Cloud SQL์ ๋ณต์ ๋ณธ์ ๋ง๋ญ๋๋ค. ์์ ๋ณต์ ๋ณธ์ ์ธ์คํด์ค ํ์ด์ง๊ฐ ๋ค์ ํ์๋ฉ๋๋ค.
- ๋ง๋ค๋ ค๋ ์ ์ฐ์ ๋ณต์ ๋ณธ๋ง๋ค 4~6๋จ๊ณ๋ฅผ ์ํํฉ๋๋ค.
gcloud
--master-instance-name
ํ๋๊ทธ์์ ๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ ์ธ์คํด์ค๋ฅผ ์ง์ ํ์ฌ ์ ๋ณต์ ๋ณธ์ ๋ง๋ญ๋๋ค.- REPLICA_NAME: ๋ง๋ค๋ ค๋ ๋ณต์ ๋ณธ์ ๊ณ ์ ID
- CASCADABLE_REPLICA_NAME: ๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ์ ์ด๋ฆ
- ์ฐ์ ๋ณต์ ๋ณธ์ ๋ง๋ ํ ๊ธฐ๋ณธ ์ธ์คํด์ค์ ์ํ๋ ๋ณ๊ฒฝ์ฌํญ์ด ์ฐ์ ๋ณต์ ์ฒด์ธ์ ์๋ ๋ชจ๋ ๋ณต์ ๋ณธ์ ๋ณต์ ๋์๋์ง ํ์ธํ ์ ์์ต๋๋ค.
gcloud sql instances create REPLICA_NAME \ --master-instance-name=CASCADABLE_REPLICA_NAME \
curl
- ๊ณ์ธตํ ๊ฐ๋ฅํ ๋ณต์ ๋ณธ ์๋์ ๊ณ์ธตํ ๋ณต์ ๋ณธ์ ๋ง๋ค๋ ค๋ฉด ๋ค์ JSON ์ฝ๋ ์ํ์ ์์ ํ๊ณ
request.json
ํ์ผ์ ์ ์ฅํฉ๋๋ค.{ "masterInstanceName": "CASCADABLE_REPLICA_NAME", "project": "PROJECT_ID", "name": "REPLICA_NAME", "region": "REPLICA_REGION", "settings": { "tier": "MACHINE_TYPE", } }
- ๋ค์ ๋ช
๋ น์ด๋ฅผ ์คํํฉ๋๋ค.
curl -X POST -H "Authorization: Bearer "$(gcloud auth print-access-token) -H "Content-Type: application/json; charset=utf-8" -d @request.json "https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances"
๋ฌธ์ ํด๊ฒฐ
๋ฌธ์ | ๋ฌธ์ ํด๊ฒฐ |
---|---|
์์ฑ ์ ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ด ๋ณต์ ๋ฅผ ์์ํ์ง ์์ | ๋ก๊ทธ ํ์ผ์ ๋ ๊ตฌ์ฒด์ ์ธ ์ค๋ฅ๊ฐ ์์ ์ ์์ต๋๋ค. Cloud Logging์ ๋ก๊ทธ๋ฅผ ๊ฒ์ฌํ์ฌ ์ค์ ์ค๋ฅ๋ฅผ ์ฐพ์ผ์ธ์. |
์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ค ์ ์์ - invalidFlagValue ์ค๋ฅ | ์์ฒญ์ ํ๋๊ทธ ์ค ํ๋๊ฐ ์๋ชป๋์์ต๋๋ค. ๋ช
์์ ์ผ๋ก ์ ๊ณตํ ํ๋๊ทธ ๋๋ ๊ธฐ๋ณธ๊ฐ์ผ๋ก ์ค์ ๋ ํ๋๊ทธ์ผ ์ ์์ต๋๋ค.
๋จผ์
|
์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ค ์ ์์ - ์ ์ ์๋ ์ค๋ฅ | ๋ก๊ทธ ํ์ผ์ ๋ ๊ตฌ์ฒด์ ์ธ ์ค๋ฅ๊ฐ ์์ ์ ์์ต๋๋ค.
Cloud Logging์ ๋ก๊ทธ๋ฅผ ๊ฒ์ฌํ์ฌ ์ค์ ์ค๋ฅ๋ฅผ ์ฐพ์ผ์ธ์.
์ค๋ฅ๊ฐ |
๋์คํฌ๊ฐ ๊ฐ๋ ์ฐธ | ๋ณต์ ๋ณธ์ ๋ง๋๋ ๋์ ๊ธฐ๋ณธ ์ธ์คํด์ค ๋์คํฌ ํฌ๊ธฐ๊ฐ ๊ฐ๋ ์ฐฐ ์ ์์ต๋๋ค. ๊ธฐ๋ณธ ์ธ์คํด์ค๋ฅผ ์์ ํ์ฌ ๋ ํฐ ๋์คํฌ ํฌ๊ธฐ๋ก ์ ๊ทธ๋ ์ด๋ํฉ๋๋ค. |
๋ณต์ ๋ณธ ์ธ์คํด์ค๊ฐ ๋๋ฌด ๋ง์ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ์ฌ์ฉํ๊ณ ์์ต๋๋ค. | ๋ณต์ ๋ณธ์ ์์ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ์ฌ์ฉํ์ฌ ์์ฃผ ์์ฒญ๋๋ ์ฝ๊ธฐ ์์
์ ์บ์ํ๋ฏ๋ก ๊ธฐ๋ณธ ์ธ์คํด์ค๋ณด๋ค ๋ ๋ง์ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ์ฌ์ฉํ ์ ์์ต๋๋ค.
๋ณต์ ๋ณธ ์ธ์คํด์ค๋ฅผ ๋ค์ ์์ํ์ฌ ์์ ๋ฉ๋ชจ๋ฆฌ ๊ณต๊ฐ์ ํ์ํฉ๋๋ค. |
๋ณต์ ๊ฐ ์ค์ง๋์์ต๋๋ค. | ์ต๋ ์คํ ๋ฆฌ์ง ํ๋์ ๋๋ฌํ๊ณ ์คํ ๋ฆฌ์ง ์๋ ์ฆ๊ฐ๊ฐ ์ฌ์ฉ ์ค์ ๋์ง ์์์ต๋๋ค.
์ธ์คํด์ค๋ฅผ ์์ ํ์ฌ |
๊ธด ๋ณต์ ์ง์ฐ ์๊ฐ์ด ์ง์์ ์ผ๋ก ๋ฐ์ํจ | ์ฐ๊ธฐ ๋ถํ๊ฐ ๋๋ฌด ๋์ ๋ณต์ ๋ณธ์ด ์ฒ๋ฆฌํ ์ ์์ต๋๋ค. ๋ณต์ ๋ณธ์ SQL ์ค๋ ๋๊ฐ IO ์ค๋ ๋๋ฅผ ๋ฐ๋ผ์ก์ ์ ์๋ ๊ฒฝ์ฐ ๋ณต์ ์ง์ฐ์ด ๋ฐ์ํฉ๋๋ค. ์ผ๋ถ ์ฟผ๋ฆฌ ๋๋ ์ํฌ๋ก๋๋ก ์ธํด ํน์ ์คํค๋ง์์ ์ผ์์ ์ด๊ฑฐ๋ ์๊ตฌ์ ์ธ ๋ณต์ ์ง์ฐ์ด ๋ฐ์ํ ์ ์์ต๋๋ค. ๋ณต์ ์ง์ฐ์ด ๋ฐ์ํ๋ ์ผ๋ฐ์ ์ธ ์์ธ์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.
๊ฐ๋ฅํ ์๋ฃจ์ ์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.
|
์ ํ ์๊ฐ์ผ๋ก ์ธํด ๋ณต์ ๋ณธ์ ๋ง๋ค์ง ๋ชปํ์ต๋๋ค. | ๊ธฐ๋ณธ ์ธ์คํด์ค์์ ์ปค๋ฐ๋์ง ์์ ์ฅ๊ธฐ ์คํ ํธ๋์ญ์
์ผ๋ก ์ธํด ์ฝ๊ธฐ ๋ณต์ ๋ณธ์ ๋ง๋ค์ง ๋ชปํ ์ ์์ต๋๋ค.
์คํ ์ค์ธ ๋ชจ๋ ์ฟผ๋ฆฌ๋ฅผ ์ค์งํ ํ ๋ณต์ ๋ณธ์ ๋ค์ ๋ง๋ญ๋๋ค. |
๋ค์ ๋จ๊ณ
- ๋ณต์ ๋ณธ ๊ด๋ฆฌ ๋ฐฉ๋ฒ ์์๋ณด๊ธฐ
- ๋ฆฌ์ ๊ฐ ๋ณต์ ๋ณธ ์์๋ณด๊ธฐ