成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL性能優(yōu)化實(shí)戰(zhàn)

數(shù)據(jù)庫(kù) MySQL 數(shù)據(jù)庫(kù)運(yùn)維
本文向您介紹通過(guò)優(yōu)化查詢語(yǔ)句等措施環(huán)境數(shù)據(jù)庫(kù)壓力過(guò)大導(dǎo)致運(yùn)行緩慢甚至死機(jī)的方法。

過(guò)年這段時(shí)間由于線上數(shù)據(jù)庫(kù)經(jīng)常壓力過(guò)大導(dǎo)致響應(yīng)非常緩慢甚至死機(jī),咬咬牙下大決心來(lái)解決效率不高的問(wèn)題!

首先是由于公司秉承快速開發(fā)原則,頻繁上線,導(dǎo)致每次忽視了性能問(wèn)題!日積月累,所以導(dǎo)致系統(tǒng)越來(lái)越慢,所以如果你的系統(tǒng)查詢語(yǔ)句本來(lái)就優(yōu)化的很好了可能參考意義不大!

提取慢查詢?nèi)罩疚募瑧?yīng)該在你的DataDir目錄下面

通過(guò)程序處理慢查詢文件,將文件格式的慢查詢導(dǎo)入到數(shù)據(jù)庫(kù)中:

1 mysql> desc slow_query;
2 +---------------+-------------+------+-----+---------+-------+
3 | Field         | Type        | Null | Key | Default | Extra |
4 +---------------+-------------+------+-----+---------+-------+
5 | Date          | varchar(32) | NO   |     |         |       | 查詢發(fā)生的時(shí)間
6 | user          | varchar(64) | NO   |     |         |       | 
7 | host          | varchar(64) | NO   |     |         |       | 
8 | content       | text        | NO   |     |         |       | 將Statement進(jìn)行Mask后的語(yǔ)句,
便于Group By 9 | query_time | int(11) | NO | | | | 查詢所用時(shí)間,直接性能指標(biāo) 10 | lock_time | int(11) | YES | | 0 | | 等待鎖定的時(shí)間 11 | rows_sent | int(11) | YES | | 0 | | 返回的結(jié)果行數(shù) 12 | rows_examined | int(11) | YES | | 0 | | 掃描行數(shù) 13 | statement | text | YES | | NULL | | 實(shí)際查詢語(yǔ)句 14 +---------------+-------------+------+-----+---------+-------+

然后發(fā)揮您的想象力在這個(gè)表中盡力捕捉你想捕捉的,那類型語(yǔ)句壓力最大、掃描行數(shù)最多、等鎖最久……

比如:

優(yōu)化后:

mysql> select sum(query_time)/count(*),count 
(*),sum(query_time),min(Date),Max(Date) from slow where Date>'2008-02-20 22:50:52'
and Date<'2008-02-21 17:34:35'; +--------------------------+----------+-----------------+---------------------+---------------------+ | sum(query_time)/count(*) | count(*) | sum(query_time) | min(Date) | Max(Date) | +--------------------------+----------+-----------------+---------------------+---------------------+ | 5.7233 | 2197 | 12574 | 2008-02-20 22:51:16 | 2008-02-21 17:34:10 | +--------------------------+----------+-----------------+---------------------+---------------------+ 1 row in set (0.09 sec)

優(yōu)化前:

mysql> select sum(query_time)/count(*),count(*),sum(query_time),min(Date),Max(Date) from slow 
where Date>'2008-02-17 22:50:52' and Date<'2008-02-18 17:34:35'; +--------------------------+----------+-----------------+---------------------+---------------------+ | sum(query_time)/count(*) | count(*) | sum(query_time) | min(Date) | Max(Date) | +--------------------------+----------+-----------------+---------------------+---------------------+ | 2.5983 | 16091 | 41810 | 2008-02-17 22:50:58 | 2008-02-18 17:34:34 | +--------------------------+----------+-----------------+---------------------+---------------------+ 1 row in set (0.15 sec)

再比如,優(yōu)化前:

基本信息:

慢查詢統(tǒng)計(jì)從 2008-02-17 17:59:34 到2008-02-18 22:45:22時(shí)間段,接近29個(gè)小時(shí)的數(shù)據(jù);

總共有慢查詢28914個(gè),平均一小時(shí)有1000個(gè)慢查詢;(花了一天優(yōu)化降到每小時(shí)100個(gè)的樣子了,成就感啊)

所有慢查詢耗費(fèi)總時(shí)間75690秒;

慢查詢時(shí)間設(shè)置是大于2秒

參數(shù)說(shuō)明

sum--總執(zhí)行時(shí)間(秒);

