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部署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
cat /etc/group
将www用户加入sudoers并可以无密码执行shell
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教程》
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。