下面由Laravel教學欄位給大家詳解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中文網其他相關文章!