Memantau kueri aktif

Halaman ini menjelaskan cara memantau dan memecahkan masalah kueri yang aktif di database Anda. Memantau kueri ini dapat membantu mengidentifikasi penyebab latensi sistem dan penggunaan CPU yang tinggi.

Di dasbor Query Insight, Anda dapat melihat ringkasan transaksi aktif dan daftar transaksi dengan kueri dan statistik terkait. Transaksi ditampilkan berdasarkan waktu mulai transaksi. Jika ada banyak kueri yang berjalan, hasilnya mungkin terbatas pada subset dari total kueri.

Sebelum memulai

Untuk memantau kueri aktif, Anda dapat menggunakan edisi Cloud SQL Enterprise atau edisi Cloud SQL Enterprise Plus.

Untuk menghentikan sesi atau transaksi yang berjalan lama dalam kueri aktif, Anda harus menggunakan edisi Cloud SQL Enterprise Plus untuk instance Cloud SQL.

Untuk mengetahui informasi selengkapnya tentang edisi Cloud SQL, lihat Pengantar edisi Cloud SQL.

Peran dan izin yang diperlukan

Untuk mendapatkan izin yang Anda perlukan guna melihat kueri aktif, minta administrator untuk memberi Anda peran IAM berikut pada project yang menghosting instance Cloud SQL:

Untuk mengetahui informasi selengkapnya tentang pemberian peran, lihat Mengelola akses ke project, folder, dan organisasi.

Peran yang telah ditetapkan ini berisi izin yang diperlukan untuk melihat kueri aktif. Untuk melihat izin yang benar-benar diperlukan, perluas bagian Izin yang diperlukan:

Izin yang diperlukan

Izin berikut diperlukan untuk melihat kueri aktif:

  • Melihat ringkasan aktivitas database dan transaksi yang berjalan lama:
    • databaseinsights.activeQueries.fetch
    • databaseinsights.activitySummary.fetch

Anda mungkin juga bisa mendapatkan izin ini dengan peran khusus atau peran bawaan lainnya.

Mengaktifkan kueri aktif

Saat Anda mengaktifkan Query Insight, Anda akan mengaktifkan kueri aktif secara otomatis. Agar dapat menghentikan sesi atau transaksi yang berjalan lama dalam kueri aktif, Anda harus menggunakan Query Insight untuk edisi Cloud SQL Enterprise Plus.

Menonaktifkan kueri aktif

Anda tidak dapat menonaktifkan kueri aktif tanpa menonaktifkan Query Insight. Untuk menonaktifkan kueri aktif dan Query Insight, lihat Menonaktifkan Query Insight.

Melihat kueri aktif

Untuk melihat kueri aktif, selesaikan langkah-langkah berikut:

  1. Di Google Cloud Konsol, buka halaman Instance Cloud SQL.

    Buka Instance Cloud SQL

  2. Untuk membuka halaman Ringkasan instance, klik nama instance.

  3. Lakukan salah satu tindakan berikut untuk menampilkan dasbor Query Insight:

    • Pilih tab Query Insight.
    • Klik Buka Query Insight untuk info lebih mendalam tentang kueri dan performa. Dasbor Query Insight akan terbuka. Halaman ini menampilkan detail tentang instance di bagian atas.
  4. Klik tab Kueri aktif.

    Dari sini, Anda dapat mengubah informasi kueri yang muncul di tabel Transaksi yang berjalan paling lama:

    • Database: memfilter pemuatan kueri di database tertentu atau semua database.
    • Pengguna: memfilter pemuatan kueri dari akun pengguna tertentu.

Melihat kueri aktif yang dinormalisasi

