總結(jié)mysql服務(wù)器查詢慢原因_MySQL教程
推薦:go語言怎么和mysql數(shù)據(jù)庫進(jìn)行鏈接在網(wǎng)上找了一大堆例子,最后簡化一下把,一下會從安裝mysql開始,與大家分享一下如何用go鏈接服務(wù)器上的mysql 我用的是ubuntu系統(tǒng) 1,安裝mysql:sudo apt-get install mysql-server (記住root的密碼假設(shè)密碼為root123) 2,進(jìn)入mysql:mysql -uroot -p 然后輸入密碼
會經(jīng)常發(fā)現(xiàn)開發(fā)人員查一下沒用索引的語句或者沒有l(wèi)imit n的語句,這些沒語句會對數(shù)據(jù)庫造成很大的影響,例如一個幾千萬條記錄的大表要全部掃描,或者是不停的做filesort,對數(shù)據(jù)庫和服務(wù)器造成io影響等。這是鏡像庫上面的情況。
而到了線上庫,除了出現(xiàn)沒有索引的語句,沒有用limit的語句,還多了一個情況,mysql連接數(shù)過多的問題。說到這里,先來看看以前我們的監(jiān)控做法
1. 部署zabbix等開源分布式監(jiān)控系統(tǒng),獲取每天的數(shù)據(jù)庫的io,cpu,連接數(shù)
2. 部署每周性能統(tǒng)計(jì),包含數(shù)據(jù)增加量,iostat,vmstat,datasize的情況
3. Mysql slowlog收集,列出top 10
以前以為做了這些監(jiān)控已經(jīng)是很完美了,現(xiàn)在部署了mysql節(jié)點(diǎn)進(jìn)程監(jiān)控之后,才發(fā)現(xiàn)很多弊端
第一種做法的弊端: zabbix太龐大,而且不是在mysql內(nèi)部做的監(jiān)控,很多數(shù)據(jù)不是非常準(zhǔn)備,現(xiàn)在一般都是用來查閱歷史的數(shù)據(jù)情況
第二種做法的弊端:因?yàn)槭敲恐苤慌芤淮危芏嗲闆r沒法發(fā)現(xiàn)和報(bào)警
第三種做法的弊端: 當(dāng)節(jié)點(diǎn)的slowlog非常多的時(shí)候,top10就變得沒意義了,而且很多時(shí)候會給出那些是一定要跑的定期任務(wù)語句給你。。參考的價(jià)值不大
那么我們怎么來解決和查詢這些問題呢
對于排查問題找出性能瓶頸來說,最容易發(fā)現(xiàn)并解決的問題就是MYSQL的慢查詢以及沒有得用索引的查詢。
OK,開始找出mysql中執(zhí)行起來不“爽”的SQL語句吧。
方法一: 這個方法我正在用,呵呵,比較喜歡這種即時(shí)性的。
方法二:mysqldumpslow命令
最后總結(jié)一下節(jié)點(diǎn)監(jiān)控的好處
1. 輕量級的監(jiān)控,而且是實(shí)時(shí)的,還可以根據(jù)實(shí)際的情況來定制和修改
2. 設(shè)置了過濾程序,可以對那些一定要跑的語句進(jìn)行過濾
3. 及時(shí)發(fā)現(xiàn)那些沒有用索引,或者是不合法的查詢,雖然這很耗時(shí)去處理那些慢語句,但這樣可以避免數(shù)據(jù)庫掛掉,還是值得的
4. 在數(shù)據(jù)庫出現(xiàn)連接數(shù)過多的時(shí)候,程序會自動保存當(dāng)前數(shù)據(jù)庫的processlist,DBA進(jìn)行原因查找的時(shí)候這可是利器
5. 使用mysqlbinlog 來分析的時(shí)候,可以得到明確的數(shù)據(jù)庫狀態(tài)異常的時(shí)間段
有些人會建義我們來做mysql配置文件設(shè)置
調(diào)節(jié)tmp_table_size 的時(shí)候發(fā)現(xiàn)另外一些參數(shù)
Qcache_queries_in_cache 在緩存中已注冊的查詢數(shù)目
Qcache_inserts 被加入到緩存中的查詢數(shù)目
Qcache_hits 緩存采樣數(shù)數(shù)目
Qcache_lowmem_prunes 因?yàn)槿鄙賰?nèi)存而被從緩存中刪除的查詢數(shù)目
Qcache_not_cached 沒有被緩存的查詢數(shù)目 (不能被緩存的,或由于 QUERY_CACHE_TYPE)
Qcache_free_memory 查詢緩存的空閑內(nèi)存總數(shù)
Qcache_free_blocks 查詢緩存中的空閑內(nèi)存塊的數(shù)目
Qcache_total_blocks 查詢緩存中的塊的總數(shù)目
Qcache_free_memory 可以緩存一些常用的查詢,如果是常用的sql會被裝載到內(nèi)存。那樣會增加數(shù)據(jù)庫訪問速度。
分享:mysql給用戶添加查詢權(quán)限grant select on *.* to tianq@localhost identified by tianq;
- go語言怎么和mysql數(shù)據(jù)庫進(jìn)行鏈接
- mysql給用戶添加查詢權(quán)限
- SQL中l(wèi)eftjoin和innerjoin配合使用
- SQL 2000怎么向SQL 2008 R2推送數(shù)據(jù)?
- MySQL導(dǎo)入導(dǎo)出數(shù)據(jù)出現(xiàn)亂碼的解決辦法
- sql語句中刪除表數(shù)據(jù)drop、truncate和delete的用法
- 安裝sql server 2008 報(bào)錯等問題怎么解決
- Mysql教程之Windows 7/8下連接本地MySQL慢怎么辦
- MSSQL清空日志刪除日志文件
- 關(guān)于數(shù)據(jù)庫中保留小數(shù)位的問題
- 解析mysql與Oracle update的區(qū)別
- mysql 導(dǎo)入導(dǎo)出數(shù)據(jù)庫以及函數(shù)、存儲過程的介紹
MySQL教程Rss訂閱編程教程搜索
MySQL教程推薦
- 網(wǎng)站模板:SQL2005CLR函數(shù)擴(kuò)展 - 關(guān)于山寨索引
- 用MyEclipse配置DataBase Explorer(圖示)
- MySql中把一個表的數(shù)據(jù)插入到另一個表中的實(shí)現(xiàn)代碼
- mysql中text與varchar與char的區(qū)別
- 解決bash: mysql: command not found 的方法
- MySQL的重裝問題解決方法
- SQL中l(wèi)eftjoin和innerjoin配合使用
- Mysql中“Insert into xxx on duplicate key update”問題
- MySQL索引簡單分析
- Mysql,phpmyadmin密碼忘了怎么辦
猜你也喜歡看這些
- 解讀在SQL Server中處理空值時(shí)涉及的三個問題
- 數(shù)據(jù)庫用SQL語法大全
- 解析SQL Server數(shù)據(jù)庫觸發(fā)器的安全隱患
- 解析SQL Server 2005常見問題
- 遠(yuǎn)程連接SQL Server 2000服務(wù)器的解決方案
- 確定幾個SQL Server欄中的最大值
- 如何在SQL Server2005中還原數(shù)據(jù)庫
- 解析SQL Server數(shù)據(jù)庫恢復(fù)操作實(shí)例
- SQL Server 2008R2編寫腳本時(shí)智能提示功能丟失的處理方法
- 解析MySQL實(shí)現(xiàn)SQL Server的sp_executesql
- 相關(guān)鏈接:
- 教程說明:
MySQL教程-總結(jié)mysql服務(wù)器查詢慢原因。