Maison >cadre php >YII >File d'attente de messages dans Yii Framework : implémentation du traitement asynchrone

File d'attente de messages dans Yii Framework : implémentation du traitement asynchrone

PHPz
PHPzoriginal
2023-06-21 08:50:102000parcourir

Avec la popularisation d'Internet et le développement continu de la technologie, la quantité de données et la complexité des services continuent d'augmenter. Afin d'améliorer les performances et la vitesse de réponse du système, le traitement asynchrone est devenu un moyen technique largement utilisé. Dans le développement PHP, la file d'attente de messages est l'un des outils importants pour implémenter le traitement asynchrone. Le framework Yii fournit également un système complet de file d'attente de messages. Cet article présentera en détail comment utiliser les files d'attente de messages pour implémenter le traitement asynchrone dans le framework Yii.

1. Le concept et l'application de la file d'attente des messages

La file d'attente des messages est une méthode de stockage de messages premier entré, premier sorti (FIFO) Le producteur du message envoie le message à la file d'attente, et le consommateur du message peut. récupérez le message de la file d’attente et traitez-le. Lorsque le traitement d'un message prend beaucoup de temps ou que le traitement consomme beaucoup de temps et de ressources, la file d'attente des messages peut être utilisée pour traiter le message de manière asynchrone et éviter de bloquer l'exécution du thread principal en plaçant la tâche dans la file d'attente. avance, le traitement de la tâche peut être réduit et la réponse, améliorant ainsi la vitesse de réponse et les capacités de traitement du système.

La file d'attente de messages propose un large éventail de scénarios d'application, tels que :

  1. Transcodage et compression d'images, de vidéos et d'autres fichiers ;
  2. Processus ETL de données (Extraire, Transformer, Charger), c'est-à-dire la collecte, le nettoyage et le chargement de données. importation ;
  3. Service push de messages ;
  4. Envoi d'e-mails, envoi de SMS et autres services ;
  5. Statistiques de données asynchrones, génération de rapports et autres tâches.

2. File d'attente de messages dans le framework Yii

Dans le framework Yii, un système complet de file d'attente de messages est fourni, comprenant les parties d'envoi et de consommation de messages. Nous pouvons utiliser le composant de file d'attente fourni par le framework Yii ou des extensions tierces (telles que yii-queue, Beanstalkd, etc.) pour implémenter la fonction de file d'attente de messages.

  1. Le composant de file d'attente intégré du framework Yii

Le composant de file d'attente intégré du framework Yii fournit un ensemble complet de processus de traitement de file d'attente de messages. Dans le framework Yii, l'utilisation de composants de file d'attente pour implémenter des files d'attente de messages nécessite les étapes suivantes :

  1. Créer une classe de traitement de messages

Nous pouvons créer une classe de traitement de messages et implémenter l'interface Queueable pour définir le processus de traitement des messages. Par exemple, nous créons une classe de traitement de messages nommée ExportTask, implémentons l'interface Queueable et implémentons le processus de traitement de tâches spécifique dans la méthode process :

use yiiqueueQueueable;

class ExportTask implements Queueable
{
    public $data;

    public function __construct($data)
    {
        $this->data = $data;
    }

    public function handle($queue)
    {
        // 处理导出任务
        // $this->data包含导出所需的参数和数据
    }
}
  1. Envoyer un message

Là où vous devez envoyer un message, appelez Yii : :$ La méthode app->queue->push envoie des messages à la file d'attente :

Yii::$app->queue->push(new ExportTask(['file' => 'export.xlsx', 'data' => $data]));
  1. Configurez le composant de file d'attente

Configurez le composant de file d'attente dans le fichier de configuration de l'application (généralement config/console.php) :

return [
    // ...
    'components' => [
        // ...
        'queue' => [
            'class' => yiiqueueedisQueue::class,
            'redis' => [
                'class' => yiiedisConnection::class,
                'hostname' => '127.0.0.1',
                'port' => 6379,
                'database' => 0,
            ],
            'channel' => 'queue',
        ],
        // ...
    ],
    // ...
];

Dans ce qui précède Dans la configuration, nous avons utilisé redis comme stockage de file d'attente de messages et également utilisé redis comme stockage de cache dans le framework Yii, réduisant ainsi l'utilisation des ressources système.

  1. Démarrez le processus de consommation

Utilisez la commande de console fournie par le framework Yii pour démarrer le processus de consommation :

yii queue/listen

Après le démarrage, le processus de consommation s'exécutera en arrière-plan, écoutant les messages dans la file d'attente et les traitant.

Voici les étapes de base pour implémenter la file d'attente de messages à l'aide du composant de file d'attente intégré au framework Yii. Il convient de noter que les méthodes de stockage de messages prises en charge par le composant de file d'attente intégré du framework Yii incluent des bases de données, des fichiers, etc. en plus de redis. Pour une implémentation spécifique, veuillez vous référer à la documentation officielle.

  1. Utilisation d'extensions tierces

