- Add comprehensive health check system with multiple endpoints - Add Prometheus metrics endpoint - Add production logging configurations (5 strategies) - Add complete deployment documentation suite: * QUICKSTART.md - 30-minute deployment guide * DEPLOYMENT_CHECKLIST.md - Printable verification checklist * DEPLOYMENT_WORKFLOW.md - Complete deployment lifecycle * PRODUCTION_DEPLOYMENT.md - Comprehensive technical reference * production-logging.md - Logging configuration guide * ANSIBLE_DEPLOYMENT.md - Infrastructure as Code automation * README.md - Navigation hub * DEPLOYMENT_SUMMARY.md - Executive summary - Add deployment scripts and automation - Add DEPLOYMENT_PLAN.md - Concrete plan for immediate deployment - Update README with production-ready features All production infrastructure is now complete and ready for deployment.
33 lines
903 B
PHP
33 lines
903 B
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Framework\Queue\Exceptions;
|
|
|
|
use App\Framework\Exception\Core\QueueErrorCode;
|
|
use App\Framework\Exception\ExceptionContext;
|
|
|
|
/**
|
|
* Exception thrown when Redis PHP extension is not loaded
|
|
*
|
|
* This is typically caught and handled with graceful fallback to FileQueue.
|
|
*/
|
|
final class RedisExtensionNotLoadedException extends QueueException
|
|
{
|
|
public static function notLoaded(): self
|
|
{
|
|
$context = ExceptionContext::forOperation('queue.init', 'QueueInitializer')
|
|
->withData([
|
|
'required_extension' => 'redis',
|
|
'loaded_extensions' => get_loaded_extensions(),
|
|
'fallback_available' => 'FileQueue',
|
|
]);
|
|
|
|
return self::fromContext(
|
|
'Redis PHP extension is not loaded',
|
|
$context,
|
|
QueueErrorCode::WORKER_UNAVAILABLE
|
|
);
|
|
}
|
|
}
|