yaknet / circuit-breaker
A robust and resilient Circuit Breaker implementation for PHP applications.
dev-main
2026-05-13 16:15 UTC
Requires
- php: >=8.1
Requires (Dev)
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^10.0
This package is auto-updated.
Last update: 2026-05-13 16:19:15 UTC
README
A robust, resilient, and lightweight Circuit Breaker implementation for modern PHP applications. Prevent cascading failures and make your system more reliable when interacting with external APIs or microservices.
๐ Features
- Modern PHP 8.1+: Leverages Enums, Readonly properties, and strictly typed logic.
- Fail-Fast Strategy: Immediately blocks requests to failing services to save resources and allow recovery.
- Three-State Management: Full support for
CLOSED,OPEN, andHALF_OPENstates. - Storage Agnostic: Comes with
FileStorageout of the box, with an interface to easily add Redis or Memcached. - Developer Friendly: Simple API and zero-dependency core.
๐ฆ Installation
composer require yaknet/circuit-breaker
๐ Usage
Basic Example
use YakNet\CircuitBreaker\CircuitBreaker; use YakNet\CircuitBreaker\Storage\FileStorage; use YakNet\CircuitBreaker\Settings; // 1. Initialize Storage $storage = new FileStorage(__DIR__ . '/cache'); // 2. Configure Settings (Optional) $settings = new Settings( failureThreshold: 5, retryTimeout: 60 ); // 3. Create the Breaker $breaker = new CircuitBreaker('GeminiAPI', $storage, $settings); // 4. Run your risky operation try { $result = $breaker->run(function() { // Your logic here (e.g. API call) return $api->fetchData(); }); } catch (\YakNet\CircuitBreaker\Exception\CircuitOpenException $e) { // Service is currently down, handle gracefully echo "Service unavailable. Try again in " . $e->getMessage(); }
๐ง Core States
| State | Description |
|---|---|
| CLOSED | Normal operation. Requests flow through to the service. |
| OPEN | Failure threshold reached. Requests fail immediately without hitting the service. |
| HALF_OPEN | Trial period. A limited number of requests are allowed to check if the service recovered. |
๐งช Testing
composer test
๐ License
The MIT License (MIT). Please see License File for more information.
Developed with โค๏ธ by YakNet