Maison développement back-end tutoriel php Partagez des exemples de publication correcte du code PHP

Partagez des exemples de publication correcte du code PHP

Mar 12, 2018 pm 02:44 PM
php 分享 实例


Presque tous les programmeurs PHP ont publié du code, éventuellement via la synchronisation FTP ou rsync , il peut également être mis à jour via svn ou git. Un projet actif peut publier du code plusieurs fois par jour, mais la réalité est que peu de gens prêtent attention aux détails. En fait, les pièges sont nombreux et il est possible que vous soyez dans le gouffre sans le savoir.

Un système de publication correctement mis en œuvre devrait au moins prendre en charge la publication atomique. Si chaque version représente un état indépendant, alors pendant la période de publication, toute requête ne peut être exécutée que dans un seul état. C'est ce qu'on appelle la prise en charge de la version atomique ; au contraire, si une requête s'étend sur différents états au cours de la version, elle ne peut pas être appelée version atomique. Donnons un exemple pour illustrer : Supposons qu'une requête nécessite include deux fichiers PHP, à savoir a.php et b.php Lorsque include a.php est terminé, libérez le code, puis include b.php. , s'il n'est pas géré correctement, l'ancienne version de a.php et la nouvelle version de b.php peuvent exister en même temps dans la même requête. En d'autres termes, la version atomique n'est pas implémentée.

Il existe de nombreux bons outils de publication de code dans le monde open source, tels que capistrano dans la communauté ruby. Le processus consiste en gros à publier le code dans un tout nouveau répertoire, puis en douceur. lien vers le répertoire de la version réelle.

├── current -> releases/v1
└── releases
    ├── v1
    │   ├── foo.php
    │   └── bar.php
    └── v2
        ├── foo.php
        └── bar.php
Copier après la connexion

Cependant, étant donné la particularité de PHP lui-même, il sera difficile de réaliser une véritable publication atomique si vous appliquez simplement le processus ci-dessus. Pour clarifier la raison, vous devez également comprendre les concepts des deux en PHPCache :

  • cache d'opcode

  • cache Partagez des exemples de publication correcte du code PHP

Parlons de opcode cache d'abord, en gros apc ou zend opcode, à ce sujet, tout le monde est déjà familier avec sa fonction. Inutile de dire que apc a de nombreux bugs. Par exemple, après avoir activé la configuration apc.enable_cli, il y aura de nombreux problèmes étranges, donc opcode cache devrait être utilisé autant que possible. possible. Eh bien, si vous avez besoin de mettre en cache des données, vous pouvez utiliser apcu. De plus, zend opcache et apc ont des sélections différentes de clés de cache : zend opcode sélectionne le apc du fichier et inode sélectionne le zend opcode du fichier. path

Parlons encore de

Sa fonction est de tamponner l'opération Partagez des exemples de publication correcte du code PHP cacheIO pour obtenir les informations du fichier La plupart du temps, elle est transparente pour nous, de sorte que beaucoup de gens ne le font pas. sachez-le. Pour son existence, il convient de noter que est au niveau du processus, c'est-à-dire que chaque Partagez des exemples de publication correcte du code PHP cache processus a son propre php-fpm indépendant. Partagez des exemples de publication correcte du code PHP cache

En supposant que les données dans

ou opcode cache expirent lors de la publication du code, il y aura alors une situation où une partie du cache est constituée d'anciens fichiers et une partie du cache est une version non atomique de nouveaux fichiers. Afin d'éviter cela. Dans ce cas, nous devons nous assurer que le délai d'expiration du cache est suffisamment long. Il est préférable qu'il n'expire jamais à moins que nous ne l'actualisions manuellement. La configuration correspondante est la suivante : désactivez apc.stat. et opcache.validate_timestamps, et définissez les configurations Partagez des exemples de publication correcte du code PHP_cache_size et Partagez des exemples de publication correcte du code PHP_cache_ttl suffisamment grandes, la surveillance nécessaire est toujours bénéfique. Partagez des exemples de publication correcte du code PHP cache

