宝塔 + WebHook 自动同步Gitee代码(不看后悔系列)

文章介绍了如何通过在宝塔面板安装WebHook,结合Gitee的WebHook配置,实现前后端代码在更新时自动同步到服务器。具体步骤包括在宝塔中配置WebHook脚本,Gitee项目设置WebHook,以及安装和配置Git,确保目录权限和Git安全设置,以实现代码的自动拉取和更新。
摘要由CSDN通过智能技术生成


需求

前后端代码每次在更新时,总要提交代码,想着有没有云效流水线那种模式,能同步代码。故用宝塔 + WebHook + Gitee来完成此操作。


一、WebHook

在宝塔的商店面板下载WebHook,安装后。添加Hook。名称任选,执行脚本在网上找了一个:

PS: 其中gitHttp中的xxx替换为自己gitee上的地址,比如我的主页为 https://gitee.com/acardia_liu,则我把xxx替换为acardia_liu即可。

echo ""
#输出当前时间
date --date='0 days ago' "+%Y-%m-%d %H:%M:%S"
echo "Start"
#判断宝塔WebHook参数是否存在
if [ ! -n "$1" ];
then 
          echo "param参数错误"
          echo "End"
          exit
fi
#git项目路径
gitPath="/www/wwwroot/$1"
#git 网址
gitHttp="https://gitee.com/xxx/$1.git" //xxx替换为自己仓库的链接
echo "Web站点路径:$gitPath"
#判断项目路径是否存在
if [ -d "$gitPath" ]; then
        cd $gitPath
        #判断是否存在git目录
        if [ ! -d ".git" ]; then
                echo "在该目录下克隆 git"
                sudo git clone $gitHttp gittemp
                sudo mv gittemp/.git 
                sudo rm -rf gittemp
        fi
        echo "拉取最新的项目文件"
        sudo git reset --hard origin/master
        sudo git pull        
        echo "设置目录权限"
        sudo chown -R www:www $gitPath
        echo "End"
        exit
else
        echo "该项目路径不存在"
                echo "新建项目目录"
        mkdir $gitPath
        cd $gitPath
        #判断是否存在git目录
        if [ ! -d ".git" ]; then
                echo "在该目录下克隆 git"
                sudo git clone $gitHttp gittemp
                sudo mv gittemp/.git .
                sudo rm -rf gittemp
        fi
        echo "拉取最新的项目文件"
        #sudo git reset --hard origin/master
        sudo git pull
        echo "设置目录权限"
        sudo chown -R www:www $gitPath
        echo "End"
        exit
fi

提交后,点击查看秘钥:
在这里插入图片描述
框起来的部分,在Gitee项目配置WebHook时会要到,param后面的参数为Gitee项目的仓库名,比如我的项目为test-webhooks,则将aaa替换为test-webhooks。
在这里插入图片描述

二、Gitee项目配置WebHook

项目添加WebHook

在这里插入图片描述

点击添加后,需填写如下参数:
在这里插入图片描述
URL填写WebHook中框起来的部分,param后面的参数为Gitee项目的仓库名。密码可以不用填。

三、安装Git

yum -y install git

因为我配置了,无法重现,使用一下别人配置的代码

git config --global user.name "用户名"
git config --global user.email "邮箱"
git config --global credential.helper store

//会生成.gitconfig 的文件,查看
cat ~/.gitconfig  //显示内容

[user]
        name = 输入的用户名
        email = 输入的邮箱
[credential]
        helper = store
// 假设你已经设置好origin并已拉取过代码
// 第一次pull会提示输入用户名密码
[root@iZ25mi9h7ayZ test]# git pull
Username for 'https://gitee.com': xxxx@xxxx.com
Password for 'https://xxxx@xxxx.com@gitee.com':输入正确密码(看不到输入内容)
//生成.git-credentials 隐藏文件
cat ~/.git-credentials
https://Username:Password@gitee.com
// 看到这个说明已经设置成功

vi ~/.git-credentials
//可加多个用户名密码

配置完成后,在wwwroot目录下,克隆自己的仓库(此处的文件目录应与gitee上的目录保持一致)。

git clone https://gitee.com/acardia_liu/test-webhooks.git

测试:在Gitee项目上添加一个文件,看服务器是否进行同步处理。发现并没有同步代码,然后在test-webhooks目录中执行git pull时,提示:git config --global --add safe.directory /www/wwwroot/test-webhooks
在这里插入图片描述
因为git进行了版本升级,添加了新的目录安全限制。会造成在进行git常规操作或者在各类编辑器中无法发现.git文件。
解决:

  1. 忽略单个目录,以后每个目录都要执行以下命令,否则无法同步数据。
git config --global --add safe.directory /www/wwwroot/test-webhooks
  1. 忽略全部文件夹。不适用于有多个用户的电脑,否则存在安全问题
git config --global --add safe.directory "*"

解决完毕后,再执行git pull 看是否执行成功。
在Gitee项目新建文件fff,看是否同步成功。
在这里插入图片描述
增加文件成功!
在这里插入图片描述
再试试删除test文件:
在这里插入图片描述
删除成功!
在这里插入图片描述
webHook日志上也成功显示:
在这里插入图片描述


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值