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 dibatasi ke subset 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 mengetahui info selengkapnya 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.
    • Kartu skor ringkasan semua kueri aktif: memberikan ringkasan semua kueri aktif dengan menampilkan total koneksi berdasarkan parameter berikut:

      1. Distribusi koneksi aktif yang dikategorikan menurut status koneksi.
      2. Distribusi transaksi aktif berdasarkan status transaksi.
      3. Distribusi durasi kueri.
    • Transaksi yang berjalan paling lama: memberikan ringkasan 50 kueri teratas yang berjalan (dalam status aktif) berdasarkan waktu eksekusi menurun. Anda dapat memfilter dan mengurutkan kueri aktif dalam tabel.

Melihat kueri aktif yang dinormalisasi

Anda dapat melihat daftar transaksi yang berjalan lama 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 dalam sesi yang berbeda akan ditampilkan sebagai entri yang berbeda di dasbor.

Melihat transaksi yang berjalan paling lama

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

Nama kolom Deskripsi
ID Proses ID unik koneksi.
Kueri Teks kueri SQL.
Status transaksi Status eksekusi transaksi saat ini. Nilai yang diizinkan mencakup: RUNNING, LOCK WAIT, ROLLING BACK, dan COMMITTING.
Status thread Status thread (atau status kueri) menunjukkan status thread aktif saat ini.
Waktu mulai transaksi Stempel waktu saat transaksi memulai eksekusinya.
Durasi transaksi Durasi transaksi aktif saat ini dalam detik.
Durasi tunggu transaksi Durasi tunggu dalam detik pada transaksi aktif saat ini.
Durasi status thread Waktu yang berlalu dalam kueri.
Baris transaksi terkunci Jumlah baris yang dikunci oleh transaksi aktif saat ini.
Baris transaksi diubah Jumlah baris yang diubah oleh transaksi aktif saat ini.
Database Nama database tempat koneksi ini berjalan.
Nama pengguna Nama pengguna yang terhubung ke database.
Alamat klien Alamat IP klien tempat pengguna terhubung ke database.
Tindakan Berisi link untuk menghentikan transaksi.

Tampilan dimuat ulang setiap 60 detik secara otomatis.

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

Menghentikan koneksi

Untuk menghentikan koneksi atau transaksi yang berjalan lama dalam kueri aktif, 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 koneksi.
  3. Di jendela Hentikan koneksi, klik Konfirmasi.

Permintaan database akan segera ditampilkan saat penghentian terjadi di latar belakang.

Halaman dimuat ulang setelah memulai penghentian. Jika penghentian gagal, pesan atau notifikasi error tidak akan ditampilkan. Kueri akan terus muncul dalam daftar Kueri Aktif. Jika penghentian berhasil, kueri tidak akan lagi ditampilkan dalam daftar. Jika penghentian memerlukan rollback, kolom Status transaksi akan menampilkan status ROLLING BACK, yang berarti penghentian masih dalam proses.

Langkah berikutnya