Si vous devez utiliser d'autres méthodes de stockage de messages, vous pouvez utiliser des extensions tierces (telles que yii-queue, Beanstalkd, etc.) pour implémenter la fonction de file d'attente de messages. En prenant yii-queue comme exemple, nous devons configurer les éléments suivants :

  1. Installer l'extension

Utiliser composer pour installer l'extension yii-queue :

composer require yii2tech/queue
  1. Configurer le composant d'application

Dans le fichier de configuration de l'application (généralement config/console .php) :

return [
    // ...
    'components' => [
        // ...
        'queue' => [
            'class' => yiiqueuemqpQueue::class,
            'host' => '127.0.0.1',
            'port' => 5672,
            'user' => 'guest',
            'password' => 'guest',
            'queueName' => 'queue-name',
        ],
        // ...
    ],
    // ...
];

La configuration ci-dessus utilise amqp comme stockage des messages et l'extension php-amqp doit être installée.

  1. Écrire une classe de traitement de messages

Pour utiliser yii-queue dans le framework Yii, nous devons implémenter l'interface Job pour définir le processus de traitement des tâches. Par exemple, nous créons une classe de traitement de message nommée ExportTask :

use yiiqueueJob;

class ExportTask implements Job
{
    public $data;

    public function __construct($data)
    {
        $this->data = $data;
    }

    public function execute($queue)
    {
        // 处理导出任务
        // $this->data包含导出所需的参数和数据
    }
}
  1. Envoyer un message

Là où vous devez envoyer un message, appelez la méthode Yii::$app->queue->push pour envoyer le message. à la file d'attente :

Yii::$app->queue->push(new ExportTask(['file' => 'export.xlsx', 'data' => $data]));
  1. Démarrez le processus de consommation

Utilisez la commande console fournie par le framework Yii pour démarrer le processus de consommation :

yii queue/run

Après le démarrage, le processus de consommation s'exécutera en arrière-plan, en écoutant les messages dans le faire la queue et les traiter.

Ce qui précède sont les étapes de base pour implémenter la file d'attente de messages à l'aide de l'extension yii-queue. Il convient de noter que les méthodes de stockage de messages prises en charge par l'extension yii-queue incluent la base de données, redis, beanstalkd, etc. en plus d'amqp.

3. Optimisation de la file d'attente des messages

Dans le processus d'utilisation de la file d'attente des messages, nous devons optimiser les performances, la sécurité et d'autres aspects de la file d'attente des messages. Voici quelques méthodes d'optimisation courantes :

  1. Réutilisation des connexions de file d'attente

Chaque fois que vous utilisez le composant de file d'attente pour traiter une tâche, vous devez vous reconnecter au serveur de file d'attente. La création fréquente de connexions affectera sérieusement les performances. Nous pouvons envisager d'utiliser un pool de connexions ou un mode singleton pour réutiliser les connexions afin d'améliorer les performances.

  1. Confirmation de remise du message

Lors de l'envoi d'un message, vous pouvez utiliser le mécanisme de confirmation de remise du message pour vous assurer que le message est correctement remis au serveur de file d'attente. Ce n'est qu'après que le serveur de file d'attente a renvoyé un message de confirmation de livraison réussie que nous pouvons supprimer le message de la liste des tâches pour garantir qu'il ne sera pas traité de manière répétée.

  1. Mécanisme de nouvelle tentative de message

Lorsqu'une exception ou une autre erreur se produit pendant le traitement de la tâche, nous pouvons utiliser le mécanisme de nouvelle tentative de message pour renvoyer les informations . Par exemple, lors du traitement d'une tâche d'exportation, si la génération du fichier échoue, nous pouvons soumettre à nouveau la tâche à la file d'attente et attendre le prochain traitement.

  1. Considérations de sécurité

La sécurité des files d'attente de messages est très critique, en particulier lors du traitement de données sensibles. Afin d'assurer la sécurité du message, nous pouvons chiffrer et déchiffrer le message en même temps, nous devons faire attention à la configuration de la sécurité de la connexion à la file d'attente pour éviter les attaques malveillantes.

4. Résumé

La file d'attente de messages est un outil efficace pour le traitement asynchrone et a été largement utilisée dans de nombreux systèmes à grande échelle. Dans le framework Yii, nous pouvons utiliser des composants de file d'attente intégrés ou des extensions tierces (telles que yii-queue, Beanstalkd, etc.) pour implémenter les fonctions de file d'attente de messages en améliorant la vitesse de réponse et les capacités de traitement du système, cela améliore l'expérience utilisateur. et la stabilité du système. Lors de l'utilisation de files d'attente de messages, nous devons optimiser les connexions aux files d'attente, la confirmation de livraison des messages, les tentatives de messages et la sécurité pour garantir la fiabilité et la confidentialité des messages.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn