fastcgi_finish_request()
est une fonction fournie par php-fpm
qui peut mettre fin aux données de réponse de connexion plus tôt et continuer à effectuer des tâches sur le backend, afin d'effectuer des tâches de longue durée tâches ou améliorer En ce qui concerne la vitesse de réponse, nous pouvons utiliser cette fonction pour réaliser une implémentation simple. Bien sûr, une meilleure façon consiste à utiliser une file d'attente.
Dans Laravel, l'envoi d'une réponse appellera fastcgi_finish_request()
(s'il existe), puis la méthode terminate()
sera appelée, qui exécutera à son tour la méthode terminate()
dans le middleware enregistré.
L'utilisation de Terminable Middleware dans le document nécessite l'enregistrement d'un middleware global, mais en pratique, nous n'aurons peut-être besoin que de répondre à l'avance à certaines interfaces puis de traiter la logique ultérieure (base de données, logs...). Mais à partir du code source, nous pouvons voir que le routeMiddleware
de Laravel prend en charge le middleware Terminable, nous pouvons donc définir un middleware FinishRequest
comme suit pour l'enregistrer et l'utiliser.
<?phpnamespace App\Http\Middleware;use Closure;class FinishRequest {protected static $next;/** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure $next * @return mixed */public function handle($request, Closure $next){self::$next = $next;return response(['code' => 0, 'data' => [], 'msg' => '']);}/** * @param \Illuminate\Http\Request $request * @param $response */public function terminate($request, $response){call_user_func(self::$next, $request);} }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!