git自动化部署php脚本怎么实现
git自动化部署php脚本的实现方法:1、安装git;2、克隆仓库代码;3、更改linux权限,修改配置;4、将www用户加入sudoers;5、生成密钥;6、填写webhook域名,上传php脚本即可。
本文操作环境:linux5.9.8系统、Git 2.30.0版、DELL G3电脑
git自动化部署php脚本怎么实现?
git+php部署webhook自动化脚本 实现代码同步
本文将介绍git+php部署webhook自动化脚本 实现代码同步
git配合webhook自动化部署不算是个高深的技术,但是第一次自己部署中走了很多弯路,主要自己在linux方面算是个菜鸡,本文记录一下容易出错的问题点,遇到的坑
准备
lnmp环境下部署可访问的web域名,服务端php脚本,仓库码云gitee
自动化流程,本地push->gitee仓库webhook->linux服务器php脚本pull
首先在gitee码云上创建仓库
本地使用ssh协议与仓库进行通讯,我的本地是windows,这里就不介绍怎么生成ssh公钥,下面linux下将会介绍
1.安装git
yum install git
2.克隆仓库代码《注意一定要使用ssh协议,后面都是基于ssh》
git initgit clone git@gitee.com:zhuyanbin/HiAdmin.git
3.更改linux权限,修改配置
因为我们webhook去通知服务端属于外部访问,所以这里的管理员用户默认是www用户,所以要给定www足够的权限才行
vim /etc/passwd 添加下面的一行 www:x:1001:1001::/home/www:/bin/bash
1001是用户组的id,使用以下命令可查看用户www的id
cat /etc/group
将www用户加入sudoers并可以无密码执行shell
#(1)为当前用户添加写入sudoers的权限
chmod u+w /etc/sudoers
#(2)编辑sudoers
vim /etc/sudoers
#(3)搜索Allow root to run any commands anywhere,在root用户对应行下写入如下内容:
www ALL=(ALL) NOPASSWD:/usr/bin/git
#(4)收回对sudoers的写入权限
chmod u-w /etc/sudoers
修改php-fpm.conf配置设置访问者,我这里是www,也就是php已经默认的配置
4.最后生成密钥(此步必须是www用户生成密钥,ps:在这个地方卡了两天,一直使用root管理员账号生成,百度了好几天,尝试各种方法,后来切换到www用户生成密钥之后一切ok)
生成公钥密钥
mkdir -p /home/www/.ssh
chown -R www.www /home/www/.ssh
ssh-keygen -t rsa
查看公钥密钥
cat /home/www/.ssh/id_rsa.pub
将生成好的公钥复制到gitee码云仓库公钥填写处
https://gitee.com/profile/sshkeys
补充:gitee填写公钥的地方有两个,一个是仓库的公钥,如果填写到仓库的公钥,服务端git权限将只有pull的权限,另一个是账号的公钥,如果填写到个人账号的公钥,将会有pull,push等权限,我这里直接使用的个人账号公钥
5.最后填写webhook域名,上php脚本
填写webhook通知地址域名(密码设置的空,后面php中没有密码验证,如果考虑安全,请在后面设置密码)
上php脚本处理程序hook.php(执行linux命令)
chdir("/home/wwwroot/default/HiAdmin"); exec("git pull origin master 2>&1", $out); foreach($out as $v) { echo iconv( 'GB2312','UTF-8', $v)."<br>"; }
到此,配置完以上服务端代码可自动同步,完成自动化部署
出现问题
1.php脚本不执行
原因php.ini中php很多函数是默认没打开包括执行linux脚本函数exec(),shell_exec()等等
找到php.ini,找到disable_functions那一行删除相应的函数即可,或者整行注释掉
2.无法执行git pull命令
问题一
Host key verification failed.
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
归根结底还是因为linux权限的问题,我遇到的是出现一下问题
到这里的原因是因为root生成git公钥密钥,而切换到www后生成公钥密钥后就成功了(上述第四小步生成公钥,一定使用www生成公钥密钥)
问题二
error: insufficient permission for adding an object to repository database .git/objects
fatal: failed to write object
fatal: unpack-objects failed
这个还是没有权限执行git命令,只需要执行以下
第一步:cd .git/objects 定位到git下的objects文件下 第二步: ls -al 查看git库的所有者(git用户 git组) 第三步: chown -R yourname:yourgrounp * 或者sudo chmod 777 -R .git/objects 提交
最后解决完以上问题,大功告成,上一张成功的截图
自己的后端语言是php,这里可以用多种方式去实现执行linux脚本,nodejs,python等等
推荐学习:《PHP视频教程》