当前位置:首页 > PHP教程 > php高级应用 > 列表

PHP实现git部署的方法教程

发布:smiling 来源: PHP粉丝网  添加日期:2021-08-23 11:42:00 浏览: 评论:0 

虽然一直用git做版本管理,以前也用过git项目的部署,但都没有坚持这种习惯,最近决定再学习下,下面这篇文章主要给大家介绍了关于PHP实现git部署的方法教程,文中通过示例代码介绍的非常详细,需要的朋友可以参考下。

背景

在小站点上,直接用git来部署php代码相当方便,你的远程站点以及本地版本库都有一个版本控制,追踪问题或者回滚是很轻松的事情。

因为在小公司上班,原先的系统还在使用传统的ftp上传部署,部署太麻烦,也不好管控线上的代码。在网上找了下git部署的教程,一路跟着下来碰到了不少坑,现在把整个过程发出来,希望可以帮助到大家,下面话不多说了,来一起看看详细的介绍吧。

账号相关

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

此处一定要注意权限问题,否则密钥登入无法生效,各文件夹对应的权限如下

.ssh文件夹权限 700

id_rsa 600

id_rsa.pub 644

authorized_keys 600

文件权限设置

将git与站点运行nginx或者apache的用户放同一用户组,如www

vim /etc/passwd   找到git账号与www账号,将git账号的组标识变更为与www组标识一致

站点所属者设置为git,用户组设置为 www     //假设nginx与git 都归属于www用户组

目录权限设置775 ,文件权限设置为664

仓库代码

服务器端

cd 站点目录

git init //初始化目录

git配置

git config receive.denyCurrentBranch ignore //设置仓库接受代码提交

设置sudo免密

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

钩子设置

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

hook.php内容

  1. <?php 
  2. /** 
  3.  * git上传执行钩子 
  4.  */ 
  5. //TODO 安全限制 
  6. //TODO 其他钩子行为 
  7. // 清除opcache 
  8. if (version_compare(PHP_VERSION, '5.5.0''>=')) { 
  9.  opcache_reset(); 

增加钩子可执行权限

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

本地代码

git remote add 远程仓库名称 ssh://git@IP地址:/站点目录 //添加远程仓库

git push 远程仓库名称 master

特别注意

用户上传的图片目录一定要做好文件忽视动作,否则有可能在清除未追踪文件时将此部分文件删除,造成灾难性结果。

Tags: git部署

分享到: