Memigrasikan VM Linux menggunakan CLI Migrate to Containers

Dalam panduan memulai ini, Anda akan membuat instance virtual machine (VM) Compute Engine, lalu gunakan Migrate to Containers CLI untuk memigrasikan VM ke Google Kubernetes Engine (GKE).

Sebelum memulai

  1. Di Konsol Google Cloud, pada halaman pemilih project, pilih atau membuat project Google Cloud.

    Buka pemilih project

  2. Pastikan penagihan diaktifkan untuk project Google Cloud Anda. Pelajari cara memeriksa apakah penagihan diaktifkan pada project.

  3. Aktifkan Compute Engine API.

    Mengaktifkan Compute Engine API

  4. Mengaktifkan GKE API.

    Mengaktifkan GKE API

Membuat VM Compute Engine dengan server web untuk digunakan sebagai VM sumber

Bagian ini menjelaskan cara membuat VM Compute Engine yang menyalurkan Hello World! yang dapat Anda gunakan untuk pengujian setelah migrasi adalah selesai.

  1. Di Konsol Google Cloud, klik Tombol Activate ShellAktifkan Cloud Shell.

    Buka konsol Google Cloud

  2. Buat VM:

    gcloud compute instances create quickstart-source-vm \
      --zone=us-central1-a --machine-type=e2-medium  \
      --subnet=default --scopes="cloud-platform" \
      --tags=http-server,https-server --image=ubuntu-2204-jammy-v20240208 \
      --image-project=ubuntu-os-cloud --boot-disk-size=10GB --boot-disk-type=pd-standard \
      --boot-disk-device-name=quickstart-source-vm
    

    Tunggu beberapa menit sampai pembuatan VM selesai.

  3. Buat aturan firewall yang mengizinkan permintaan ke instance melalui HTTP:

    gcloud compute firewall-rules create default-allow-http \
      --direction=INGRESS --priority=1000 --network=default --action=ALLOW \
      --rules=tcp:80 --source-ranges=0.0.0.0/0 --target-tags=http-server
    
  4. Buka halaman VM instances.

    Buka instance VM

  5. Untuk terhubung ke VM quickstart-source-vm, temukan baris untuk VM tersebut, lalu klik SSH.

    Koneksi dibuat di tab baru.

  6. Pada tab perintah quickstart-source-vm, instal paket apache2:

    sudo apt-get update && sudo apt-get install apache2 -y
    

    Setelah menginstal Apache, sistem operasi akan otomatis memulai server Apache.

  7. Pada tab yang sama, timpa laman web {i>default<i} server web Apache dengan halaman baru:

    echo '<!doctype html><html><body><h1>Hello World!</h1></body></html>' | sudo tee /var/www/html/index.html
    
  8. Kembali ke halaman VM instances, lalu salin alamat External IP. ditampilkan untuk quickstart-source-vm.

  9. Tempel alamat IP VM di kolom URL browser Anda. Awali dengan http://.

    Halaman Hello World! akan muncul.

Membuat VM Compute Engine untuk digunakan sebagai mesin lokal

Di bagian ini, Anda akan membuat VM Linux yang dapat Anda gunakan sebagai mesin lokal untuk melakukan operasi Migrate to Containers yang berbeda guna memigrasikan sumber Pesan Suara.

  1. Di Konsol Google Cloud, klik Tombol Activate ShellAktifkan Cloud Shell.

    Buka konsol Google Cloud

  2. Buat VM:

    gcloud compute instances create quickstart-local-vm \
      --zone=us-central1-a --machine-type=e2-medium  \
      --subnet=default --scopes="cloud-platform" \
      --tags=http-server,https-server --image=ubuntu-2204-jammy-v20240208 \
      --image-project=ubuntu-os-cloud --boot-disk-size=50GB --boot-disk-type=pd-standard \
      --boot-disk-device-name=quickstart-local-vm
    

    Tunggu beberapa menit sampai pembuatan VM selesai.

Membuat cluster GKE

Di bagian ini, Anda akan membuat cluster GKE di Google Cloud, tempat Anda men-deploy workload dalam container nanti dalam panduan memulai ini.

  • Di Cloud Shell, buat cluster Kubernetes baru:

    gcloud container clusters create quickstart-cluster \
      --zone=us-central1-a --machine-type=e2-medium \
      --image-type=ubuntu_containerd --num-nodes=1 \
      --logging=SYSTEM,WORKLOAD,API_SERVER,SCHEDULER,CONTROLLER_MANAGER
    

    Tunggu beberapa menit sampai pembuatan cluster selesai.

Menyiapkan VM lokal untuk melakukan migrasi

  1. Buka halaman VM instances.

    Buka instance VM

  2. Untuk terhubung ke VM quickstart-local-vm, temukan baris untuk VM tersebut, lalu klik SSH.

    Koneksi dibuat di tab baru.

  3. Pada tab perintah quickstart-local-vm, instal Google Cloud CLI:

    # Import the Google Cloud public key.
    curl https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo gpg --dearmor -o /usr/share/keyrings/cloud.google.gpg
    
    # Add the gcloud CLI distribution URI as a package source
    echo "deb [signed-by=/usr/share/keyrings/cloud.google.gpg] https://packages.cloud.google.com/apt cloud-sdk main" | sudo tee -a /etc/apt/sources.list.d/google-cloud-sdk.list
    
    # Update and install gcloud
    sudo apt-get update && sudo apt-get install google-cloud-cli
    
    # Get started
    gcloud init
    

    Untuk menyelesaikan penyiapan gcloud CLI, ikuti petunjuknya yang muncul di tab perintah quickstart-local-vm:

    1. Untuk memilih akun yang akan digunakan untuk melakukan berbagai operasi, masukkan 1.
    2. Untuk memilih project tempat Anda membuat VM, masukkan 1.
    3. Untuk melewati proses konfigurasi region dan zona default, masukkan n.
  4. Instal Docker dan izinkan pengguna non-root menjalankan container:

    # Download the convenience script
    curl -fsSL https://get.docker.com -o install-docker.sh
    
    # Install Docker
    sudo sh install-docker.sh
    
    # Allow the non-root user to access Docker
    sudo usermod -aG docker $USER
    
    # Activate the group changes
    newgrp docker
    
  5. Instal Skaffold:

    curl -Lo skaffold https://storage.googleapis.com/skaffold/releases/latest/skaffold-linux-amd64 && \
    sudo install skaffold /usr/local/bin/
    
  6. Download CLI Migrate to Containers:

    curl -O "https://m2c-cli-release.storage.googleapis.com/$(curl -s https://m2c-cli-release.storage.googleapis.com/latest)/linux/amd64/m2c"
    chmod +x ./m2c
    

Memigrasikan VM sumber

Migrasi biasanya melibatkan tiga langkah: menyalin sistem file VM sumber, menganalisis sistem file untuk membuat rencana migrasi, dan menghasilkan artefak migrasi.

Bagian berikut menjelaskan cara menggunakan CLI Migrate to Containers untuk melakukan migrasi VM sumber menggunakan VM Linux lokal Anda.

Menyalin sistem file VM sumber

Saat Anda menyalin sistem file VM sumber, CLI Migrate to Containers akan menggunakan filter untuk mengurangi ukuran sistem file yang disalin. Namun, untuk membuat Server Apache tersedia untuk dimulai, server membutuhkan direktori /var/log, yang dihapus oleh filter {i>default<i}.

