Memigrasikan data antara SQL Server 2017 dan Cloud SQL untuk SQL Server menggunakan file cadangan


Dalam tutorial ini, Anda akan memigrasikan data dari SQL Server 2017 Enterprise yang berjalan di Compute Engine ke Cloud SQL untuk SQL Server 2017 Enterprise. Tutorial ini menunjukkan cara mengekspor data dari SQL Server 2017, mengimpor data ke Cloud SQL untuk SQL Server 2017, dan memvalidasi bahwa data berhasil diimpor.

Jika Anda ingin memigrasikan data dari SQL Server 2008, lihat Memigrasikan data antara SQL Server 2008 dan Cloud SQL untuk SQL Server menggunakan file cadangan.

Tutorial ini berguna jika Anda merupakan sysadmin, developer, engineer, admin database, atau engineer DevOps yang ingin memigrasikan data dari SQL Server 2017 ke Cloud SQL untuk SQL Server.

Tutorial ini mengasumsikan bahwa Anda sudah memahami hal-hal berikut:

Tujuan

  • Membuat instance virtual machine (VM) SQL Server di Compute Engine untuk menghosting database sampel.
  • Membuat instance Cloud SQL untuk SQL Server.
  • Membuat bucket Cloud Storage.
  • Mencadangkan database sampel.
  • Mengimpor database ke Cloud SQL untuk SQL Server.
  • Memvalidasi data yang diimpor.

Biaya

Dalam dokumen ini, Anda akan menggunakan komponen Google Cloud yang dapat ditagih berikut: Google Cloud:

Untuk membuat perkiraan biaya berdasarkan proyeksi penggunaan Anda, gunakan kalkulator harga. Pengguna Google Cloud baru mungkin memenuhi syarat untuk mendapatkan uji coba gratis.

Setelah menyelesaikan tugas yang dijelaskan dalam dokumen ini, Anda dapat menghindari penagihan berkelanjutan dengan menghapus resource yang Anda buat. Untuk mengetahui informasi selengkapnya, lihat Pembersihan.

Sebelum memulai

  1. Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  3. Make sure that billing is enabled for your Google Cloud project.

  4. Enable the Cloud Storage, Cloud SQL Admin, and Compute Engine APIs.

    Enable the APIs

  5. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  6. Make sure that billing is enabled for your Google Cloud project.

  7. Enable the Cloud Storage, Cloud SQL Admin, and Compute Engine APIs.

    Enable the APIs

  8. In the Google Cloud console, activate Cloud Shell.

    Activate Cloud Shell

    At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.

Membuat skrip untuk database sampel

Di bagian ini, Anda akan membuat skrip untuk mengisi database contoh yang telah dimuat sebelumnya. Kemudian, Anda membuat instance SQL Server 2017 pada Compute Engine yang menggunakan database ini.

  1. Di Cloud Shell, buat skrip PowerShell untuk men-deploy sebagai skrip startup:

    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
    

    Skrip startup ini membuat database lokal bernama testdb dengan tabel bernama MarylandZipCodes. Kemudian, skrip akan mendownload registry kode pos publik Maryland dan mengimpor registry ke dalam tabel.

  2. Buat instance SQL Server 2017 Enterprise untuk Windows Server 2016:

    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
    

    Untuk tutorial ini, Anda membuat instance di zona us-central1-f dengan ukuran boot disk sebesar 50 GB. Untuk mengetahui informasi selengkapnya tentang zona, lihat Lokasi Cloud. Flag --metadata-from-file menetapkan skrip PowerShell menjadi skrip startup untuk instance tersebut.

Membuat instance Cloud SQL dan bucket Cloud Storage

  1. Di Cloud Shell, buat instance Cloud SQL untuk SQL Server 2017 Enterprise yang nantinya akan menjadi tujuan migrasi database:

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

    Diperlukan waktu beberapa menit untuk membuat instance. Nama pengguna root default adalah sqlserver dengan sandi default sqlserver12@. Untuk tutorial ini, Anda akan membuat instance di zona us-central1-f. Untuk mengetahui informasi selengkapnya tentang zona, lihat Lokasi Cloud.

  2. Buat bucket Cloud Storage untuk menyimpan file cadangan sebelum data diimpor ke Cloud SQL:

    gcloud storage buckets create "gs://${DEVSHELL_PROJECT_ID}-sql-backups" --location=US
    

