搜尋
首頁專題PHP Mysql建立MySQL索引大幅優化某PHP應用效能

這篇文章為大家帶來了關於mysql的相關知識,其中主要介紹了關於索引大幅優化某PHP應用性能的相關內容,下面一起來看一下,希望對大家有幫助。

建立MySQL索引大幅優化某PHP應用效能

起因

前兩個月某朋友要做一個項目,本著快速上線推廣的目的,直接購買了某公司的原始碼並讓賣家部署上線。看到原始碼後,我直接對朋友說:算是被小坑了,這個源碼品質有點差,用戶數起來後可能會有比較嚴重的效能問題。

做出這樣的評價,我是有依據的:

  • 作為近乎即時應用,核心程式碼用PHP編寫,透過資料庫表記錄控制許多場景的並發和重複請求;

  • PHP開發不是問題,但對方工程師似乎不知道有CLI模式,而是透過計畫任務(crontab)達到程式不停運轉,於是乎浩浩蕩蕩幾十個curl計畫任務每分鐘執行;

  • #程式碼中有不少class1.php,像 class1-1.php這樣複製備份的文件,一眼看過去很難知曉其存在目的;

  • 存在不少for迴圈讀取資料庫的程式碼,命名規則混亂。

當然,能賺錢的程式碼才是好程式碼(對方就透過這些程式碼賺錢了),我也沒多去糾結。最初的想法是,4核8G的配置,跑1萬個客戶應該很難,跑5000就可以了。

轉折

就在這週,忽然頻繁接到 阿里雲 的警報簡訊和郵件,說CPU佔用過高。心想市場推廣很順利,用戶大增嗎?一問朋友,才不到300個用戶!

建立MySQL索引大幅優化某PHP應用效能

這時才意識到,這套程式碼實際表現比我想想中的更差,有嚴重的效能問題。依照這個資源消耗速度,升級硬體是無底洞,效能優化才是正途。

效能最佳化

拿到程式碼兩個月了,閒暇時間偶爾會看一下,已經大體知道其結構和主要功能。現在出現了嚴重效能問題,是時候嘗試做一些效能優化了。

鑑於數十個計畫任務不停運行,其不斷驅動系統運轉,因此計畫任務的相關功能是最先被了解的。根據自己的理解,先暫停了二十多個已經不需要的計畫任務。暫停無用計畫任務後,系統整體CPU使用率下降到了60%多,煩人的提醒簡訊和郵件終於消停了。等待了一天,朋友也沒有回饋有功能受影響,顯示思路和出手點都正確。

但是200多個用戶就這麼消耗資源,一定還有什麼地方不對勁。今天有空又登入伺服器,執行top指令,發現mysql進程一直佔據200%多的CPU資源。看過原始碼的我知道MySQL佔用高是有原因的而且是可能的,但還是想看看為什麼這麼耗資源。

登入MySQL伺服器,查看是否開啟了slow log:show variables like '%slow%';,發現開啟了慢查詢日誌:

建立MySQL索引大幅優化某PHP應用效能

接著檢視日誌,查到某條sql語句一直出現在日誌中:

建立MySQL索引大幅優化某PHP應用效能

可以看到,執行這條sql語句掃描了38萬多行記錄。語句涉及的兩張表一張有600多筆記錄,另一張4萬多筆記錄,相當於全表掃描了4萬多的表好幾次,怪不得特別慢。

接著檢查兩個表的索引,除了自增id作為主鍵外,沒有建立其他索引。使用explain執行語句,顯示沒有使用任何索引:

建立MySQL索引大幅優化某PHP應用效能

接下來,在兩個表上分別就查詢條件的uid、session_id列上建立索引。索引建立完成後,肉眼可見的CPU佔用率和系統負載都降下來了。再次使用explain執行查詢語句,索引資訊已經用上了,掃描行數大大減少:

建立MySQL索引大幅優化某PHP應用效能

經過上面的最佳化,目前應用的總體CPU佔用率在5%左右,MySQL的CPU佔用率大約是15%,系統負載從4降到了0.3。終於暫時不用擔心效能問題了,就算伺服器配置降到1核心CPU也能撐得住。

進一步查看程式碼並結合日誌,建立索引和修改部分查詢語句,CPU佔用率降到6%左右,終於暫時不用擔心效能問題了

總結

工程師在開發工程中,不僅要寫出「能用」的程式碼,還要寫出「好用」的程式碼。本例中透過建立兩個索引就能大幅提升系統效能,便是讓程式碼從「能用」轉到「好用」。

本文提到的效能最佳化偏運維,程式碼中的效能最佳化暫時還未觸碰。但一個整體的原則是不會錯的:多使用緩存,盡可能的減少慢IO設備的同步讀取。

推薦學習:《mysql影片教學》、《PHP影片教學

以上是建立MySQL索引大幅優化某PHP應用效能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:tlanyan。如有侵權,請聯絡admin@php.cn刪除

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境