搜尋
首頁後端開發php教程與黑火的增壓應用程序的深入演練

blackfire.io:深入研究更快的PHP應用程序的性能分析

>沒有人喜歡緩慢,笨拙的應用程序,尤其是在處理快速擴展的數據庫和數百萬日常請求時。 分析提供了一個解決方案,提供了對程序資源消耗(時間和內存)的見解。這允許識別和解決性能瓶頸。 存在許多分析工具,每種工具都採用不同的方法。

An In-depth Walkthrough of Supercharging Apps with Blackfire

>兩種主要分析方法是採樣和儀器。採樣定期捕獲呼叫堆棧或內存的快照,最小化的性能,但可能丟失了細節。相反,儀器將分析指令直接插入代碼(手動或自動在字節碼級別上),提供精確的詳細信息,但具有更大的性能開銷。

BlackFire可以通過Chrome擴展或命令行接口訪問,很容易集成到包括Homestead在內的各種環境中。該教程展示了Blackfire在改進的設置中構建更快的應用程序中的用途。

密鑰功能:

零影響儀器:與傳統介紹者不同,黑火不會減慢您的應用程序。

> 通過Chrome擴展名或命令行工具。
  • 寬兼容性:與眾多雲提供商和虛擬機,包括宅基地的無縫集成。
  • 模塊化體系結構:>包括一個探針(PHP擴展),代理(服務器端守護程序),companion(Chrome Extension),客戶端(CLI)和基於Web的接口。
  • 連續測試:
  • 主動績效管理而沒有代碼更改。
  • 詳細的可視化:
  • 圖形表示有效瓶頸分析的執行流和性能指標。
  • 入門:

    >通過vagrant ssh訪問您的流浪框後,創建一個Blackfire帳戶(如果您還沒有一個帳戶)。 從Blackfire配置文件設置中檢索您的憑據(客戶端和服務器)。 使用以下憑據更新您的homestead.yaml>文件(位於Vagrant Box的根目錄中)

    blackfire:
        - id: "Server Id here"
          token: "Server token here"
          client-id: "Client Id here"
          client-token: "Client token here"

    黑火體系結構:

    黑火包括五個核心組件:

      >
    • >探針: php擴展工具儀器和收集性能數據(Linux和MacOS)。 >
    • 代理:
    • 服務器端守護程序匯總和將配置文件信息傳輸到Blackfire。
    • 伴侶:
    • >基於瀏覽器的分析的Google Chrome擴展名。
    • 客戶端:
    • 同伴的命令行等效。 >
    • Web接口:
    • 一個基於Web的儀表板,用於可視化和比較配置文件數據。 >
    • (探針,代理和客戶端已預先安裝在Homestead改進中。)

    基本術語:

    參考資料:比較的基線性能測量。

      獨家時間:
    • >執行功能所花費的時間,不包括外部呼叫。
    • 包含時間:
    • >總執行時間,包括外部呼叫。
    • 熱路徑:
    • 分析過程中應用程序中最活躍的部分。 >
    • 分析php腳本:
    • >
    >讓我們介紹一個涉及數據庫交互的腳本。 為了進行現實的結果,我們將使用Faker生成虛擬數據,避免在我們的主要分析中包括Faker的開銷。

    1。虛擬數據生成(userproviderjson.php):

    >使用

    運行此腳本。這會創建

    <?php
    require_once('vendor/autoload.php');
    
    $num = isset($_GET['num']) ? $_GET['num'] : 1000;
    $data = [];
    
    $faker = Faker\Factory::create();
    
    if(!file_exists('data')) {
        mkdir('data');
    }
    
    for ($i = 0; $i < $num; $i++) {
        $data[] = ['name' => $faker->name, 'email' => $faker->email, 'city' => $faker->city,];
    }
    
    file_put_contents('data/users.json', json_encode($data));
    
    echo 'JSON file generated.';
    2。數據庫設置:

    php UserProviderJSON.php data/users.json創建一個具有適當列的MySQL數據庫(

    )和表(

    )。

    3。主腳本(Benchmark-before.php):

    blackfire_tutorial sample_users

    >通過其URL訪問此腳本以填充數據庫。 >

    4。初始分析:

    <?php
    $db = new PDO('mysql:host=localhost;dbname=blackfire_tutorial;charset=utf8', 'homestead', 'secret');
    
    function SaveCustomers($db) {
        $users = json_decode(file_get_contents('data/users.json'), true);
        foreach ($users as $user) {
            $stmt = $db->prepare("INSERT INTO sample_users (name, email, city) VALUES (?, ?, ?)");
            $stmt->execute([$user['name'], $user['email'], $user['city']]);
        }
    }
    
    SaveCustomers($db);
    echo 'Users imported successfully.';
    使用Blackfire Chrome擴展名,配置文件

    ,創建一個新的參考配置文件。

    >

    Blackfire Web界面提供了詳細的分析:工具欄匯總了關鍵指標,可視化執行流,具有詳細定時信息的功能列表以及各種指標(SQL查詢,內存使用等)。

    benchmark-before.php5。優化和重新封建:

    >優化腳本以減少數據庫調用(例如,使用具有多個值的單個插入語句)。 用優化的代碼創建benchmark-after.php。重新構圖,與參考配置文件進行比較。

    An In-depth Walkthrough of Supercharging Apps with Blackfire

    比較突出了績效的改進。

    命令行接口:

    >黑火的CLI(

    )允許通過終端進行分析:> blackfire

      proping http請求:
    • > blackfire curl http://your-url
    • 分析CLI腳本:
    • > blackfire run php your-script.php創建一個參考資料:
    • blackfire --new-reference curl http://your-url
    • 與參考值進行比較:
    • blackfire --reference=profile-id curl http://your-url>

    性能測試:

    blackfire(高級用戶)允許在

    >文件中創建性能測試,從而定義了各種指標的斷言。 .blackfire.yml

    結論: BlackFire.IO是優化PHP應用程序性能的強大工具。它的易用性,詳細的分析和連續的測試功能使其對於努力為高性能應用程序而進行的開發人員無價。 提供的常見問題解答進一步闡明了其功能和收益。 請記住,用您的實際服務器ID,代幣和數據庫憑據替換代碼示例中的佔位符值。 >