Bagian ini menjelaskan cara mengedit filter default untuk memastikan bahwa /var/log/* disalin dengan sistem file VM sumber.

  1. Pada tab perintah quickstart-local-vm, dapatkan daftar perintah default Filter Migrate to Containers dalam file bernama filters.txt:

    ./m2c copy default-filters > filters.txt
    
  2. Untuk mengedit filter default, lakukan hal berikut:

    1. Buka file filters.txt di editor teks:

      vi filters.txt
      
    2. Untuk membuat perubahan pada file, tekan i.

    3. Hapus pernyataan berikut:

      - /var/log/*
      
    4. Untuk menyimpan file dan keluar dari editor teks, tekan Esc lalu enter :wq.

  3. Salin sistem file mesin sumber:

    ./m2c copy gcloud \
      --project PROJECT_ID --zone us-central1-a \
      --vm-name quickstart-source-vm --output quickstart-vm-filesystem \
      --filters filters.txt
    

    Ganti PROJECT_ID dengan ID project.

    Salinan sistem file komputer sumber tersedia di Direktori quickstart-vm-filesystem.

Membuat rencana migrasi

  • Pada tab perintah quickstart-local-vm, buat rencana migrasi:

    ./m2c analyze \
      --source quickstart-vm-filesystem --plugin linux-vm-container \
      --output analysis-output
    

    Setelah analisis selesai, direktori baru bernama analysis-output akan dibuat yang berisi rencana migrasi, config.yaml.

Membuat artefak migrasi

  • Pada tab perintah quickstart-local-vm, buat artefak migrasi:

    ./m2c generate --input analysis-output --output migration-artifacts
    

    Artefak migrasi yang dibuat ditambahkan ke migration-artifacts saat ini.

Men-deploy beban kerja yang dimigrasikan

Di bagian ini, Anda akan men-deploy workload yang dimigrasikan dari VM lokal Anda quickstart-local-vm ke cluster GKE yang berjalan di Google Cloud.

  1. Pada tab perintah quickstart-local-vm, instal Plugin gke-gcloud-auth-plugin:

    sudo apt-get install google-cloud-sdk-gke-gcloud-auth-plugin
    
  2. Instal kubectl:

    sudo apt-get install kubectl
    
  3. Hubungkan ke cluster quickstart-cluster:

    gcloud container clusters get-credentials quickstart-cluster
      --zone us-central1-a --project PROJECT_ID
    
  4. Buka folder migration-artifacts:

    cd migration-artifacts
    
  5. Untuk mengekspos workload ke internet, tambahkan layanan LoadBalancer baru di file deployment_spec.yaml. Untuk mengedit file deployment_spec.yaml, lakukan hal berikut:

    1. Buka file deployment_spec.yaml di editor teks:

      vi deployment_spec.yaml
      
    2. Untuk membuat perubahan pada file, tekan i.

    3. Temukan objek Service dengan nama linux-system. Tampaknya mirip dengan contoh berikut ini:

      ---
      apiVersion: v1
      kind: Service
      metadata:
      creationTimestamp: null
      labels:
         anthos-migrate.cloud.google.com/type: linux-container
         migrate-for-anthos-optimization: "true"
         migrate-for-anthos-version: m2c-cli-1.2.2
      name: linux-system
      spec:
      clusterIP: None
      selector:
         app: linux-system
      type: ClusterIP
      
      ---
      
    4. Tambahkan objek Service lain bernama hello-service tepat setelah linux-system:

      ---
      apiVersion: v1
      kind: Service
      metadata:
      creationTimestamp: null
      labels:
         anthos-migrate.cloud.google.com/type: linux-container
         migrate-for-anthos-optimization: "true"
         migrate-for-anthos-version: m2c-cli-1.2.2
      name: linux-system
      spec:
      clusterIP: None
      selector:
         app: linux-system
      type: ClusterIP
      
      ---
      # Add the hello-service object
      apiVersion: v1
      kind: Service
      metadata:
      name: hello-service
      spec:
      selector:
         app: linux-system
      ports:
         - protocol: TCP
           port: 80
           targetPort: 80
      type: LoadBalancer
      
      ---
      
    5. Untuk menyimpan file dan keluar dari editor teks, tekan Esc lalu enter :wq.

  6. Deploy VM yang dimigrasikan:

    skaffold run -d eu.gcr.io/PROJECT_ID
    
  7. Dapatkan alamat IP eksternal dari VM yang dimigrasikan:

    kubectl get service hello-service
    
  8. Saat server web sudah siap, Anda akan melihat alamat IP eksternal untuk hello-service yang Anda tambahkan.

    NAME            TYPE           CLUSTER-IP      EXTERNAL-IP    PORT(S)        AGE
    hello-service   LoadBalancer   10.23.241.124   EXTERNAL_IP   80:32611/TCP   5m4s
    
  9. Untuk memeriksa apakah migrasi berhasil, buka tab browser baru dan kunjungi laman web di alamat IP eksternal.

    http://EXTERNAL_IP
    

    Pastikan Anda menggunakan HTTP, bukan HTTPS.

  10. Jika melihat teks Hello World! pada layar, berarti VM Anda migrasi berhasil.

    Jika Anda tidak dapat mengakses beban kerja yang dimigrasikan, lihat cara memecahkan masalah umum.

Pembersihan

Agar tidak menimbulkan biaya pada akun Google Cloud Anda untuk resource yang digunakan pada halaman ini, ikuti langkah-langkah berikut.

Menghapus cluster GKE

  1. Di konsol Google Cloud, buka halaman GKE.

    Buka GKE

  2. Pilih quickstart-cluster, lalu klik Hapus.
  3. Saat diminta untuk mengonfirmasi, klik Hapus lagi.

Menghapus VM

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

    Buka instance VM

  2. Klik nama quickstart-source-vm.
  3. Di bagian atas halaman detail instance, klik Hapus.
  4. Klik nama quickstart-local-vm.
  5. Di bagian atas halaman detail instance, klik Hapus.

Langkah selanjutnya