Les détails techniques pertinents sont très triviaux. Il est recommandé de lire attentivement les informations suivantes :

  • Partagez des exemples de publication correcte du code PHP_cache
    PHP’s OPCache extension review
    Atomic Partagez des exemples de publication correcte du code PHPs at Etsy
    Cache invalidation for scripts in symlinked folders
    Copier après la connexion
Lors de la publication de code en utilisant. liens logiciels, Le premier problème habituellement rencontré est que le nouveau code ne prend pas effet ! Même si la méthode apc_clear_cache ou opcache_reset est appelée, cela ne fonctionnera pas. Le redémarrage

peut naturellement résoudre le problème, mais le redémarrage est trop lourd pour les langages de script ! N'y a-t-il pas d'autre moyen que de redémarrer ? php-fpm

En fait, la raison pour laquelle un tel problème se produit est principalement parce que

obtient les informations sur le fichier via opcode cache Même si le lien logiciel a pointé vers le nouvel emplacement, si l'ancien fichier est toujours stocké dans. Partagez des exemples de publication correcte du code PHP cache Quant aux données, Partagez des exemples de publication correcte du code PHP cache ne peut toujours pas connaître l'existence du nouveau code. Par défaut, la période de validité du cache Partagez des exemples de publication correcte du code PHP_cache_ttl est de deux minutes, ce qui signifie qu'une fois le code publié, cela peut prendre deux minutes pour prendre effet. . Pour que la libération prenne effet le plus rapidement possible, il est nécessaire d'effacer opcode cache dans les unités de processus : Partagez des exemples de publication correcte du code PHP cache

<?php

    $key = &#39;php.pid_&#39; . getmypid();    if (($rev = apc_fetch($key)) != DEPLOY_VERSION) {        if($rev < DEPLOY_VERSION) {
            apc_store($key, DEPLOY_VERSION);
        }

        clearstatcache(true);
    }
Copier après la connexion
Cela fonctionnera essentiellement dans l'environnement

, mais il peut y en avoir. problèmes dans l'environnement apc. Étant donné que opcache.revalidate_path est désactivé par défaut, la valeur des liens symboliques non résolus sera mise en cache. Cela empêchera le lien logiciel de prendre effet même s'il est modifié. Par conséquent, lors de l'utilisation de zend opcode, si vous utilisez Si vous. avoir un lien logiciel, vous devrez peut-être l'activer zend opcode selon la situation. opcache.revalidate_path

详细介绍参考:PHP’s OPCache extension review。

BTW:如果需要手动重置 opcode cache,需要注意的是因为它是基于 SAPI 的概念,所以不能直接在命令行下调用 apc_clear_cache 或者 opcache_reset 方法来重置缓存,当然办法总是有的,那就是使用 CacheTool 在命令行下模拟 fastcgi 请求。

分析到这里,我们不妨反思一下:在 PHP 中原子发布之所以是一个棘手的问题,归根结底是因为软链接和缓存之间的的矛盾。不管是 opcode cache 还是 Partagez des exemples de publication correcte du code PHP cache,都是 PHP 固有的缓存特性,基于客观需要无法绕开,如此说来是否有办法绕开软链接,使其成为马奇诺防线呢?答案是 NGINX 的 $Partagez des exemples de publication correcte du code PHP_root:

    fastcgi_param SCRIPT_FILENAME $Partagez des exemples de publication correcte du code PHP_root$fastcgi_script_name;    fastcgi_param DOCUMENT_ROOT $Partagez des exemples de publication correcte du code PHP_root;
Copier après la connexion

有了 $Partagez des exemples de publication correcte du code PHP_root,即便 DOCUMENT_ROOT 目录中含有软链接,NGINX 也会把软链接指向的真正的路径发给 PHP,也就是说,对 PHP 而言,软链接已经不存在了!不过作为代价,每一次请求,NGINX 都要通过相对昂贵的 IO 操作获取 $Partagez des exemples de publication correcte du code PHP_root 的值,通过 strace 命令我们能监控这一过程,下图从 currentfoo 的过程:

