首頁 >後端開發 >php教程 >Yii框架官方指南系列52-專題:效能調整

Yii框架官方指南系列52-專題:效能調整

黄舟
黄舟原創
2017-02-16 10:00:011340瀏覽



網路應用程式的效能受許多因素的影響。資料庫訪問,檔案系統操作,網路頻寬等都是潛在的影響因素。 Yii 已在各方面減少框架帶來的效能影響。但是在用戶的應用中仍有許多地方可以被改善來提高效能。

1. 開啟 APC 擴充

啟用 PHP APC 擴充 可能是改善一個應用整體效能最簡單的方式。此擴充功能快取和最佳化 PHP 中間程式碼並避免時間花費再為每個新來的請求解析PHP腳本。

2. 停用偵錯模式

禁用偵錯模式是另一個改善效能的容易方式。若常數 YII_DEBUG 被定以為 true,這個 Yii 應用將以調試模式運作。 調試模 式在開發階段是有用的,但是它影響性能因為一些組件引起額外的系統開銷。例如,資訊記錄器(the message logger)將為 被筆被記錄的資訊記錄額外的偵錯資訊。

3. 使用 yiilite.php

當啟用 PHP APC 擴充 時, 我們可以將 yii.php 替換為另一個名為 yiilite. 。

檔案 

yiilite.php 包含在每個 Yii 發布中。它是一些常用到的 Yii 類別文件的合併文件。在文件中,註釋和追蹤語句都被移除。因此,使用 yiilite.php 將減少被引用的檔案數量並避免執行追蹤語句。

注意,使用 

yiilite.php 而不開啟 APC 實際上將降低效能,因為 yiilite.php 包含了一些不是每個請求都必須的類別,這將花費額外的解析時間。 同時也要注意,在一些伺服器設定下使用 yiilite.php 將更慢,即使 APC 被開啟。 最好使用示範中的 hello world 執行基準程式來決定是否使用 yiilite.php

4. 使用快取技術

如在 快取 章節所述,Yii 提供了幾個可以有效提升效能的快取方案。 若某些資料的產生需要長時間,我們可以使用資料快取 方法來減少資料產生的頻率;若頁面的一部分保持相對的固定,我們可以使用 碎片快取 方法來減少它的渲染頻率;若一整個頁面保持相對的固定,我們可以使用 頁面快取 方法來節省頁面渲染所需的花銷。

若應用在使用 Active Record,我們應當開啟 資料結構快取 以節省解析資料表結構的時間。可以 透過設定CDbConnection::schemaCachingDuration 屬性為一個大於 0 的值來完成。

除了這些應用程式層級的快取技術,我們也可使用服務等級的快取方案來提升應用程式的效能。 事實上,我們之前描述的PHP APC 快取 就屬於此項。 還有其他的伺服器技術,例如 Zend Optimizer, eAccelerator, Squid,其他則不一一列出。

5. 資料庫最佳化

從資料庫取出資料經常是一個網路應用的主要瓶頸。雖然使用快取可以減少效能損失,但它不能解決根本問題。 當資料庫包 包含大量資料而被快取的資料是無效時,如果沒有良好的資料庫和查詢最佳化設計,取得最新的資料將會非常耗費資源。

在一個資料庫中聰明的設計索引。索引可以讓 

SELECT 查詢更快, 但它會讓 INSERTUPDATE 或 DELETE 查詢更慢。

對於複雜的查詢,推薦為它建立一個資料庫視圖,而不是透過PHP程式碼產生查詢語句讓DBMS來重複解析他們。

不要濫用 Active Record。雖然 Active Record 擅長以一個 OOP樣式模型化數據, 它實際上為了它需要創建一個或幾個對 象來代表每個查詢結果降低了性能。 對於資料密集的應用,在底層使用 DAO 或 資料庫介面 將會是更好的選擇。

最後但不是最不重要的一點,在你的 

SELECT 查詢中使用 LIMIT 。這將避免從資料庫中取出過多的資料 並耗盡為 PHP 分配的記憶體。

6. 最小化腳本檔案

複雜的頁面經常需要引入許多外部的 JavaScript 和 CSS 檔案。 因為每個文件將引起一次額外的往返一次,我們應該透過聯合文件來最小化腳本文件的數量。 我們也應考慮減少每個腳本檔案的大小來減少 網路傳輸時間。有很多工具來幫助改善這兩方面。

對於一個 Yii 產生的頁面,例外是一些由組件渲染的腳本文件我們不想要更改 (例如 Yii core 組件,第三方組件)。 為了最小化這些腳本文件,我們需要兩個步驟。

Note: 下方所述的 scriptMap 特徵已自版本 1.0.3 起支援。

首先,透過設定應用元件 clientScript 的 scriptMap 屬性來宣告腳本被最小化。 可以在應用程式配置中完成,也可以在程式碼中配置。例如,


$cs=Yii::app()->clientScript;
$cs->scriptMap=array(
    'jquery.js'=>'/js/all.js',
    'jquery.ajaxqueue.js'=>'/js/all.js',
    'jquery.metadata.js'=>'/js/all.js',
    ......
);

上面的程式碼所做是映射這些 JavaScript 檔案到 URL /js/all.js。 如果這些 JavaScript 檔案任何之一需要被一些元件引入, Yii 將會引入這個 URL (一次) 而不是各個獨立的腳本檔案。

其次,我們需要使用一些工具來聯合 (和壓縮) JavaScript 文件為一個單獨的文件,並保存為 js/all.js

相同的技巧也適用於 CSS 檔案。

在 Google AJAX Libraries API 幫助下我們可以改善頁面載入速度。例如,我們可以從 Google 的伺服器引入jquery.js 而不是從我們自己的伺服器。要這樣做, 我們首先配置 scriptMap 如下,


$cs=Yii::app()->clientScript;
$cs->scriptMap=array(
    'jquery.js'=>false,
    'jquery.ajaxqueue.js'=>false,
    'jquery.metadata.js'=>false,
    ......
);

透過映射(map)這些腳本檔案為 false,我們阻止 Yii 引入這些檔案的程式碼。作為替代,我們在頁面中編寫如下程式碼直接從Google 引入文件,

<head>
<?php echo CGoogleApi::init(); ?>

<?php echo CHtml::script(
    CGoogleApi::load(&#39;jquery&#39;,&#39;1.3.2&#39;) . "\n" .
    CGoogleApi::load(&#39;jquery.ajaxqueue.js&#39;) . "\n" .
    CGoogleApi::load(&#39;jquery.metadata.js&#39;)
); ?>
......
</head>

 以上就是Yii框架官方指南系列52——專題:性能調整的內容,更多相關內容請關注PHP中文網(www. php.cn)!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn