Cet article présente principalement les instructions sur les timers PHP, qui ont une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer
Il existe deux timers courants : une exécution planifiée périodique, par exemple, le rapport sera émis chaque jour à trois heures du matin ; l'autre sera exécuté après une heure spécifiée (une fois), par exemple, les récompenses de connexion quotidiennes seront émises cinq minutes après la connexion des membres au système. Les deux situations correspondent aux commandes cron
et at
du shell, qui sont similaires aux fonctions JavaScript
et setInterval
dans setTimeout
(à proprement parler, setInterval
est exécuté périodiquement, et l'exécution à le moment spécifié doit être géré par lui-même).
Les programmeurs PHP qui font du développement web devraient être familiers avec les deux fonctions de minuterie en JavaScript. Revenant au niveau PHP, ils sont un peu abasourdis : PHP a sleep
, mais il n'y en a pas (intégré). fonction minuterie disponible. sleep
La fonction peut à peine le faire, mais elle entraînera le blocage du processus et ne pourra pas faire autre chose (ou ne plus répondre) pendant cette période. Pourquoi PHP ne fournit-il pas la fonction timer ?
Personnellement, je crois que la raison essentielle pour laquelle PHP ne peut pas utiliser de minuteries dans le développement Web est le manque de contrôlable environnement d'exécution de la mémoire résidente . Deux points clés : premièrement, la mémoire résidente et deuxièmement, contrôlable. En mode CGI, le processus se termine directement après l'exécution du script et ne peut pas exécuter la tâche à une heure spécifiée ; en mode PHP-FPM, le processus réside (principalement) en mémoire mais est incontrôlable.
Incontrôlable signifie que le processus exécutant PHP n'est pas affecté par le code PHP, et que le point d'entrée et le timing de sortie du processus sont contrôlés par des programmes supplémentaires. Par exemple, en mode FPM, les fonctions exit
et die
du script PHP interrompent uniquement l'exécution du script et n'auront pas d'impact particulier sur le processus d'exécution du script (sauf fuites de mémoire). Le script écrit par les développeurs PHP est le corps d'exécution du processus. Après exécution, il est déchargé du contexte d'exécution du processus. Dans ce cas, le timing d'exécution du script PHP est toujours déterminé par l'extérieur. S'il n'y a pas de requête externe, le code PHP restera tranquillement sur le disque dur, ne faisant rien, et ce sera une tâche planifiée.
Étant donné que PHP est principalement orienté vers le développement web, le mode d'exécution de PHP est stable et fiable, et l'efficacité du développement est rapide. Par exemple, omettre l’étape de libération des ressources peut éviter beaucoup de charge de travail et d’embûches lors du développement. Pensez à certains codes de bibliothèques tierces qui modifient les fuseaux horaires, les encodages de caractères, etc. et ne les restaurent pas dans un environnement d'exécution de mémoire résidente, cela entraînera presque certainement des problèmes avec les requêtes ultérieures. Mais en mode FPM, cet écueil est involontairement atténué, ce qui permet d'économiser beaucoup de temps de débogage et de contribuer grandement à la capacité des programmeurs à garder leurs distances.
Maintenant que le problème est compris, comment utiliser un timer pour effectuer des tâches planifiées en PHP ?
Dans un environnement web, les scripts PHP ont un timeout par défaut. Supprimez le paramètre de délai d'attente et vous pourrez continuer à exécuter le programme en arrière-plan (si le processus ne se termine pas). Par exemple, le code suivant continue de s'exécuter en arrière-plan après avoir répondu à la requête et affiche l'heure dans un fichier toutes les cinq secondes :
# test.php set_time_limit(0); # 取消超时设置,让脚本可一直运行 echo 'This is a background run forever script. Now you can leave me alone.'; fastcgi_finish_request(); # 结束当前请求 do{ file_put_contents("/tmp/out.dat", "test script, now:" . date("Y-m-d H:i:s") . "\n", FILE_APPEND); sleep(5); }while(true);
Après avoir demandé le fichier http://localhost:8080/test.php
, surveillez le /tmp/out.dat
fichier, et vous constaterez que le contenu est constamment affiché, que le client se déconnecte, ferme le navigateur ou redémarre l'ordinateur (le serveur ne peut pas être redémarré). Cela montre que le programme a été exécuté et que la fonction de minuterie souhaitée a été atteinte. Si vous remplacez sleep
par usleep
ou time_nanosleep
, vous pouvez également implémenter des minuteries en microsecondes et nanosecondes. Ne serait-ce pas sympa ?
En pratique, vous devriez essayer d'éviter d'implémenter des minuteries de cette manière, non seulement parce que c'est inefficace, mais aussi légèrement dangereux. L'une des raisons est que chaque demande occupera un processus, et 100 000 demandes nécessitent 100 000 processus, ce qui entraînera essentiellement un crash du système ou l'absence de réponse des demandes ultérieures, si la session est ouverte mais que vous oubliez d'appeler , cela entraînera également le blocage des demandes ultérieures d'un utilisateur (la session est dans un état verrouillé lorsqu'elle est active, et l'échec de la fermeture de la session empêchera les processus suivants d'ouvrir la session). session_write_close
Pour être honnête, le mode CLI permet à PHP d'étendre beaucoup son espace. En mode CLI, le point d'entrée du programme est le script, le code peut résider en mémoire et le processus est entièrement contrôlé par le code PHP. Sous cette forme, il existe de nombreuses façons de mettre en œuvre la minuterie. Cet article répertorie plusieurs méthodes pour inspirer les autres :
Utilisez swoole
, workerman
et d'autres frameworks avec des minuteries intégrées (de haute précision)
, pcntl
les extensions ne sont disponibles qu'en mode CLI) ; des signaux tels que tick ou alarme pthreads
et
; une boucle ou implémentez vous-même la boucle d'événement.libevent
Si vous voulez vous embêter, utilisez vous-même le plan 2-5. Si vous ne voulez pas vous embêter, des cadres tels que libev
et
sleep
Distinguez la relation entre les requêtes HTTP et les tâches, et il est simple de mettre en œuvre des tâches planifiées. Quant à savoir s'il faut utiliser PHP pour l'implémenter, c'est une autre affaire. Bien entendu, en tant que langage privilégié pour le développement Web, PHP peut facilement implémenter des tâches planifiées.
Recommandations associées : swoole
workerman
php utilise simplement la fonction shmop pour créer de la mémoire partagée Réduire charge du serveur
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!