吐血推薦5大管理MYSQL的開源免費利器,按需選擇,值得珍藏(開源的mysql管理工具)
概述
對于數(shù)據(jù)庫運維人員來說,想要保證數(shù)據(jù)庫在高效平穩(wěn)的運行就有點像雜技演員在轉(zhuǎn)盤子,需要靈活、專注、能快速做出反應(yīng)、并且擁有冷靜的頭腦。數(shù)據(jù)庫幾乎是所有能夠成功運行系統(tǒng)的核心。而數(shù)據(jù)庫運維人員對組織的數(shù)據(jù)負責,能找到可依靠的工具來更加高效的管理數(shù)據(jù)庫,并且輕松的維護日常的工作就變得格外重要。數(shù)據(jù)庫運維人員因此需要更好的工具來使得他們的系統(tǒng)平穩(wěn)運行。那什么工具才是對MYSQL管理者來說是經(jīng)過測試并且值得相信的呢?這里推薦5款mysql的開源工具。
01
Mycli
mycli, 命令行操作mysql的智能提示工具。
提供了代碼補全,語法高亮等功能自動通過輸入第一個字符檢索表名或字段名通過命令行模式其中,命令行模式的好處在于,在有著遠程操作或者雙重認證等安全限制的環(huán)境中,不受制約,而圖像化的工具未必好用。
02
Gh-ost
作為一個DBA,大表的DDL的變更大部分都是使用Percona的pt-online-schema-change,其實還有另外一個比較小巧的工具–gh-ost。gh-ost的設(shè)計號稱無觸發(fā)器,可監(jiān)控,可動態(tài)調(diào)整暫停等,更重要的是切換方案的優(yōu)秀設(shè)計。
通常業(yè)內(nèi)對大表DDL變更的處理方式無外乎三種,一是利用Percona的pt-online-schema-change,Facebook的OSC等三方工具,二是在備庫修改通過切換實現(xiàn)滾動變更,三則是升級MySQL到5.6/5.7通過官方Online DDL實現(xiàn)部分變更。然而,引入觸發(fā)器帶來的鎖競爭問題,主備切換帶來的附加成本以及Online DDL的局限性都不讓DBA省心。
那么gh-ost是怎么工作的呢?官方架構(gòu)圖如下:
其有兩種工作方式如下:
1. 連接主庫直接修改
- 直連主庫
- 主庫上創(chuàng)建ghost表
- 新表(ghost表)上直接alter修改表結(jié)構(gòu)
- 遷移原表數(shù)據(jù)到新表
- 拉取解析binlog事件,應(yīng)用到新表
- cut-over階段,用新表替換掉原表
2. 連接從庫間接應(yīng)用到主庫
連接從庫校驗完后,在主庫創(chuàng)建新表遷移原表數(shù)據(jù)到新表模擬從庫的從庫,拉取解析增量binlog應(yīng)用到主庫cut-over階段,用新表替換掉原表兩者不同的點就在于,通過連接從庫來進行變更,對主庫的性能影響最小。
03
PhpMyAdmin
資歷最老并且最成熟的WEB版MySQL工具。允許數(shù)據(jù)庫運維人員通過瀏覽器對數(shù)據(jù)表進行操作。而且具有豐富的格式來展示數(shù)據(jù)。
能夠動態(tài)地將問題、連接數(shù)/進程、流量繪制成圖形。并且檢測當性能下降時自動提供解決建議的功能。
04
Sqlcheck
在MySQL的反模式中,有興趣的同學可以看下相關(guān)資料(SQL anti-patterns)。
SqlCheck能將夠定位的問題分為3類,高風險,中風險,低風險。這個能幫助列出哪些是最影響你效率的問題。你所要做的就是將文件名稱當作參數(shù)輸入到工具中。
05
Orchestrator
orchestrator是一款非常實用的數(shù)據(jù)復(fù)制管理工具。它能夠通過抓取數(shù)據(jù)庫主從關(guān)系來生成拓撲圖。并且可以通過拖拉拽的方式來重構(gòu)你的數(shù)據(jù)庫關(guān)系。這些操作非常安全,不會因為非法操作來損壞數(shù)據(jù)庫。
最后,orchestrator能夠恢復(fù)當其中的節(jié)點發(fā)生故障,它應(yīng)用了狀態(tài)的概念來正確的恢復(fù)并且在適當?shù)臅r候與主庫進行連接。
上面的工具在某些場景還是挺好用的,后面會抽時間介紹下這些工具的部署和使用教程,感興趣的朋友可以關(guān)注一下~
版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請發(fā)送郵件至 舉報,一經(jīng)查實,本站將立刻刪除。