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视频教程》

hmoban主题是根据ripro二开的主题,极致后台体验,无插件,集成会员系统
自学咖网 » git自动化部署php脚本怎么实现