Partagez des exemples de publication correcte du code PHP

在本例中,压测发现使用 $Partagez des exemples de publication correcte du code PHP_root 后,性能下降了大约 5% 左右,不过明眼人一下就能发现,虽然 $Partagez des exemples de publication correcte du code PHP_root 导致了 lstatreadlink 操作,但是 lstat 操作的次数是和目录深度成正比的,也就是说目录越深,执行的 lstat 次数越多,性能下降也就越大。如果能够降低发布目录的深度,那么可以预计还能降低一些性能损耗。

结尾介绍一下 Deployer,它是 PHP 中做得比较好的工具,有很多特色,比如支持并行发布,具体演示如下图,左边是串行,右边是并行,使用「vvv」能得到更详细信息:

Partagez des exemples de publication correcte du code PHP

不过 Deployer 在原子发布上有一点瑕疵,具体见 release/symlink 代码:

<?php// Partagez des exemples de publication correcte du code PHP:releaserun("cd {{Partagez des exemples de publication correcte du code PHP_path}} && if [ -h release ]; then rm release; fi");
run("ln -s $releasePath {{Partagez des exemples de publication correcte du code PHP_path}}/release");// Partagez des exemples de publication correcte du code PHP:symlinkrun("cd {{Partagez des exemples de publication correcte du code PHP_path}} && ln -sfn {{release_path}} current");
run("cd {{Partagez des exemples de publication correcte du code PHP_path}} && rm release");?>
Copier après la connexion

release 的时候,它是先删除再创建,是一个两步的非原子操作,在 symlink 的时候,看上去「ln -sfn」是单步原子操作,实际上也是错误的:

shell> strace ln -sfn releases/foo currentsymlink("releases/foo", "current")      = -1 EEXIST (File exists)unlink("current")                       = 0symlink("releases/foo", "current")      = 0
Copier après la connexion

通过 strace 我们能清晰的看到,虽然表面上使用「ln -sfn」是一步操作,但是内部依然是按照先删除再创建的逻辑执行的,实际上这里应该搭配使用「ln & mv」

shell> ln -sfn releases/foo current.tmpshell> mv -fT current.tmp current
Copier après la connexion

先通过 ln 创建一个临时的软链接,再通过 mv 实现原子操作,此时如果使用 strace 监控,会发现 mv「T」 选项实际上仅仅执行了一个 rename 操作,所以是原子的。

BTW:在使用「ln -sfn」前后,如果使用 stat 查看新旧文件的 inode 的话,可能会发现它们拥有一样的 inode 值,看上去和我们的结论相悖,其实不然,实际上只是复用删除值而已(如果想验证,注意 Linux 会复用,Mac 不会复用)。

据说一千个人的心中就有一千个哈姆雷特,不过我希望所有的 PHP 程序员在发布 PHP 代码的时候都能采用一种方法,那就是本文介绍的方法,正确的方法。

相关推荐:

php代码标志基础讲解

提高PHP代码质量的方法

JS和PHP代码实现用户输入数字后显示最大的值

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
<🎜>: Grow A Garden - Guide de mutation complet
3 Il y a quelques semaines By DDD
Nordhold: Système de fusion, expliqué
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel Java
1675
14
Tutoriel PHP
1278
29
Tutoriel C#
1257
24
PHP vs Python: comprendre les différences PHP vs Python: comprendre les différences Apr 11, 2025 am 12:15 AM

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.

PHP: un langage clé pour le développement Web PHP: un langage clé pour le développement Web Apr 13, 2025 am 12:08 AM

PHP est un langage de script largement utilisé du côté du serveur, particulièrement adapté au développement Web. 1.Php peut intégrer HTML, traiter les demandes et réponses HTTP et prend en charge une variété de bases de données. 2.PHP est utilisé pour générer du contenu Web dynamique, des données de formulaire de traitement, des bases de données d'accès, etc., avec un support communautaire solide et des ressources open source. 3. PHP est une langue interprétée, et le processus d'exécution comprend l'analyse lexicale, l'analyse grammaticale, la compilation et l'exécution. 4.PHP peut être combiné avec MySQL pour les applications avancées telles que les systèmes d'enregistrement des utilisateurs. 5. Lors du débogage de PHP, vous pouvez utiliser des fonctions telles que error_reportting () et var_dump (). 6. Optimiser le code PHP pour utiliser les mécanismes de mise en cache, optimiser les requêtes de base de données et utiliser des fonctions intégrées. 7

PHP et Python: comparaison de deux langages de programmation populaires PHP et Python: comparaison de deux langages de programmation populaires Apr 14, 2025 am 12:13 AM

PHP et Python ont chacun leurs propres avantages et choisissent en fonction des exigences du projet. 1.Php convient au développement Web, en particulier pour le développement rapide et la maintenance des sites Web. 2. Python convient à la science des données, à l'apprentissage automatique et à l'intelligence artificielle, avec syntaxe concise et adaptée aux débutants.

PHP en action: Exemples et applications du monde réel PHP en action: Exemples et applications du monde réel Apr 14, 2025 am 12:19 AM

PHP est largement utilisé dans le commerce électronique, les systèmes de gestion de contenu et le développement d'API. 1) E-commerce: Utilisé pour la fonction de panier et le traitement des paiements. 2) Système de gestion du contenu: utilisé pour la génération de contenu dynamique et la gestion des utilisateurs. 3) Développement des API: Utilisé pour le développement de l'API RESTful et la sécurité de l'API. Grâce à l'optimisation des performances et aux meilleures pratiques, l'efficacité et la maintenabilité des applications PHP sont améliorées.

La pertinence durable de PHP: est-elle toujours vivante? La pertinence durable de PHP: est-elle toujours vivante? Apr 14, 2025 am 12:12 AM

PHP est toujours dynamique et occupe toujours une position importante dans le domaine de la programmation moderne. 1) La simplicité de PHP et le soutien communautaire puissant le rendent largement utilisé dans le développement Web; 2) sa flexibilité et sa stabilité le rendent exceptionnelle dans la gestion des formulaires Web, des opérations de base de données et du traitement de fichiers; 3) PHP évolue et optimise constamment, adapté aux débutants et aux développeurs expérimentés.

PHP et Python: différents paradigmes expliqués PHP et Python: différents paradigmes expliqués Apr 18, 2025 am 12:26 AM

PHP est principalement la programmation procédurale, mais prend également en charge la programmation orientée objet (POO); Python prend en charge une variété de paradigmes, y compris la POO, la programmation fonctionnelle et procédurale. PHP convient au développement Web, et Python convient à une variété d'applications telles que l'analyse des données et l'apprentissage automatique.

PHP et Python: exemples de code et comparaison PHP et Python: exemples de code et comparaison Apr 15, 2025 am 12:07 AM

PHP et Python ont leurs propres avantages et inconvénients, et le choix dépend des besoins du projet et des préférences personnelles. 1.Php convient au développement rapide et à la maintenance des applications Web à grande échelle. 2. Python domine le domaine de la science des données et de l'apprentissage automatique.

PHP vs autres langues: une comparaison PHP vs autres langues: une comparaison Apr 13, 2025 am 12:19 AM

PHP convient au développement Web, en particulier dans le développement rapide et le traitement du contenu dynamique, mais n'est pas bon dans les applications de la science des données et de l'entreprise. Par rapport à Python, PHP présente plus d'avantages dans le développement Web, mais n'est pas aussi bon que Python dans le domaine de la science des données; Par rapport à Java, PHP fonctionne moins bien dans les applications au niveau de l'entreprise, mais est plus flexible dans le développement Web; Par rapport à JavaScript, PHP est plus concis dans le développement back-end, mais n'est pas aussi bon que JavaScript dans le développement frontal.

See all articles