Mencadangkan database sampel

Di bagian ini, Anda akan terhubung ke mesin virtual (VM) SQL Server, membuat cadangan database, dan mengupload database cadangan ke Cloud Storage.

  1. Di Cloud Shell, reset sandi untuk instance VM SQL Server:

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

    Catat sandi baru untuk pengguna tersebut.

  2. Instal klien Remote Desktop Protocol (RDP). Untuk informasi selengkapnya, lihat Klien Desktop Jarak Jauh Microsoft.

  3. Di konsol Google Cloud , buka halaman Instance VM.

    BUKA HALAMAN VM INSTANCES

  4. Di bagian Compute Engine pada konsol Google Cloud , klik menu dropdown RDP dan pilih opsi Download the RDP file untuk mendownload file RDP untuk instance VM SQL Server Anda.

    Gunakan file ini untuk terhubung ke instance menggunakan klien RDP. Untuk informasi selengkapnya, lihat Klien Desktop Jarak Jauh Microsoft.

  5. Di browser, minimalkan semua jendela, lalu luncurkan alat command line PowerShell.

  6. Buat folder cadangan:

    mkdir c:\backup
    
  7. Di browser, buat cadangan database di folder cadangan:

    osql -E -Q "BACKUP DATABASE testdb TO DISK='c:\backup\testdb.bak'"
    
  8. Di shell dalam instance, salin file cadangan ke bucket Cloud Storage:

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

Mengimpor file cadangan ke Cloud SQL

  1. Di Cloud Shell, ambil akun layanan yang terkait dengan instance Cloud SQL dan simpan dalam variabel:

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

    Google Cloud membuat akun layanan saat Anda membuat instance Cloud SQL. Anda dapat menggunakan akun layanan untuk memberikan izin instance Cloud SQL guna mengakses resource yang diperlukan.

  2. Berikan izin akun layanan untuk menulis ke bucket Cloud Storage:

    gcloud storage buckets add-iam-policy-binding gs://${DEVSHELL_PROJECT_ID}-sql-backups \
        --member=serviceAccount:${SVC_EMAIL_ADDRESS} \
        --role=roles/storage.legacyBucketWriter
    
  3. Berikan izin akun layanan untuk membaca file di bucket Cloud Storage:

    gcloud storage buckets add-iam-policy-binding gs://${DEVSHELL_PROJECT_ID}-sql-backups/testdb.bak \
        --member=serviceAccount:${SVC_EMAIL_ADDRESS} \
        --role=roles/storage.legacyObjectReader
    
  4. Impor file cadangan ke database Cloud SQL:

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

Memvalidasi impor data

Di bagian ini, Anda akan memeriksa apakah data sampel berhasil diimpor.

  1. Di Cloud Shell, instal toolkit SQL Server:

    sudo apt-get install -y mssql-tools
    

    Jika Anda menyetujui persyaratan lisensi, masukkan yes saat diminta.

  2. Untuk mengakses instance Cloud SQL dengan aman, download proxy Cloud SQL:

    wget https://dl.google.com/cloudsql/cloud_sql_proxy.linux.amd64 -O cloud_sql_proxy
    
  3. Mulai proxy Cloud SQL:

    CONNECTION_NAME=$(gcloud sql instances describe target --format='value(connectionName)')
    ./cloud_sql_proxy -instances=${CONNECTION_NAME}=tcp:1433 &
    
  4. Baca jumlah baris dalam tabel Cloud SQL:

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

    Saat diminta, masukkan sandi sqlserver12@. Pada output, pastikan hasilnya adalah 619.

Pembersihan

Cara termudah untuk menghilangkan penagihan adalah dengan menghapus project Google Cloud yang Anda buat untuk tutorial.

Menghapus project

  1. In the Google Cloud console, go to the Manage resources page.

    Go to Manage resources

  2. In the project list, select the project that you want to delete, and then click Delete.
  3. In the dialog, type the project ID, and then click Shut down to delete the project.

Langkah berikutnya