백업 파일을 사용하여 SQL Server 2017과 SQL Server용 Cloud SQL 사이에 데이터 마이그레이션


이 가이드에서는 Compute Engine에서 실행되는 SQL Server 2017 Enterprise에서 SQL Server 2017 Enterprise용 Cloud SQL로 데이터를 마이그레이션합니다. 이 가이드에서는 SQL Server 2017에서 데이터를 내보내고, 데이터를 SQL Server 2017용 Cloud SQL로 가져오고, 데이터 가져오기가 성공했는지 검증하는 방법을 보여줍니다.

SQL Server 2008에서 데이터를 마이그레이션하려면 백업 파일을 사용하여 SQL Server 2008과 SQL Server용 Cloud SQL 사이에 데이터 마이그레이션을 참조하세요.

이 가이드는 SQL Server 2017에서 SQL Server용 Cloud SQL로 데이터를 마이그레이션하려는 시스템 관리자, 개발자, 엔지니어, 데이터베이스 관리자, DevOps 엔지니어에게 유용합니다.

이 가이드에서는 사용자가 다음 항목에 익숙하다고 가정합니다.

목표

  • Compute Engine에서 샘플 데이터베이스를 호스팅하기 위한 SQL Server 가상 머신(VM) 인스턴스를 만듭니다.
  • SQL Server용 Cloud SQL 인스턴스를 만듭니다.
  • Cloud Storage 버킷을 만듭니다.
  • 샘플 데이터베이스를 백업합니다.
  • SQL Server용 Cloud SQL로 데이터베이스를 가져옵니다.
  • 가져온 데이터를 검증합니다.

비용

이 문서에서는 비용이 청구될 수 있는 다음과 같은 Google Cloud 구성요소를 사용합니다.

프로젝트 사용량을 기준으로 예상 비용을 산출하려면 가격 계산기를 사용하세요. Google Cloud를 처음 사용하는 사용자는 무료 체험판을 사용할 수 있습니다.

이 문서에 설명된 태스크를 완료했으면 만든 리소스를 삭제하여 청구가 계속되는 것을 방지할 수 있습니다. 자세한 내용은 삭제를 참조하세요.

시작하기 전에

  1. Google Cloud 계정에 로그인합니다. Google Cloud를 처음 사용하는 경우 계정을 만들고 Google 제품의 실제 성능을 평가해 보세요. 신규 고객에게는 워크로드를 실행, 테스트, 배포하는 데 사용할 수 있는 $300의 무료 크레딧이 제공됩니다.
  2. Google Cloud Console의 프로젝트 선택기 페이지에서 Google Cloud 프로젝트를 선택하거나 만듭니다.

    프로젝트 선택기로 이동

  3. Google Cloud 프로젝트에 결제가 사용 설정되어 있는지 확인합니다.

  4. API Cloud Storage, Cloud SQL Admin, and Compute Engine 사용 설정

    API 사용 설정

  5. Google Cloud Console의 프로젝트 선택기 페이지에서 Google Cloud 프로젝트를 선택하거나 만듭니다.

    프로젝트 선택기로 이동

  6. Google Cloud 프로젝트에 결제가 사용 설정되어 있는지 확인합니다.

  7. API Cloud Storage, Cloud SQL Admin, and Compute Engine 사용 설정

    API 사용 설정

  8. Google Cloud 콘솔에서 Cloud Shell을 활성화합니다.

    Cloud Shell 활성화

    Google Cloud 콘솔 하단에서 Cloud Shell 세션이 시작되고 명령줄 프롬프트가 표시됩니다. Cloud Shell은 Google Cloud CLI가 사전 설치된 셸 환경으로, 현재 프로젝트의 값이 이미 설정되어 있습니다. 세션이 초기화되는 데 몇 초 정도 걸릴 수 있습니다.

샘플 데이터베이스 스크립트 만들기

