背景
在小站点上,直接用git来部署PHP代码相当方便,你的远程站点以及本地版本库都有一个版本控制,追踪问题或者回滚是很轻松的事情。
因为在小公司上班,原先的系统还在使用传统的ftp上传部署,部署太麻烦,也不好管控线上的代码。在网上找了下git部署的教程,一路跟着下来碰到了不少坑,现在把整个过程发出来,希望可以帮助到大家,下面话不多说了,来一起看看详细的介绍吧。
账号相关
> ~/.ssh/authorized_keys //设置公钥
此处一定要注意权限问题,否则密钥登入无法生效,各文件夹对应的权限如下
文件夹权限 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
仓库代码
服务器端
站点目录
git init //初始化目录
git配置
代码提交
设置sudo免密
添加
# PHP的命令默认需要在 secure_path最后面添加 :/usr/local/PHP/bin"
在 root ALL=(ALL) ALL 下面一行添加
git ALL=(ALL) NOPASSWD:ALL
# 保存退出,这样针对laravel 要重启队列命令就可以使用了.
# sudo PHP artisan queue:restart
钩子设置
站点钩子目录
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
hook.PHP内容
PHP;">
=')) {
opcache_reset();
}
增加钩子可执行权限
本地代码
特别注意
用户上传的图片目录一定要做好文件忽视动作,否则有可能在清除未追踪文件时将此部分文件删除,造成灾难性结果
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持。