Maison >développement back-end >tutoriel php >Exemples pour expliquer l'implémentation PHP du déploiement git

Exemples pour expliquer l'implémentation PHP du déploiement git

小云云
小云云original
2017-12-20 10:20:401733parcourir

Bien que j'ai toujours utilisé git pour la gestion des versions et que j'ai déjà utilisé le déploiement de projets git, je n'ai jamais adhéré à cette habitude. Récemment, j'ai décidé d'en savoir plus. L'article suivant vous présente principalement la méthode de déploiement de git en PHP. Le tutoriel est très détaillé grâce à un exemple de code. Les amis qui en ont besoin peuvent s'y référer. J'espère qu'il pourra aider tout le monde.

Contexte

Sur un petit site, il est très pratique d'utiliser directement git pour déployer du code PHP. Votre site distant et votre référentiel local disposent d'un contrôle de version pour suivre les problèmes ou effectuer une restauration. très facile.

Parce que je travaille dans une petite entreprise, le système d'origine utilise toujours le téléchargement et le déploiement FTP traditionnels. Le déploiement est trop fastidieux et il est difficile de contrôler le code en ligne. J'ai recherché un didacticiel de déploiement de git sur Internet et j'ai rencontré de nombreux pièges en cours de route. Maintenant, je publie l'intégralité du processus, en espérant que cela puisse aider tout le monde. Je ne dirai pas grand-chose ci-dessous, jetons un coup d'œil au détail. introduction.

Lié au compte

useradd -m git //新增git账号
ssh-keygen //密钥生成,如果已经有了可略过
su git //切换至git账号
cd ~ //切换到git账号根目录
mkdir .ssh //创建.ssh目录
cat /密钥存放目录/xxx.pub >> ~/.ssh/authorized_keys //设置公钥

Assurez-vous de faire attention aux problèmes d'autorisation ici, sinon la connexion par clé ne sera pas effective. Les autorisations correspondantes de chaque dossier sont les suivantes

.ssh文件夹权限 700
id_rsa 600
id_rsa.pub 644
authorized_keys 600
Paramètres d'autorisation de fichier


Placez git et l'utilisateur exécutant nginx ou apache sur le site dans le même groupe d'utilisateurs, tel que www


vim /etc/passwd Recherchez le compte git et le compte www , modifiez l'ID de groupe du compte git pour qu'il soit cohérent avec l'ID du groupe www


Définissez le propriétaire du site sur git et définissez le groupe d'utilisateurs sur www //Supposons que nginx et git appartiennent tous deux au groupe d'utilisateurs www


Les autorisations de répertoire sont définies sur 775 et les autorisations de fichiers sont définies sur 664


Code d'entrepôt


Côté serveur

cd 站点目录
git init //初始化目录
Configuration de Git


git config receive.denyCurrentBranch ignore //设置仓库接受代码提交
Définir sudo sans mot de passe


vim /etc/sudoers
# Defaults secure_path 中若没有你要的命令,要注意添加
# php的命令默认需要在 secure_path最后面添加 :/usr/local/php/bin"
在 root ALL=(ALL) ALL 下面一行添加
git ALL=(ALL) NOPASSWD:ALL 
# 保存退出 ,这样针对laravel 要重启队列命令就可以使用了.
# sudo php artisan queue:restart
Paramètres du hook


cd .git/hooks //切换至站点钩子目录
touch post-receive //创建接收提交时钩子
// 钩子文件内容如下:
#!/bin/sh
# 设置账号创建文件的默认权限
umask 002 
unset GIT_DIR
cd ..
git checkout -f
# 执行PHP钩子逻辑
/usr/bin/curl http(s)://域名/钩子文字位置/hook.php
# 如果有使用laravel队列则需要重启队列进程,让新代码生效
# sudo php artisan queue:restart
exit 0
contenu hook.php


<?php
/**
 * git上传执行钩子
 */
//TODO 安全限制
//TODO 其他钩子行为
// 清除opcache
if (version_compare(PHP_VERSION, &#39;5.5.0&#39;, &#39;>=')) {
 opcache_reset();
}
Ajouter des autorisations exécutables du hook


chmod a+x .git/hooks/post-receive
Code local

git remote add 远程仓库名称 ssh://git@IP地址:/站点目录 //添加远程仓库
git push 远程仓库名称 master
Portez une attention particulière aux


images téléchargées par les utilisateurs. Le répertoire doit être ignoré, sinon certains fichiers peuvent être supprimés lorsque les fichiers non suivis sont effacés, provoquant des résultats catastrophiques

Recommandations associées :


php Utilisation de l'environnement de déploiement git

Quelques cas d'utilisation de Git

Explication détaillée des types de données javascript et du code d'utilisation de git

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