Membuat dan menjalankan tugas migrasi MySQL yang berisi metadata dengan klausa DEFINER

Ringkasan

Tugas migrasi MySQL tidak memigrasikan data pengguna. Oleh karena itu, sumber yang berisi metadata yang ditentukan oleh pengguna dengan klausa DEFINER akan gagal saat dipanggil di replika Cloud SQL baru, karena pengguna belum ada di sana.

Untuk mengidentifikasi nilai DEFINER mana yang ada dalam metadata, Anda dapat menjalankan kueri berikut di database sumber MySQL. Periksa hasil untuk entri untuk root%localhost atau untuk pengguna yang tidak ada di instance tujuan:

SELECT DISTINCT DEFINER FROM INFORMATION_SCHEMA.EVENTS WHERE EVENT_SCHEMA NOT 
IN ('mysql', 'sys');
SELECT DISTINCT DEFINER FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA NOT 
IN ('mysql', 'sys');
SELECT DISTINCT DEFINER FROM INFORMATION_SCHEMA.TRIGGERS WHERE TRIGGER_SCHEMA NOT 
IN ('mysql', 'sys');
SELECT DISTINCT DEFINER FROM INFORMATION_SCHEMA.VIEWS WHERE TABLE_SCHEMA NOT 
IN ('mysql', 'sys');

Untuk menjalankan tugas migrasi dari sumber yang menyertakan metadata tersebut, Anda dapat melakukan salah satu hal berikut:

  • Buat pengguna di instance replika Cloud SQL tujuan sebelum memulai tugas migrasi Anda.

    1. Buat tugas migrasi tanpa memulainya. Artinya, pilih Buat daripada Buat & Mulai.

    2. Buat pengguna dari instance MySQL sumber Anda di instance Cloud SQL tujuan menggunakan Cloud SQL API atau UI.

    3. Mulai tugas migrasi dari daftar tugas migrasi atau halaman tugas tertentu.

  • Perbarui klausa DEFINER menjadi INVOKER pada instance MySQL sumber Anda sebelum menyiapkan tugas migrasi.