mc0de/console-timer
最新稳定版本:1.0.3
Composer 安装命令:
composer require mc0de/console-timer
包简介
A trait for tracking execution time in Laravel console commands
README 文档
README
A simple trait that adds execution time tracking to your Laravel console commands. Useful for:
- Tracking how long your commands take to run
- Measuring specific operations within commands
- Debugging slow operations
- Getting timing feedback during long-running processes
Features
- Track total command execution time
- Measure individual operations
- Get operation return values
- Format durations in a readable way
- Start/stop measurements manually or with closures
Requirements
- PHP ^8.1
- Laravel 10.x|11.x|12.x
Installation
composer require mc0de/console-timer
Usage
Basic Usage
Add the trait to your command and wrap operations you want to measure:
use Mc0de\ConsoleTimer\ConsoleTimer; use Illuminate\Console\Command; class YourCommand extends Command { use ConsoleTimer; public function handle() { $this->startCommandTimer(); $this->measure('Processing items', function () { // Your processing logic }); $this->displayCommandTime(); } }
Getting Return Values
$result = $this->measure('Fetching data', function () { return ['data' => 'value']; }); // $result contains ['data' => 'value']
Manual Timing
For operations that span multiple methods:
public function handle() { $this->startCommandTimer(); $this->startMeasure('Processing items'); $this->processItems(); $this->finishMeasure(); $this->displayCommandTime(); } protected function processItems() { // This method is part of the measured operation }
Example Output
19:17:45 Fetching CRM data ........................................ 1.92s ✓
19:17:47 Syncing product catalog .................................. 2.34s ✓
19:17:49 Processing user data ..................................... 394ms ✓
19:17:49 Running ML recommendations ............................... 3.76s ✓
19:17:53 Generating sales report .................................. 899ms ✓
19:17:54 Creating analytics dashboard ............................. 5.26s ✓
19:17:59 Saving to database ....................................... 389ms ✓
Completed in 14.99s
Methods
startCommandTimer()- Start tracking total command timemeasure(string $message, Closure $callback)- Measure an operation and show progressstartMeasure(string $message)- Start measuring without a closurefinishMeasure()- End the current measurementdisplayCommandTime()- Show total command execution time
License
MIT License - see LICENSE.md
统计信息
- 总下载量: 293
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 14
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-04-25