Introduction
Dans notre processus de développement, nous utiliserons inévitablement le contrôle de version. Bien sûr, cela vous donne également une compréhension de Git et SVN. Les deux sont d’excellents outils de contrôle de version. Personnellement, je suis plus habitué à utiliser Git. Bien sûr, cela peut être lié à des habitudes personnelles. Je ne sais pas comment vous avez utilisé git pour le développement en premier lieu. Quoi qu'il en soit, j'ai personnellement soumis le code au référentiel github, puis je me suis connecté au serveur en utilisant SSH, puis j'ai cloné ou mis à jour la version. Cela semble très gênant, et bien sûr, c'est aussi très gênant en pratique. Alors, existe-t-il un moyen de « résoudre ce problème une fois pour toutes » ? Veuillez lire ci-dessous !
Facile à utiliser
Git hook
Qu'est-ce qu'un git hook ? L'explication officielle est un peu longue. Pour faire simple, il s'agit d'un script qui se déclenche dans un environnement spécifique. Cette explication n'est peut-être pas exacte, mais je pense qu'elle est plus facile à comprendre. Si vous souhaitez en savoir plus, vous pouvez vous rendre sur le site officiel de Git pour la consulter. Ci-dessous, nous utiliserons des hooks pour implémenter un déploiement automatisé.
Étape 1 : Créer un utilisateur git
Connectez-vous à notre serveur, sur lequel vous avez déjà installé git par défaut. Créez un utilisateur git :
# 创建一个名叫jouzeyu的用户 adduser jouzeyu
Étape 2 : Ajoutez des autorisations à l'utilisateur git
#在根目录下的 home 文件夹下创建一个git文件夹 mkdir /home/git #切换到创建好的git文件夹 cd /home/git #创建 .ssh文件夹,里面主要用来放公钥 mkdir .ssh #切换到.ssh文件夹并创建authorized_keys文件 cd .ssh touch authorized_keys
Étape 3 : Configurez git et obtenez la clé publique
#在本地配置用户名和邮箱,我的用户名默认为jouzeyu git config --global user.name "jouzeyu" git config --global user.email "your email"
Remarque : Si vous utilisez l'option --global, tous vos futurs projets utiliseront les informations utilisateur configurées ici. Si vous souhaitez utiliser un autre nom ou une autre adresse e-mail dans un projet spécifique, exécutez simplement sous le projet :
git config user.name "xxx" git config user.email "xxx"
OK, nous obtenons ensuite la clé publique, veuillez d'abord vérifier le fichier .ssh sous votre utilisateur. Si le dossier contient des clés publiques et privées auparavant, nous devons rechercher une paire de fichiers nommés id_dsa ou id_rsa, dont l'un a une extension .pub. Le fichier .pub est votre clé publique et l'autre est votre clé privée. Sinon, exécutez ssh-keygen.
Utilisez la commande cat ~/.ssh/id_rsa.pub pour obtenir la clé publique, copiez-la, utilisez la commande vi ou vim pour la coller dans le fichier authorised_keys que nous avons créé précédemment et utilisez : wq pour enregistrer il.
Étape 4 : Initialiser le référentiel
Créez un dossier pour stocker le référentiel git :
mkdir /www/wwwroot/git cd /www/wwwroot/git
Initialisez le référentiel :
#初始化一个裸仓库(强烈建议) git init --bare website.git #配置仓库的权限,让我们之前创建好的git用户jouzeyu能读写 chown -R git:git website.git
Il faut noter ici que si l'autorisation n'est pas donnée, le git pull suivant signalera une erreur car il n'y a pas d'autorisation d'écriture. La différence entre un entrepôt nu et un entrepôt ordinaire est simplement que l'entrepôt nu ne peut pas voir les fichiers du projet. L'entrepôt ordinaire est le même que le répertoire de votre projet, à l'exception d'un dossier .git supplémentaire.
Étape 5 : Générer l'entrepôt du projet
Cela se fait également sur le serveur, et veuillez noter que /www/wwwroot/ est le répertoire racine de mon environnement.
#创建我服务器上的项目目录test mkdir /www/wwwroot/test #克隆仓库 git clone /www/wwwroot/git/website.git #设置权限 chown -R git website
Remarque : assurez-vous de faire attention à mon chemin. Le référentiel git est /www/wwwroot/git et le référentiel du projet est /www/wwwroot/test.
Étape 6 : Cloner en local
# 通过ip地址从配置好的线上仓库拉取下来 git clone git@47.97.121.XXX:/www/wwwroot/git/website.git # 如果有配置域名的话也可以通过域名拉取 git clone git@www.XXX.XXX:/www/wwwroot/git/website.git
En raison de la clé publique, aucun mot de passe n'est requis ici. En cas de succès, un site Web apparaîtra sur le dossier de votre ordinateur. si une erreur est signalée, veuillez vérifier avant de procéder aux opérations suivantes.
Étape 7 : Test du téléchargement (git pull)
# 打开刚才克隆下来的本地仓库 cd website # 创建README.md文件 touch README.md git add . git commit -m"创建README.md文件" git push
Comme prévu, il a été téléchargé normalement. Si une erreur est signalée, veuillez vérifier les autorisations comme mentionné. ci-dessus, si cela ne fonctionne pas encore, vous pouvez laisser un commentaire ci-dessous.
Étape 8 : Ajouter des crochets
Enfin, il est temps d'entrer dans le vif du sujet. L'écriture est relativement détaillée, donc c'est un peu plus gênant. De retour sur notre serveur en ligne, ce qui suit se fait en ligne :
#切换到这个目录 cd /www/wwwroot/git/website.git/hooks # 生成post-receive文件 touch post-receive # 使用vim编辑 vim post-receive
Coller dans le fichier de post-réception :
#!/bin/sh # 打印输出 echo '======上传代码到服务器======' # 打开线上项目文件夹 cd /www/wwwroot/test/website # 这个很重要,如果不取消的话将不能在cd的路径上进行git操作 unset GIT_DIR git pull origin master # 自动编译vue项目,如有需要请去掉前面的#号 # npm run build # 自动更新composer(我暂时没试过) # composer update echo $(date) >> hook.log echo '======代码更新完成======'
Après avoir enregistré, ajoutez les autorisations d'exécution au fichier de post-réception :
chmod +x post-receive
La dernière étape
Modifiez certains contenus localement, puis soumettez et poussez git pull Vous pouvez voir que nous avons implémenté le déploiement automatisé.
Utilisez Git pour réaliser un déploiement automatisé de projets Laravel
Pour plus d'articles techniques liés à Laravel, veuillez visiter le Tutoriel de démarrage de Laravel Framework étude de colonne !
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!