count--執(zhí)行次數(shù);

avg--平均執(zhí)行時(shí)間(秒);

content--類似SQL語(yǔ)句的表達(dá)通式,其中'DD'代表數(shù)字;

statement--某一條具體執(zhí)行的SQL語(yǔ)句

由于訪問(wèn)時(shí)的鎖,導(dǎo)致update非常慢:

1 mysql> select count(*) as n,sum(query_time) as s, sum(query_time)/count(*) as avg,
substring_index(statement,' ',2)
as u from slow where statement like 'update%' and query_time>14 group by u; 2 +-----+------+---------+--------------------------+ 3 | n | s | avg | u | 4 +-----+------+---------+--------------------------+ 5 | 7 | 112 | 16.0000 | update conversation | 6 | 151 | 2413 | 15.9801 | update user | 7 | 4 | 65 | 16.2500 | update user_modification | 8 +-----+------+---------+--------------------------+

說(shuō)明程序中還是存在一些忘記釋放事務(wù)鎖的情況

最耗費(fèi)資源的10個(gè)查詢:

其中第1,2,5應(yīng)該是同一類查詢,這樣的話這一類查詢占總查詢的一半以上,每分鐘出現(xiàn)10個(gè)以上這樣的慢查詢,需要重點(diǎn)解決!

1 mysql> select sum(query_time) as sum, count(*) as count, sum(query_time)/count(*) 
as avg,statement from slow wher 2 e host like '%69.12.23.%' group by content order by sum desc limit 0,10\G 3 *************************** 1. row *************************** 4 sum: 27326 5 count: 11681 6 avg: 2.3394 7 …………

 

【編輯推薦】

  1. 詳解MySQL數(shù)據(jù)庫(kù)提升性能的八種方法
  2. 優(yōu)化MySQL插入方法的五個(gè)妙招
責(zé)任編輯:佚名 來(lái)源: IT168
相關(guān)推薦

2018-03-30 18:17:10

MySQLLinux

2017-03-29 14:44:20

網(wǎng)絡(luò)性能優(yōu)化

2022-05-17 09:02:30

前端性能優(yōu)化

2010-07-06 16:22:14

2019-12-13 10:25:08

Android性能優(yōu)化啟動(dòng)優(yōu)化

2018-09-18 17:20:14

MySQL優(yōu)化數(shù)據(jù)庫(kù)

2018-05-09 14:45:50

蘇寧前端Nodejs

2015-05-30 10:04:24

線下公開課51CTO沙龍MDSA

2018-05-09 08:35:59

2020-10-19 19:45:58

MySQL數(shù)據(jù)庫(kù)優(yōu)化

2017-03-14 18:48:06

Android性能優(yōu)化內(nèi)存優(yōu)化

2010-03-02 09:53:14

MySQL性能優(yōu)化

2020-03-23 15:15:57

MySQL性能優(yōu)化數(shù)據(jù)庫(kù)

2015-07-09 13:19:17

Ceph分布式存儲(chǔ)性能調(diào)優(yōu)

2019-09-03 09:41:48

運(yùn)維架構(gòu)技術(shù)

2018-06-07 08:54:01

MySQL性能優(yōu)化索引

2022-11-11 08:16:02

java性能技術(shù)

2019-01-15 09:34:30

MySQL高性能優(yōu)化

2011-04-25 09:11:15

2024-10-09 23:32:50

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 日韩在线小视频 | 久久aⅴ乱码一区二区三区 91综合网 | 国产精品s色| 中文字幕免费在线 | 亚洲成人av一区二区 | 伦理片97| 中文字幕欧美一区 | 男女在线网站 | 狠狠色香婷婷久久亚洲精品 | 亚洲成人黄色 | 国产高清在线观看 | 四虎成人精品永久免费av九九 | 国产综合精品 | 国产一区二区 | 久久国产精品99久久久久久丝袜 | 在线视频一区二区 | 欧美日韩亚洲视频 | 日韩二区 | 91久久精品国产91久久性色tv | 欧美综合国产精品久久丁香 | www.日韩在线 | 成人在线国产 | 91亚洲精品国偷拍自产在线观看 | 亚洲精品影院 | 九九国产在线观看 | 国产精品国产成人国产三级 | 一区二区三区国产视频 | 国产精品我不卡 | 日韩电影中文字幕 | 色欧美综合 | 亚洲国产精品99久久久久久久久 | 久久久久久网 | 欧美91| 在线观看a视频 | 国产精品高 | 91传媒在线播放 | 毛片在线看片 | 欧美成年人网站 | 国产做a爱片久久毛片 | 国产精品免费av | 91精品国产91久久综合桃花 |