Bu makale makine çevirisi ayna makalesidir, orijinal makaleye geçmek için lütfen buraya tıklayın.

Görünüm: 13963|Yanıt: 0

[Kaynak] Mysql, SQL ifadelerinin yavaş yürütülmesinin nedenlerini analiz etmek için profilleme kullanır

[Bağlantıyı kopyala]
Yayınlandı 6.07.2017 11:12:17 | | | |

CleverCode'tan bir meslektaşım yakın zamanda MySQL'de sql ifadelerini analiz etmek için profilleme aracı önerdi ve bu aracın çok iyi olduğunu, sorgulama sürecinde sql ifadelerine harcanan belirli zamanı doğru şekilde analiz edebildiğini buldu. CleverCode bunu burada özetliyor ve sizinle paylaşıyor.

1 Giriş

MySQL'in Query Profiler'ı, çok kullanışlı bir Sorgu tanı analiz aracıdır; bu arayışla bir sorgu yürütme sürecinde CPU, IO, IPC, SWAP gibi birden fazla kaynağın tüketimini, ayrıca SAYFA HATALARI, CONTEXT SWITCHE vb. örneklerini elde edebilir ve ayrıca sorgu yürütülürken kaynak dosyada MySQL tarafından çağrılan her fonksiyonun konumunu elde edebilirsiniz.

MySQL sürüm 5.0.37 veya daha sonrası, SQL ifadelerinin tükettiği kaynakların detaylarını anlamanızı sağlayan PROFILING hata ayıklama fonksiyonunu destekler. Sistemin getrusage() fonksiyonunu çağırmayı gerektirdiği için, yalnızca Linux/Unix sınıfı platformlarında kullanılabilir, Windows'ta kullanılamaz. Ayrıca, PROFILLEME iş parçacıkları için değil süreçleri işlemek için kullanılır ve sunucudaki diğer uygulamalar hata ayıklama sonuçlarınızı etkileyebilir, bu yüzden bu araç geliştirme sırasında hata ayıklama için uygundur ve üretim ortamında hata ayıklamak istiyorsanız sınırlamalarına dikkat etmelisiniz.

2 Operasyon

2.1 Profilin etkin olup olmadığını kontrol edin, varsayılan olarak kapalıdır.


2.2 Profilleme etkinleştirin. Değişken profilleme, her seferinde yeniden etkinleştirilmesi gereken bir kullanıcı değişkenidir.


2.3 Aşağıdaki ifadeleri çalıştırın: Daha önce SQL'in QCACHE'ta saklanmasını önlemek için, SQL çalıştırılırken SELECT i'lesinin QCACHE algılamamasını zorunlu kılmak önerilir. Bu, analizin doğruluğunu sunmanızı sağlar.


2.4 KullanımProfil sorgusunu gösterEn son olanıAçıklamanın uygulama bilgileri。 (Analiz: system_user 20 > sql_no_cache sayı(*) seçilir)




2.5 Gösteri profillerinin kullanılması. Sunucuda çalıştırılan ifadelerin listesini görüntüleyin. (sorgu kimliği, harcanan zaman, ifade).




2.6 Formülasyon ID'sinin yürütme bilgilerini sorgulamak için profili göster kullanın. Burada ID 6 ile ifade analiz ediyoruz. (Analiz: system_user yaş 20 > olan sql_no_cache sayı(*) seçilir).


2.7 CPU alın ve IO tüketimini bloklayın.




2.8 Ek Bilgi Edinme. "PROFIL *** SORGU için göster" (SORGU için PROFIL *** göster) uygulanarak elde edilebilir. Referans adresi: http://dev.mysql.com/doc/refman/5.6/en/show-profile.html.







Önceki:Yeni Gelen raporları
Önümüzdeki:Gişe rekorları kıran haberler! Mini program geliştirme ücretsiz!
Feragatname:
Code Farmer Network tarafından yayımlanan tüm yazılım, programlama materyalleri veya makaleler yalnızca öğrenme ve araştırma amaçları içindir; Yukarıdaki içerik ticari veya yasa dışı amaçlarla kullanılamaz, aksi takdirde kullanıcılar tüm sonuçları ödemelidir. Bu sitedeki bilgiler internetten alınmakta olup, telif hakkı anlaşmazlıklarının bu siteyle hiçbir ilgisi yoktur. Yukarıdaki içeriği indirmeden sonraki 24 saat içinde bilgisayarınızdan tamamen silmelisiniz. Programı beğendiyseniz, lütfen orijinal yazılımı destekleyin, kayıt satın alın ve daha iyi orijinal hizmetler alın. Herhangi bir ihlal olursa, lütfen bizimle e-posta yoluyla iletişime geçin.

Mail To:help@itsvse.com