MySQL 优化脚本(analyze)引起的应用崩溃
早上刚走进公司的门口,快走到办公桌的时候,开发的同事很着急的跟我说:你可来了!我:发生什么事情了?开发同事:XX数据库死掉了!我:特别惊讶!这个库运行的
早上刚走进公司的门口,,快走到办公桌的时候,开发的同事很着急的跟我说:你可来了!
我:SELECT.......
注意红色字体的关键字,官网的解释是:
Flushing tables
The thread is executing FLUSH TABLES and is waiting for all threads to close their tables.
也就是说线程执行刷新表操作并且等待所有的线程关闭他们占用的表。
一个超长执行时间的SQL被发现了,这个SQL大概执行了十几个小时还没有查出结果。
但是这样也不应该回引起flush tables 的问题出现。
kill 掉这个SQL线程之后,慢慢的系统恢复了正常查询的状态。
就这样粗暴的处理完成之后,就看系统各种的日志,开始查找原因,突然想到今天是周末
对呀周末!!
周末会怎样呢?
周末有一个优化脚本任务执行的!
这个优化脚本就是使用analyze去分析每张表,analyze会收集表的统计信息。
会导致mysql检测到对应的table做了修改,必须执行flush操作,close和reopen表
由此可以推断出,是因为那个执行时间超长的SQL在执行过程中,我的优化脚本任务也启动了,对SQL占用的表进行了analyze 那张表就需要被close和reopen。但是SQL写的太烂,一直没有执行完成,也就不能释放对表的占用。以至于后面的SQL就要排队等待。
只要将那个SQL给kill掉就关闭了表,然后续的SQL就重新打开了那个表,正常!
我根据推断做了一个测试,首先手工执行那个烂SQL等待了一会儿没有查出结果的迹象,在这个时候使用analyze table table_name;
show processlit 查看状态,果然如此!截图中红色框部分
实验证明了是analyze引起的问题,但不是主要的问题。
于是和开发商量需要改进SQL进行优化。搞定!
本文出自 “影子骑士” 博客,请务必保留此出处

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Terdapat dua cara untuk melaksanakan multi-threading dalam Java, satu adalah untuk mewarisi kelas Thread, dan satu lagi adalah untuk melaksanakan antara muka Runnable kelas Thread ditakrifkan dalam pakej java.lang. Selagi kelas mewarisi kelas Thread dan mengatasi kaedah run() dalam kelas ini, ia boleh melaksanakan operasi berbilang benang Walau bagaimanapun, kelas hanya boleh mewarisi satu kelas induk, yang merupakan had kaedah ini. Mari lihat contoh: packageorg.thread.demo;classMyThreadextendsThread{privateStringname;publicMyThread(Stringname){super();this

Analisis mendalam tentang peranan dan penggunaan kata kunci statik dalam bahasa C Dalam bahasa C, statik ialah kata kunci yang sangat penting, yang boleh digunakan dalam definisi fungsi, pembolehubah dan jenis data. Menggunakan kata kunci statik boleh menukar atribut pautan, skop dan kitaran hayat objek Mari analisa peranan dan penggunaan kata kunci statik dalam bahasa C secara terperinci. Pembolehubah statik dan fungsi: Pembolehubah yang ditakrifkan menggunakan kata kunci statik di dalam fungsi dipanggil pembolehubah statik, yang mempunyai kitaran hayat global

Tajuk: Adakah pergi kata kunci dalam bahasa C? Analisis terperinci Dalam bahasa C, "go" bukan kata kunci. Kata kunci dalam bahasa C ditentukan oleh piawaian C dan digunakan untuk mewakili struktur atau fungsi tatabahasa tertentu Ia mempunyai makna khas dalam pengkompil dan tidak boleh digunakan sebagai pengecam atau nama pembolehubah. Contohnya, kata kunci "int" mewakili jenis data integer, "jika" mewakili pernyataan bersyarat dan sebagainya. Jika kami ingin mengesahkan sama ada "go" ialah kata kunci dalam bahasa C, kami boleh menulis atur cara mudah untuk mengujinya. Berikut ialah contoh: #inc

Peranan dan contoh kata kunci var dalam PHP Dalam PHP, kata kunci var digunakan untuk mengisytiharkan pembolehubah. Dalam versi PHP sebelumnya, menggunakan kata kunci var ialah cara idiomatik untuk mengisytiharkan pembolehubah ahli, tetapi penggunaannya tidak lagi disyorkan. Walau bagaimanapun, dalam beberapa kes, kata kunci var masih digunakan. Kata kunci var digunakan terutamanya untuk mengisytiharkan pembolehubah tempatan dan secara automatik menandakan pembolehubah sebagai skop tempatan. Ini bermakna pembolehubah hanya boleh dilihat dalam blok kod semasa dan tidak boleh diakses dalam fungsi atau blok kod lain. Gunakan var

Terdapat 32 kata kunci dalam bahasa C Mengikut fungsi kata kunci, ia boleh dibahagikan kepada empat kategori: kata kunci jenis data, kata kunci pernyataan kawalan, kata kunci jenis storan dan kata kunci lain. Terdapat 12 kata kunci jenis data, termasuk char, double, float, int, dll. terdapat 12 kata kunci pernyataan kawalan, termasuk untuk, break, if, else, do, dll.; static , extern, dsb. terdapat 4 kata kunci lain, termasuk const, sizeof, dsb.

Gunakan fungsi Thread.start() Java untuk memulakan utas baharu Di Java, kita boleh menggunakan multi-threading untuk melaksanakan berbilang tugas secara serentak. Java menyediakan kelas Thread untuk mencipta dan mengurus thread. Fungsi start() dalam kelas Thread digunakan untuk memulakan thread baru dan melaksanakan kod dalam kaedah run() thread. Contoh kod: publicclassMyThreadextendsThread{@Overr

Dalam java, apabila ia datang kepada benang, Benang adalah penting. Benang ialah pelaksana berjadual yang lebih ringan daripada proses. Mengapa menggunakan benang? Dengan menggunakan benang, anda boleh memisahkan peruntukan sumber dan penjadualan pelaksanaan dalam proses sistem pengendalian. Setiap utas bukan sahaja boleh berkongsi sumber proses (alamat memori, fail I/O, dll.), tetapi juga boleh dijadualkan secara bebas (benang ialah unit asas penjadualan CPU). Nota 1. Benang ialah kelas yang paling penting untuk membuat benang, dan perkataan itu sendiri juga mewakili benang. 2. Kelas Thread melaksanakan antara muka Runnable. Instance publicclassThreadDemoextendsThread{publicvoidrun(){for(inti=0

在go语言中,while不是关键字,可以用for语句加break来实现while循环的效果,例“for {sum++ if sum>10{break}else{...}}”。go语言有break、default 、func、select、case、defer、go、map、else、goto、for、if、var等25个关键字。
