Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Log Semua Pertanyaan SQL Django, Termasuk Pertanyaan Pentadbir, untuk Penyahpepijatan dan Pemantauan?
Pemintasan dan pengelogan semua pertanyaan Django SQL
Soalan:
Penglogan semua pertanyaan SQL yang dilaksanakan oleh aplikasi Django adalah berharga untuk penyahpepijatan, analisis prestasi dan pemantauan keselamatan. Bagaimanakah ini boleh dicapai, termasuk setiap pernyataan SQL yang dihasilkan oleh antara muka pentadbir Django?
Penyelesaian:
Untuk log semua pertanyaan SQL, tingkatkan konfigurasi PEMLOG dalam settings.py dengan arahan berikut:
<code>LOGGING = { 'version': 1, 'filters': { 'require_debug_true': { '()': 'django.utils.log.RequireDebugTrue', } }, 'handlers': { 'console': { 'level': 'DEBUG', 'filters': ['require_debug_true'], 'class': 'logging.StreamHandler', } }, 'loggers': { 'django.db.backends': { 'level': 'DEBUG', 'handlers': ['console'], } } }</code>
Arahan:
Konfigurasi ini menambah pengendali baharu yang dipanggil "konsol" yang mencetak mesej log ke konsol, tetapi hanya apabila mod DEBUG didayakan. Logger 'django.db.backends' dikonfigurasikan untuk log semua pertanyaan SQL pada peringkat DEBUG kepada pengendali ini.
Penggunaan:
Untuk menulis semua pertanyaan SQL pada fail dan bukannya konsol, ubah suai bahagian "pengendali" seperti berikut:
<code>'handlers': { 'file': { 'level': 'DEBUG', 'filters': ['require_debug_true'], 'class': 'logging.FileHandler', 'filename': '/path/to/all-sql.log', } }</code>
Ini akan mengubah hala semua log nyahpepijat (termasuk pertanyaan SQL) ke fail yang ditentukan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Log Semua Pertanyaan SQL Django, Termasuk Pertanyaan Pentadbir, untuk Penyahpepijatan dan Pemantauan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!