Anda dapat melihat daftar transaksi yang berjalan lama dan teratas dengan kueri aktif yang dinormalisasi di dasbor Query Insight. Kueri aktif yang dinormalisasi akan menghapus data sensitif dan menampilkan ringkasan. Ringkasan ini sama untuk nilai yang berbeda yang digunakan dalam contoh berikut:

  • Kueri reguler

    • select * from test_table where id=1;
    • select * from test_table_where id=2;
  • Ringkasan atau kueri yang dinormalisasi

    • select * from test_table where id=?;

Kueri yang berjalan di sesi yang berbeda akan ditampilkan sebagai entri yang berbeda di dasbor.

Melihat transaksi yang berjalan paling lama dan teratas

Tabel Transaksi yang berjalan paling lama di dasbor Query Insight berisi kolom berikut:

Nama kolom Deskripsi
ID sesi ID unik sesi.
Kueri Teks kueri SQL.
Status sesi Status sesi.
Durasi kueri Durasi kueri berjalan.
ID sesi pemblokiran ID sesi yang memblokir sesi.
Jenis peristiwa tunggu Jenis peristiwa tunggu, jika permintaan diblokir untuk eksekusi kueri.
Resource tunggu Resource yang saat ini ditunggu oleh permintaan, jika permintaan diblokir untuk eksekusi kueri.
Durasi tunggu transaksi Durasi tunggu saat ini, jika sesi diblokir.
Baca logis Jumlah baca logis yang telah dilakukan oleh permintaan.
Baca Jumlah baca yang telah dilakukan oleh permintaan.
Tulis Jumlah tulis yang telah dilakukan oleh permintaan.
Database Database tempat sesi berjalan.
Pengguna Nama pengguna yang terhubung ke database.
Alamat klien Alamat IP spesifik klien yang mengirim kueri.
Waktu CPU (md) Waktu CPU dalam milidetik yang digunakan oleh permintaan.
Nama aplikasi Nama aplikasi yang memulai sesi.
Baris transaksi yang diubah Jumlah baris yang ditampilkan ke klien oleh kueri ini.
% selesai Persen pekerjaan yang selesai, jika kueri melaporkan progres.
Memori kueri yang diberikan Jumlah halaman yang dialokasikan untuk eksekusi permintaan.
Tindakan Berisi link untuk menghentikan sesi.

Tampilan akan otomatis diupdate setiap 60 detik.

Anda dapat menggunakan Opsi tampilan konten... menu vertikal untuk memfilter kolom yang ingin ditampilkan.

Menghentikan sesi

Untuk menghentikan sesi atau transaksi yang berjalan lama, Anda harus menggunakan edisi Cloud SQL Enterprise Plus dan mengaktifkan Query Insight untuk edisi Cloud SQL Enterprise Plus.

Operasi yang berjalan lama mungkin memerlukan waktu lebih lama untuk dihentikan.

Untuk menghentikan kueri atau transaksi, selesaikan langkah-langkah berikut:

  1. Di tabel Transaksi yang berjalan paling lama, pilih kueri.
  2. Di kolom Tindakan, klik Hentikan sesi.
  3. Di jendela Hentikan sesi, klik Konfirmasi.

Kueri aktif yang diblokir

Jika kueri aktif tertentu diblokir atau berjalan jauh lebih lama dari yang diharapkan, kueri aktif tersebut dapat memblokir kueri dependen lainnya.

Cloud SQL memberi Anda opsi untuk menghentikan kueri aktif tertentu yang berjalan lama atau diblokir.

Mengaktifkan analisis kueri aktif yang diblokir

Secara default, Google Cloud Konsol tidak menampilkan kueri aktif mana yang diblokir.

Untuk menganalisis kueri aktif yang diblokir, persyaratan berikut berlaku:

Untuk mengaktifkan analisis kueri aktif yang diblokir, lakukan hal berikut:

Konsol

  1. Di Google Cloud Konsol, buka halaman Instance Cloud SQL.

    Buka Instance Cloud SQL

  2. Untuk membuka halaman Ringkasan instance, klik nama instance.
  3. Klik Edit.
  4. Luaskan bagian Query Insight.
  5. Pilih Aktifkan Query Insight dan Aktifkan fitur Enterprise Plus. Kedua setelan ini diperlukan.
  6. Pilih Analisis kueri yang diblokir.
  7. Klik Simpan.

Mengidentifikasi dan menghentikan kueri aktif yang diblokir

Langkah-langkah berikut menunjukkan cara mengidentifikasi dan menghentikan kueri aktif tertentu yang mungkin memblokir kueri lain.

Konsol

  1. Di Google Cloud Konsol, buka halaman Instance Cloud SQL.

    Buka Instance Cloud SQL

  2. Untuk membuka halaman Ringkasan instance, klik nama instance.
  3. Di menu navigasi SQL, klik Query Insight.
  4. Klik tab Kueri aktif.

    Jika Anda belum menjalankan kueri aktif, buka Cloud SQL Studio dan jalankan kueri yang ingin diselidiki.

  5. Buka bagian Transaksi yang berjalan paling lama. Anda dapat melihat hingga 50 kueri aktif yang berjalan paling lama di setiap kategori.

    Setiap entri yang ditampilkan memiliki detail kueri aktif yang ditampilkan, termasuk hal berikut:

    • ID sesi: ID sesi kueri. Klik luaskan untuk melihat entri. Anda dapat melihat salah satu dari dua ikon:
      • Ikon jam pasir: Ikon ini menunjukkan bahwa kueri sedang menunggu kueri lain selesai. Jika ada angka yang disertakan di samping ikon, angka tersebut menunjukkan jumlah kueri dependen yang menunggu kueri ini selesai.
      • Ikon simbol blokir: Ikon ini menunjukkan bahwa kueri tidak dapat diselesaikan dan mungkin memblokir kueri lain.
    • Kueri: Teks kueri SQL.
    • Status sesi: Status sesi.
    • Durasi kueri (detik): Durasi kueri berjalan.
    • Waktu CPU(md): Waktu CPU dalam milidetik yang digunakan oleh permintaan.
    • Jenis peristiwa tunggu: Jenis peristiwa tunggu, jika permintaan diblokir untuk eksekusi kueri.
    • Resource tunggu: Resource yang saat ini ditunggu oleh permintaan, jika permintaan diblokir untuk eksekusi kueri.
    • Durasi tunggu transaksi (detik): Durasi tunggu saat ini, jika sesi diblokir.
    • Tindakan: Tindakan yang dapat dilakukan, seperti Hentikan sesi.

    Klik untuk meluaskan ID sesi yang ingin diselidiki. Anda dapat meluaskan sesi yang mendasarinya hingga tiga tingkat di pohon investigasi.

  6. Identifikasi kueri tertentu yang diblokir, lalu klik Hentikan sesi. Setelah menghentikan sesi, Anda dapat membuka Cloud SQL Studio untuk menjalankan kueri aktif lagi.

Melihat detail sesi tidur yang memblokir

Tab Kueri aktif menampilkan sesi yang saat ini memproses permintaan. Sesi dalam status SLEEPING dikecualikan dari tampilan ini.

Untuk melihat perintah terakhir yang dijalankan untuk sesi tidur, gunakan skrip berikut:

SELECT c.session_id, st.text,s.login_name, s.open_transaction_count, s.host_name, s.program_name
FROM sys.dm_exec_connections AS c JOIN sys.dm_exec_sessions AS S ON c.session_id=s.session_id
CROSS APPLY sys.dm_exec_sql_text(c.most_recent_sql_handle) AS st
WHERE s.session_id=BLOCKING_SESSION_ID

Ganti BLOCKING_SESSION_ID dengan ID sesi yang menyebabkan pemblokiran.

Untuk mengetahui informasi selengkapnya yang dapat membantu memecahkan masalah dan mengatasi pemblokiran, lihat referensi berikut:

Langkah berikutnya