이 섹션에서는 사전 로드된 샘플 데이터베이스를 채우기 위한 스크립트를 만듭니다. 그런 후 Compute Engine에 이 데이터베이스를 사용하는 SQL Server 2017 인스턴스를 만듭니다.

  1. Cloud Shell에서 시작 스크립트로 배포할 PowerShell 스크립트를 만듭니다.

    cat << 'EOF' > startup.ps1
    [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
    $dataseturl = "https://opendata.maryland.gov/api/views/ryxx-aeaf/rows.csv?accessType=DOWNLOAD"
    Invoke-WebRequest -Uri $dataseturl -OutFile c:\dataset.csv
    Invoke-Sqlcmd -Query "CREATE DATABASE testdb;"
    Invoke-Sqlcmd -Query "CREATE TABLE testdb.dbo.MarylandZipCodes ( zipcode int NOT NULL PRIMARY KEY,  city varchar(255), county varchar(255))"
    Invoke-Sqlcmd -Query "BULK INSERT testdb.dbo.MarylandZipCodes FROM 'c:\dataset.csv' WITH (DATAFILETYPE='char',FIELDTERMINATOR=',' ,ROWTERMINATOR = '0x0a',  FIRSTROW=2);"
    EOF
    

    이 시작 스크립트는 MarylandZipCodes 테이블이 포함된 testdb라는 로컬 데이터베이스를 만듭니다. 그런 후 스크립트가 메릴랜드 공개 우편번호 레지스트리를 다운로드하고 레지스트리를 테이블로 가져옵니다.

  2. Windows Server 2016용 SQL Server 2017 Enterprise 인스턴스를 만듭니다.

    gcloud compute instances create sql-server --machine-type n1-highmem-4 \
        --boot-disk-size 50GB \
      --image-project windows-sql-cloud --image-family sql-ent-2017-win-2016 \
      --zone us-central1-f  \
      --scopes=https://www.googleapis.com/auth/cloud-platform \
      --metadata-from-file windows-startup-script-ps1=startup.ps1
    

    이 가이드에서는 us-central1-f 영역에 부팅 디스크 크기가 50GB인 인스턴스를 만듭니다. 영역에 대한 자세한 내용은 Cloud 위치를 참조하세요. --metadata-from-file 플래그는 PowerShell 스크립트를 인스턴스의 시작 스크립트로 설정합니다.

Cloud SQL 인스턴스 및 Cloud Storage 버킷 만들기

  1. Cloud Shell에서 나중에 데이터베이스를 마이그레이션할 SQL Server 2017 Enterprise용 Cloud SQL 인스턴스를 만듭니다.

    gcloud beta sql instances create target  \
        --database-version=SQLSERVER_2017_ENTERPRISE \
        --cpu=2 \
        --memory=5GB \
        --root-password=sqlserver12@ \
        --zone=us-central1-f
    

    인스턴스를 만드는 데 몇 분 정도 걸릴 수 있습니다. 기본 루트 사용자 이름은 sqlserver이고 기본 비밀번호는 sqlserver12@입니다. 이 가이드에서는 us-central1-f 영역에 인스턴스를 만듭니다. 영역에 대한 자세한 내용은 Cloud 위치를 참조하세요.

  2. 데이터를 Cloud SQL로 가져오기 전에 백업 파일을 저장할 Cloud Storage 버킷을 만듭니다.

    gsutil mb -l US "gs://${DEVSHELL_PROJECT_ID}-sql-backups"
    

샘플 데이터베이스 백업

이 섹션에서는 SQL Server 가상 머신(VM)에 연결하고, 데이터베이스 백업을 만들고, 백업 데이터베이스를 Cloud Storage에 업로드합니다.

  1. Cloud Shell에서 SQL Server VM 인스턴스에 대해 비밀번호를 재설정합니다.

    gcloud compute reset-windows-password sql-server --zone=us-central1-f
    

    사용자의 새 비밀번호를 기록해 둡니다.

  2. 원격 데스크톱 프로토콜(RDP) 클라이언트를 설치합니다. 자세한 내용은 Microsoft 원격 데스크톱 클라이언트를 참조하세요.

  3. Google Cloud Console에서 VM 인스턴스 페이지로 이동합니다.

    VM 인스턴스 페이지로 이동

  4. Google Cloud 콘솔의 Compute Engine 섹션에서 RDP 드롭다운을 클릭하고 RDP 파일 다운로드 옵션을 선택하여 SQL Server VM 인스턴스용 RDP 파일을 다운로드합니다.

    이 파일을 사용하여 RDP 클라이언트를 사용하는 인스턴스에 연결합니다. 자세한 내용은 Microsoft 원격 데스크톱 클라이언트를 참조하세요.

  5. 브라우저에서 모든 창을 최소화하고 PowerShell 명령줄 도구를 시작합니다.

  6. 백업 폴더를 만듭니다.

    mkdir c:\backup
    
  7. 브라우저에서 백업 폴더에 데이터베이스 백업을 만듭니다.

    osql -E -Q "BACKUP DATABASE testdb TO DISK='c:\backup\testdb.bak'"
    
  8. 인스턴스의 셸에서 백업 파일을 Cloud Storage 버킷에 복사합니다.

    $PROJECT_ID=(gcloud config get-value core/project)
    
    gsutil cp -n c:\backup\testdb.bak gs://$PROJECT_ID-sql-backups
    

Cloud SQL로 백업 파일 가져오기

  1. Cloud Shell에서 Cloud SQL 인스턴스와 연결된 서비스 계정을 검색하고 이를 변수에 저장합니다.

    SVC_EMAIL_ADDRESS=$(gcloud sql instances describe target \
        --format='value(serviceAccountEmailAddress)')
    echo $SVC_EMAIL_ADDRESS
    

    Cloud SQL 인스턴스를 만들 때 Google Cloud에서 서비스 계정이 생성됩니다. 서비스 계정을 사용하여 Cloud SQL 인스턴스에 필요한 리소스에 액세스하기 위한 권한을 제공합니다.

  2. 쓰기 권한을 사용해서 Cloud Storage 버킷의 액세스 제어 목록(ACL)에 서비스 계정을 추가합니다.

    gsutil acl ch -u ${SVC_EMAIL_ADDRESS}:W gs://${DEVSHELL_PROJECT_ID}-sql-backups
    
  3. 읽기 권한을 사용해서 가져오기 파일에 서비스 계정을 추가합니다.

    gsutil acl ch -u $SVC_EMAIL_ADDRESS:R gs://${DEVSHELL_PROJECT_ID}-sql-backups/testdb.bak
    
  4. 백업 파일을 Cloud SQL 데이터베이스로 가져옵니다.

    gcloud beta sql import bak target \
        gs://${DEVSHELL_PROJECT_ID}-sql-backups/testdb.bak --database testdb
    

데이터 가져오기 검증

이 섹션에서는 샘플 데이터를 성공적으로 가져왔는지 확인합니다.

  1. Cloud Shell에서 SQL Server 툴킷을 설치합니다.

    sudo apt-get install -y mssql-tools
    

    라이선스 조건에 동의하면 메시지가 표시되었을 때 yes를 입력합니다.

  2. Cloud SQL 인스턴스에 안전하게 액세스하려면 Cloud SQL 프록시를 다운로드합니다.

    wget https://dl.google.com/cloudsql/cloud_sql_proxy.linux.amd64 -O cloud_sql_proxy
    
  3. Cloud SQL 프록시를 시작합니다.

    CONNECTION_NAME=$(gcloud sql instances describe target --format='value(connectionName)')
    ./cloud_sql_proxy -instances=${CONNECTION_NAME}=tcp:1433 &
    
  4. Cloud SQL 테이블에서 행 수를 읽습니다.

    /opt/mssql-tools/bin/sqlcmd -U sqlserver -S 127.0.0.1 -Q "select count(*)
    from testdb.dbo.MarylandZipCodes"
    

    메시지가 표시되면 sqlserver12@ 비밀번호를 입력합니다. 출력에서 결과가 619인지 확인합니다.

삭제

비용이 청구되지 않도록 하는 가장 쉬운 방법은 가이드에서 만든 Google Cloud 프로젝트를 삭제하는 것입니다.

프로젝트 삭제

  1. Google Cloud 콘솔에서 리소스 관리 페이지로 이동합니다.

    리소스 관리로 이동

  2. 프로젝트 목록에서 삭제할 프로젝트를 선택하고 삭제를 클릭합니다.
  3. 대화상자에서 프로젝트 ID를 입력한 후 종료를 클릭하여 프로젝트를 삭제합니다.

다음 단계