MySQL優化思路及方向

来源:https://www.cnblogs.com/qian-fen/archive/2023/05/29/17439922.html
-Advertisement-
Play Games

本系列為:MySQL資料庫詳解,為千鋒資深教學老師獨家創作,致力於為大家講解清晰MySQL資料庫相關知識點,含有豐富的代碼案例及講解。如果感覺對大家有幫助的話,可以【關註】持續追更 ...


本系列為:MySQL資料庫詳解,為千鋒資深教學老師獨家創作,致力於為大家講解清晰MySQL資料庫相關知識點,含有豐富的代碼案例及講解。如果感覺對大家有幫助的話,可以【關註】持續追更~

文末有本文重點總結,技術類問題,也歡迎大家和我們溝通交流!

前言

從今天開始本系列文章就帶各位小伙伴學習資料庫技術。資料庫技術是Java開發中必不可少的一部分知識內容。也是非常重要的技術。本系列教程由淺入深, 全面講解資料庫體系。 非常適合零基礎的小伙伴來學習。


全文大約【1853】 字,不說廢話,只講可以讓你學到技術、明白原理的純乾貨!本文帶有豐富案例及配圖視頻,讓你更好的理解和運用文中的技術概念,並可以給你帶來具有足夠啟迪的思考...

一. 優化介紹

在進行優化講解之前,鄭重的和各位小伙伴說,本課程只是給大家提供一些優化方面的方向和思路,而具體業務場景的不同,使用的MySQL服務版本不同,都會使得優化方案的制定也不同。優化不存在按照某種方式去做就一定好用的絕對真理。

1. MySQL介紹

MySQL憑藉著出色的性能、低廉的成本、豐富的資源,已經成為絕大多數互聯網公司的首選關係型資料庫。

可以看到Google,Facebook,Twitter,百度,新浪,騰訊,淘寶,網易,久游等絕大多數互聯網公司資料庫都是用的MySQL資料庫,甚至將其作為核心應用的資料庫系統。

我們知道一般的應用系統,讀寫比例在10:1左右,而且插入操作和一般的更新操作很少出現性能問題,遇到最多的,也是最容易出問題的,還是一些複雜的查詢操作,所以查詢語句的優化顯然是重中之重。

我們將這裡進行一個較為全面的分析,讓大家瞭解到MySQL的性能到底與哪些地方有關,以便於讓大家尋找出其性能問題的根本原因,而儘可能清楚的知道該如何去優化自己的資料庫。

2. 優化可能帶來的問題

優化不總是對一個單純的環境進行,還很可能是一個複雜的已投產的系統!

優化手段有很大的風險,一定要意識到和預見到!

任何的技術可以解決一個問題,但必然存在帶來一個問題的風險!

對於優化來說調優而帶來的問題,控制在可接受的範圍內才是有成果。

保持現狀或出現更差的情況都是失敗!

3. 優化的需求

穩定性和業務可持續性,通常比性能更重要!

優化不可避免涉及到變更,變更就有風險!

優化使性能變好,維持和變差是等概率事件!

優化應該是各部門協同,共同參與的工作,任何單一部門都不能對資料庫進行優化!

4. 優化由誰參與

在進行資料庫優化時,應由資料庫管理員、業務部門代表、應用程式架構師、應用程式設計人員、應用程式開發人員、硬體及系統管理員、存儲管理員等,業務相關人員共同參與。

5. 優化的方向

在資料庫優化上有兩個主要方向:即安全與性能。

安全:數據安全性。

性能:數據的高性能訪問。

本課程主要是在性能優化方向進行介紹。

6. 優化的維度

截屏2023-05-29 11.03.37.png

從上圖中可以看出,我們把資料庫優化分為四個緯度:硬體,系統配置,資料庫表結構,SQL及索引。

硬體: CPU、記憶體、存儲、網路設備等。

系統配置: 伺服器系統、資料庫服務參數等。

資料庫表結構: 高可用、分庫分表、讀寫分離、存儲引擎、表設計等。

SQL及索引: sql語句、索引使用等。

從優化成本進行考慮: 硬體>系統配置>資料庫表結構>SQL及索引。

從優化效果進行考慮: 硬體<系統配置<資料庫表結構<SQL及索引。

7. 資料庫使用優化思路

在這裡儘可能的全面介紹資料庫的調優思路,但是在多數時候,我們進行調優不需要進行這麼全面、大範圍的調優,一般情況下,我們進行資料庫層面的優化就可以了,那我們該如何調優的呢?

應急調優的思路:

針對突然的業務辦理卡頓,無法進行正常的業務處理!需要立馬解決的場景!

show processlist(查看鏈接session狀態)。

explain(分析查詢計劃),show index from table(分析索引)。

通過執行計劃判斷,索引問題(有沒有、合不合理)或者語句本身問題。

show status like '%lock%'; # 查詢鎖狀態。

SESSION_ID; # 殺掉有問題的session。

常規調優的思路:

針對業務周期性的卡頓,例如在每天10-11點業務特別慢,但是還能夠使用,過了這段時間就好了

查看slowlog,分析slowlog,分析出查詢慢的語句。

按照一定優先順序,進行一個一個的排查所有慢語句。

分析top sql,進行explain調試,查看語句執行時間。

調整索引或語句本身。


二. 結語

在這裡對本文核心要點進行總結:

  1. 各位小伙伴要謹記優化前一定要備份各種數據規避各種風險再動手優化尤其是線上伺服器。
  2. 根據優化的效果與思路進行優化,不斷調整,優化沒有一成不變的東西,具體問題具體分析。

三. 配套視頻

如果你不習慣閱讀技術文章,或是對文中的技術概念不能很好地理解,可以來看看幫你篩選出的視頻教程。與本文配套的Java學習視頻,戳我直達


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • # Rollup ROLLUP 在多維分析中是“上捲”的意思,即將數據按某種指定的粒度進行進一步聚合。 通過建表語句創建出來的表稱為 Base 表(Base Table,基表) 在 Base 表之上,我們可以創建任意多個 ROLLUP 表。這些 ROLLUP 的數據是基於 Base 表產生的,並且在 ...
  • 《中外詩歌精品收藏ACCESS資料庫》共收錄中外經典詩歌14000首、詩歌知識500餘條。古今中外經典詩詞曲一網打盡。包含中國先秦到近當代的作品如詩經、古詩、南北朝民歌、唐詩、宋詞、元曲、近當代的自由詩 和世界各國著名詩人如拜倫、莎士比亞、雪萊、泰戈爾、裴多菲、普希金、狄金森、歌德、海涅等的經典名作 ...
  • 摘要:遷移前後結果集row_number欄位值前後不一致,前在DWS上運行不一致。 本文分享自華為雲社區《GaussDB(DWS)遷移 - oracle相容 --row_number輸出結果不一致》,作者:譡里個檔 。 【問題表現】 遷移前後結果集row_number欄位值前後不一致,前在DWS上運 ...
  • 本系列為:MySQL資料庫詳解,為千鋒資深教學老師獨家創作,致力於為大家講解清晰MySQL資料庫相關知識點,含有豐富的代碼案例及講解。如果感覺對大家有幫助的話,可以【關註】持續追更~文末有本文重點總結,技術類問題,也歡迎大家和我們溝通交流! ...
  • 雖然之前已經有了《7千多條周公解夢斷夢秘書ACCESS資料庫》、《4千多周公解夢包含化解方法ACCESS資料庫》等相關的周公解夢的資料庫,但今天發現的周公解夢的記錄數量已經達到了上萬條,雖然分類沒有《7千多條周公解夢斷夢秘書ACCESS資料庫》多,但記錄數多出了不少。 分類情況彙總有:01自然類(6 ...
  • 《上萬條全球各國紙幣大全含圖ACCESS資料庫》是今天採集自錢幣大全網站的紙幣資料,大類包含:中國大陸、中國臺灣、中國香港、中國澳門、亞洲紙鈔、歐洲紙鈔、美洲紙鈔、非洲紙鈔 、大洋洲、其他紙鈔等,而且紙幣信息包含:國家名稱、英文名稱、目錄編號、紙鈔面額、紙鈔年版、紙鈔規格、所屬類別、詳細信息等。 收 ...
  • 我記得之前我採集、提取過兩份菜譜資料資料庫,一份是菜譜數據不上萬的帶圖片的,詳情點擊這裡,一份是2萬多條記錄但格式未整理並且沒有圖片的。而今天的這個3萬多條含圖片的菜譜資料ACCESS資料庫包含了3萬多條常菜譜做法,並且結構簡潔,最主要的是每個菜譜都包含圖片。 菜譜分50個大類和400多種小類,大類 ...
  • 一個學語文的朋友問我有沒有關於中華典故以及萬物由來的數據,我看了看手頭的資料發現還真沒有,而且網上似乎也沒有這一類的成品,因此就用程式採集了一個中華典故網的文章。 分類統計情況有:成語典故(共4198條)、典故雜聞(共702條)、國外典故(共29條)、科學典故(共29條)、歷史典故(共374條)、神 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...