承接 perfbase/yii1 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

perfbase/yii1

最新稳定版本:v1.1.1

Composer 安装命令:

composer require perfbase/yii1

包简介

Yii 1.1 integration for the Perfbase profiling tool.

README 文档

README

Perfbase

Perfbase for Yii 1.1

Yii 1.1 integration for Perfbase.

Packagist Version License CI PHP Version Yii Version

This package is a thin adapter over perfbase/php-sdk. It keeps the framework layer thin, delegates transport and extension access to the shared SDK, fails open in production, and keeps action naming low-cardinality.

Scope

v1 supports:

  • HTTP request profiling
  • Console command profiling
  • Cron profiling as a classified console sub-context

v1 does not support:

  • Queue workers
  • Custom buffering or retries
  • Yii-specific profiler UI or debug panels

This package is positioned as a legacy-support adapter for real Yii 1.1 applications.

Requirements

  • PHP >=7.4 <8.5
  • Yii 1.1.x
  • perfbase/php-sdk ^1.0
  • The native Perfbase PHP extension available to the target PHP runtime

Installation

composer require perfbase/yii1

Register the component as a preloaded application component in both your web and console configs:

return [
    'preload' => ['perfbase'],
    'components' => [
        'perfbase' => [
            'class' => \Perfbase\Yii1\PerfbaseComponent::class,
            'enabled' => true,
            'api_key' => getenv('PERFBASE_API_KEY') ?: '',
            'sample_rate' => 0.1,
            'app_version' => '1.0.0',
        ],
    ],
];

Composer-based installation is required. Non-Composer Yii 1.1 applications are out of scope.

Configuration

The adapter exposes this config contract:

[
    'enabled' => false,
    'debug' => false,
    'log_errors' => true,
    'api_key' => '',
    'api_url' => 'https://ingress.perfbase.cloud',
    'sample_rate' => 0.1,
    'profile_http_status_codes' => [...range(200, 299), ...range(500, 599)],
    'timeout' => 10,
    'proxy' => null,
    'flags' => \Perfbase\SDK\FeatureFlags::DefaultFlags,
    'app_version' => '',
    'include' => [
        'http' => ['*'],
        'console' => ['*'],
        'cron' => [],
    ],
    'exclude' => [
        'http' => [],
        'console' => [],
        'cron' => [],
    ],
]

Config notes:

  • enabled controls Perfbase profiling, not Yii component loading.
  • include.cron is empty by default. That means console commands profile as source=console unless you explicitly classify them as cron.
  • sample_rate must be numeric and between 0.0 and 1.0.
  • profile_http_status_codes defaults to [...range(200, 299), ...range(500, 599)]. Add codes such as 404 if you want to keep them, or set it to [] to disable HTTP trace submission entirely.
  • app_version is application-defined.
  • environment is derived from YII_ENV when available, otherwise production.

HTTP Profiling

HTTP profiling is attached through Yii 1.1 application events:

  • onBeginRequest starts the HTTP lifecycle
  • onException and onError attach exception context
  • onEndRequest finalizes and submits

Attributes include:

  • source=http
  • action
  • http_method
  • http_url
  • http_status_code
  • user_ip
  • user_agent
  • user_id when Yii user state is available and authenticated
  • hostname
  • environment
  • app_version
  • php_version

Behavior details:

  • action prefers a stable Yii route
  • http_url excludes query strings
  • HTTP traces are only submitted when the response status code is in profile_http_status_codes
  • query parameters are intentionally not included in the primary action/span fields
  • response status defaults to 200 when Yii has not set a more specific status

Console and Cron Profiling

Console profiling also uses application lifecycle hooks:

  • onBeginRequest resolves the console command from $_SERVER['argv']
  • onException and onError mark failures
  • onEndRequest finalizes and submits

Console behavior:

  • normal console commands use source=console
  • commands matching include.cron and not matching exclude.cron use source=cron
  • span names are console.{command} or cron.{command}
  • exit code handling is best-effort and intentionally thin:
    • 0 on normal completion
    • 1 on uncaught exception or error paths

Cron is just a classification of console commands. There is no scheduler-specific integration in v1.

Filters

Each context supports include/exclude filters:

  • http
  • console
  • cron

Supported filter styles:

  • *
  • .*
  • glob patterns such as cache/*
  • regex patterns such as /^GET \/users/

Examples:

'include' => [
    'http' => ['site/*', '/^GET \\/api\\//'],
    'console' => ['cache/*', 'migrate'],
    'cron' => ['schedule/*', 'jobs/run'],
],
'exclude' => [
    'http' => ['debug/*'],
    'console' => ['help'],
    'cron' => ['schedule/test'],
],

Error Handling

The adapter is designed to fail open:

  • if SDK construction fails, profiling becomes a no-op
  • if the extension is unavailable, profiling becomes a no-op
  • if submission fails, the application continues

Error mode behavior:

  • debug=false: swallow errors and optionally log them
  • debug=true: rethrow Perfbase adapter/runtime errors

Runtime Architecture

The package stays intentionally thin:

The adapter does not implement a separate transport or persistence layer.

Development

Install and verify with:

composer install
composer run test
composer run phpstan

Documentation

Full documentation is available at perfbase.com/docs.

License

Apache-2.0. See LICENSE.txt.

统计信息

  • 总下载量: 2
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 6
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: Apache-2.0
  • 更新时间: 2026-04-08

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固