AgentSkillsCN

acc-create-bulkhead

为 PHP 8.5 生成熔断器模式。通过基于信号量的并发限制与线程池隔离,实现资源的精细化隔离,并附带单元测试。

SKILL.md
--- frontmatter
name: acc-create-bulkhead
description: Generates Bulkhead pattern for PHP 8.5. Creates resource isolation with semaphore-based concurrency limiting and thread pool isolation. Includes unit tests.

Bulkhead Pattern Generator

Creates Bulkhead pattern infrastructure for resource isolation and fault containment.

When to Use

ScenarioExample
External API callsLimit concurrent requests to payment gateway
Database connectionsPool size limiting
CPU-intensive workLimit by CPU cores
Multi-instanceRedis-based coordination

Component Characteristics

BulkheadInterface

  • Common interface for all isolation strategies
  • Acquire and release semantics
  • Capacity monitoring

Strategies

  • Semaphore Bulkhead: Limits concurrent executions
  • Thread Pool Bulkhead: Isolates execution with dedicated pool
  • Queue-based Bulkhead: Limits with waiting queue

BulkheadFullException

  • Thrown when bulkhead capacity exhausted
  • Contains bulkhead name and capacity info

Generation Process

Step 1: Generate Core Components

Path: src/Infrastructure/Resilience/Bulkhead/

  1. BulkheadInterface.php — Common interface
  2. BulkheadConfig.php — Configuration value object
  3. BulkheadFullException.php — Exception with capacity info

Step 2: Generate Bulkhead Implementation

Choose based on use case:

  1. SemaphoreBulkhead.php — Local semaphore-based limiting
  2. DistributedSemaphoreBulkhead.php — Redis-based for multi-instance

Step 3: Generate Registry (Optional)

  1. BulkheadRegistry.php — Manages multiple bulkheads

Step 4: Generate Tests

  1. SemaphoreBulkheadTest.php — Bulkhead behavior tests
  2. BulkheadConfigTest.php — Configuration tests

File Placement

ComponentPath
All Classessrc/Infrastructure/Resilience/Bulkhead/
Unit Teststests/Unit/Infrastructure/Resilience/Bulkhead/

Naming Conventions

ComponentPatternExample
InterfaceBulkheadInterfaceBulkheadInterface
SemaphoreSemaphoreBulkheadSemaphoreBulkhead
DistributedDistributedSemaphoreBulkheadDistributedSemaphoreBulkhead
ConfigBulkheadConfigBulkheadConfig
RegistryBulkheadRegistryBulkheadRegistry
ExceptionBulkheadFullExceptionBulkheadFullException
Test{ClassName}TestSemaphoreBulkheadTest

Quick Template Reference

BulkheadInterface

php
interface BulkheadInterface
{
    public function execute(callable $operation): mixed;
    public function tryAcquire(): bool;
    public function release(): void;
    public function getAvailablePermits(): int;
    public function getActiveCount(): int;
    public function getName(): string;
}

BulkheadConfig

php
final readonly class BulkheadConfig
{
    public function __construct(
        public int $maxConcurrentCalls = 10,
        public int $maxWaitDuration = 0,
        public bool $fairness = true
    ) {}

    public static function default(): self;
    public static function forCpuBound(int $cpuCores): self;
    public static function forIoBound(int $cpuCores): self;
    public static function forExternalService(int $maxConnections): self;
}

Usage Example

php
// Create limiter
$bulkhead = new SemaphoreBulkhead(
    name: 'payment-gateway',
    config: BulkheadConfig::forExternalService(maxConnections: 20),
    logger: $logger
);

// Execute with isolation
try {
    $result = $bulkhead->execute(fn() => $client->charge($request));
} catch (BulkheadFullException $e) {
    return Result::serviceOverloaded();
}

Use Case Selection

Use CaseBulkhead TypeConfig
External API callsSemaphoreLimited by API rate limits
Database connectionsSemaphoreLimited by pool size
CPU-intensive workSemaphoreLimited by CPU cores
Multi-instanceDistributedRedis-based coordination
Mixed workloadsRegistryPer-service configuration

Anti-patterns to Avoid

Anti-patternProblemSolution
Global BulkheadSingle point of contentionPer-service bulkheads
No ReleasePermit leakAlways release in finally
Wrong SizeToo small = rejected, too large = no protectionRight-size per service
No MetricsCan't monitor usageTrack acquired/rejected
Infinite WaitThread starvationSet maxWaitDuration
No FallbackHard failure on fullProvide degraded response

References

For complete PHP templates and examples, see:

  • references/templates.md — BulkheadInterface, Config, SemaphoreBulkhead, DistributedSemaphoreBulkhead, Registry
  • references/examples.md — PaymentGatewayAdapter, ConnectionPool, OrderService examples and tests