以上是與黑火的增壓應用程序的深入演練的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
PHP如何識別用戶的會話?PHP如何識別用戶的會話?May 01, 2025 am 12:23 AM

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

確保PHP會議的一些最佳實踐是什麼?確保PHP會議的一些最佳實踐是什麼?May 01, 2025 am 12:22 AM

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

PHP會話文件默認存儲在哪裡?PHP會話文件默認存儲在哪裡?May 01, 2025 am 12:15 AM

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()

您如何從PHP會話中檢索數據?您如何從PHP會話中檢索數據?May 01, 2025 am 12:11 AM

ToretrievedatafromaPHPsession,startthesessionwithsession_start()andaccessvariablesinthe$_SESSIONarray.Forexample:1)Startthesession:session_start().2)Retrievedata:$username=$_SESSION['username'];echo"Welcome,".$username;.Sessionsareserver-si

您如何使用會議來實施購物車?您如何使用會議來實施購物車?May 01, 2025 am 12:10 AM

利用會話構建高效購物車系統的步驟包括:1)理解會話的定義與作用,會話是服務器端的存儲機制,用於跨請求維護用戶狀態;2)實現基本的會話管理,如添加商品到購物車;3)擴展到高級用法,支持商品數量管理和刪除;4)優化性能和安全性,通過持久化會話數據和使用安全的會話標識符。

您如何在PHP中創建和使用接口?您如何在PHP中創建和使用接口?Apr 30, 2025 pm 03:40 PM

本文解釋瞭如何創建,實施和使用PHP中的接口,重點關注其對代碼組織和可維護性的好處。

crypt()和password_hash()有什麼區別?crypt()和password_hash()有什麼區別?Apr 30, 2025 pm 03:39 PM

本文討論了PHP中的crypt()和password_hash()的差異,以進行密碼哈希,重點介紹其實施,安全性和對現代Web應用程序的適用性。

如何防止PHP中的跨站點腳本(XSS)?如何防止PHP中的跨站點腳本(XSS)?Apr 30, 2025 pm 03:38 PM

文章討論了通過輸入驗證,輸出編碼以及使用OWASP ESAPI和HTML淨化器之類的工具來防止PHP中的跨站點腳本(XSS)。

See all articles

熱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

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

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境