首頁  >  文章  >  php框架  >  詳解laravel mysql表優化

詳解laravel mysql表優化

藏色散人
藏色散人轉載
2021-02-05 16:24:182816瀏覽

下面由Laravel教學欄位給大家詳解laravel mysql表優化 ,希望對需要的朋友有幫助!

詳解laravel mysql表優化

1. 設定資訊快取

使用以下Artisan 自帶指令,把config 資料夾裡所有設定資訊合併到一個檔案裡,減少執行時間檔案的載入數量:

php artisan config:cache

上面命令會產生檔案bootstrap/cache/config.php,可以使用以下命令來取消設定資訊快取:

php artisan config:clear

此命令做的事情就是把bootstrap/cache/config.php 檔案刪除。

注意:配置資訊快取不會隨著更新而自動重載,所以,開發時候建議關閉配置資訊緩存,一般在生產環境中使用,可以配合 Envoy 任務運行器 一起使用。

2. 路由快取

路由快取可以有效的提高路由器的註冊效率,在大型應用程式中效果越加明顯,可以使用以下命令:

php artisan route:cache

以上指令會產生bootstrap/cache/routes.php 文件,需要注意的是,路由快取不支援路由匿名函數編寫邏輯。

可以使用下面指令清除路由快取:

php artisan route:clear

此指令做的事情就是把 bootstrap/cache/routes.php 檔案刪除。

注意:路由快取不會隨著更新而自動重載,所以,開發時候建議關閉路由緩存,一般在生產環境中使用,可以配合 Envoy 任務運行器 一起使用。

3. 類別映射載入最佳化

optimize 指令把常用載入的類別合併到一個檔案裡,透過減少檔案的載入,來提高運作效率:

php artisan optimize --force

會產生bootstrap/cache/compiled.php 和bootstrap/cache/services.json 兩個檔案。

你可以可以透過修改 config/compile.php 檔案來加入要合併的類別。

在 production 環境中,參數 --force 不需要指定,檔案就會自動產生。

要清除類別對映載入最佳化,請執行下列指令:

php artisan clear-compiled

此指令會刪除上面 optimize 產生的兩個檔案。

注意:此指令要執行在 php artisan config:cache 後,因為 optimize 指令是根據設定資訊(如:config/app.php 檔案的 providers 陣列)來產生檔案的。

4. 自動載入最佳化

此指令不只針對於 Laravel 程序,適用於所有使用 composer 來建置的程式。此指令會把 PSR-0 和 PSR-4 轉換為一個類別映射表,來提高類別的載入速度。

composer dumpautoload -o

注意:php artisan optimize --force 指令裡已經做了這個操作。

5. 使用Memcached 來儲存會話

每一個Laravel 的請求,都會產生會話,修改會話的儲存方式能有效提高程式效率,會話的設定資訊是config/session.php ,建議修改為Memcached 或Redis 等專業的快取軟體:

'driver' => 'memcached',

6. 使用專業快取磁碟機

#「快取」是提高應用程式運作效率的法寶之一,預設快取驅動是file 檔案緩存,建議切換到專業的快取系統,如Redis 或Memcached,不建議使用資料庫快取。

'default' => 'redis',

7. 資料庫請求最佳化

資料關聯模型讀取時使用延遲預先載入和預先載入;

使用Laravel Debugbar 或Clockwork 留意每個頁面的總資料庫請求數量;

這裡的篇幅只寫到與Laravel 相關的,其他關於資料優化的內容,請自行查閱其他資料。

8. 為資料集書寫快取邏輯

合理的使用Laravel 提供的快取層操作,把從資料庫裡面拿出來的資料集合進行緩存,減少資料庫的壓力,運行在內存上的專業快取軟體對資料的讀取也遠遠快於資料庫。

$posts = Cache::remember('index.posts', $minutes = 30, function()
{
return Post::with('comments', 'tags', 'author', 'seo')->whereHidden(0)->get();
});

remember 連資料關聯模型也都一併快取了,多麼方便呀。

9. 使用即時編譯器

HHVM 和OpCache 都能輕輕鬆鬆的讓你的應用程式在不用做任何修改的情況下,直接提高50% 或更高的效能,PHPhub 之前先做個實驗,具體請見:使用OpCache 提升PHP 5.5 程式效能。

10. 前端資源合併

作為優化的標準,一個頁面只應該載入一個CSS 和一個JS 文件,並且文件要能方便走CDN,需要文件名隨著修改而變化。

以上是詳解laravel mysql表優化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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