Maison  >  Article  >  cadre php  >  Swoole prend-il en charge le multithreading ?

Swoole prend-il en charge le multithreading ?

青灯夜游
青灯夜游original
2019-12-25 18:18:244203parcourir

Swoole prend-il en charge le multithreading ?

Thread du réacteur

Le processus principal de SwooleServer est un programme multithread. Il existe un groupe de threads très important appelés threads Reactor. C'est le thread qui gère réellement les connexions TCP et envoie et reçoit des données.

Après avoir accepté une nouvelle connexion, le thread principal de Swoole attribuera la connexion à un thread Reactor fixe, et ce thread sera responsable de la surveillance du socket. Lisez les données lorsque le socket est lisible, effectuez une analyse de protocole et envoyez la demande au processus Worker. Envoie des données au client TCP lorsque le socket est accessible en écriture.

L'allocation est calculée comme fd % serv->reactor_num

Le langage PHP ne prenant pas en charge le multi-threading, Swoole utilise le mode multi-processus. Il existe une isolation de la mémoire de processus en mode multi-processus. Lorsque les variables globales et les variables super-globales sont modifiées dans le processus de travail, elles ne seront pas valides dans d'autres processus.

Lorsque worker_num=1 est défini, il n'y a pas d'isolation de processus et vous pouvez utiliser des variables globales pour enregistrer les données

Isolation de processus

$fds = array();
$server->on('connect', function ($server, $fd){
    echo "connection open: {$fd}\n";
    global $fds;
    $fds[] = $fd;
    var_dump($fds);
});

Bien que $fds soit une variable globale, elle n'est valide que dans le processus en cours. La couche inférieure du serveur Swoole créera plusieurs processus Worker. La valeur imprimée dans var_dump ($ fds) ne contient que des fds connectés partiels.

La solution correspondante est d'utiliser des services de stockage externes :

Base de données, telle que : MySQL, MongoDB
Serveur de cache, tel que : Redis, Memcache
Les fichiers disque doivent être verrouillés lorsque plusieurs processus lisent et écrivent simultanément

Les opérations ordinaires de base de données et de fichiers disque ont beaucoup de temps d'attente d'E/S. Par conséquent, il est recommandé d'utiliser :

Base de données en mémoire Redis, vitesses de lecture et d'écriture très rapides
/dev/shm système de fichiers en mémoire, toutes les opérations de lecture et d'écriture sont terminés en mémoire, pas de consommation d'E/S, performances extrêmement élevées
En plus d'utiliser le stockage, vous pouvez également utiliser la mémoire partagée pour enregistrer des données

Apprentissage recommandé : tutoriel vidéo swoole

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