当前位置:首页 > 技术分享 > 正文内容

实现服务器的代码与Gitee的代码同步更新:通过宝塔的WebHook、Git、Gitee的WebHooks

admin2年前 (2022-05-04)技术分享3805

(超详细避坑)实现服务器的代码与Gitee的代码同步更新:通过宝塔的WebHook、Git、Gitee的WebHooks

前言

一、效果展示

二、实现步骤

2.1 使用宝塔git生成公钥

2.2 创建Gitee仓库,添加公钥

2.3 宝塔安装WebHook并配置

2.4 配置Gitee的WebHooks

2.5 将Gitee仓库clone到服务器的本地目录中

总结

前言

提示:内容中的服务器环境为centos7,配置了宝塔的LNMP。

本篇文章最好需要已掌握Git,Gitee操作,宝塔操作的相关知识。


一、效果展示

①下面是提交的文件(时间:2020-11-28 21:16:00 左右)

②在Gitee的仓库上可以看到4分钟前提交的文件“a_test.txt”

③在宝塔的仓库上可以直接看到文件已经传到服务器


二、实现步骤

2.1 使用宝塔git生成公钥

首先去宝塔终端查看是否有装git(一般默认是安装了的)

git --version


如果没有就自行安装一下,在终端输入安装指令

yum install git

生成公钥,输入下面命令后回车三下

ssh-keygen -t rsa

查看公钥,按顺序输入下面代码,最后一个是获取密钥,cat 后面是公钥文件名

cd ~/.ssh
ls
cat id_rsa.pub

复制绿色框部分全部内容,这就是生成的SSH密钥

2.2 创建Gitee仓库,添加公钥

仓库就简单的默认仓库就好,要记好仓库名。

进入仓库管理的添加公钥功能,将上面复制的密钥copy进底下后,标题会自动生成,直接点击添加即可。


2.3 宝塔安装WebHook并配置

在宝塔界面的软件商店里搜索webhook并安装,安装成功后添加脚本


脚本代码:

#!/bin/bash
 
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


看网上说有些人代码放进去了会被过滤,大家添加好后点击编辑再确认一下,如果被过滤就再把代码复制进去然后保存


确保脚本没问题后,重启我们的宝塔,在终端输入下面代码

/etc/init.d/bt restart

有些人会重启失败,卡在关闭或启动页面,导致无法进入宝塔面板,这里推荐的解决方案是:进入Xshell6,连接服务器,连接成功后再输入上面代码

重启后,进入软件商店,查看我们宝塔WebHook生成的密钥,复制绿色框里的内容

2.4 配置Gitee的WebHooks

进入仓库的WebHooks功能页面

这部分看图片内容弄,需要注意的是URL最后的aaa必须最后一个是仓库名,前面可以根据自己想放的位置添加父级目录

2.5 将Gitee仓库clone到服务器的本地目录中

①复制仓库的下载链接


②在宝塔面板的终端设置git

git config --global user.name "用户名"
git config --global user.email "邮箱"
git config --global credential.helper store //会生成.gitconfig 的文件
cat .gitconfig   //如果报错: No such file or directory,就用下一行的代码
cat ~/.gitconfig  //显示内容

正确显示的页面


进入到 www/wwwroot 目录下(通常文件都会放这里,也可以自己选择目录),然后clone


cd /www/wwwroot/

git clone https://gitee.com/XXX/XXX.git  //clone后面是下载链接

第一次clone需要输入用户名和密码,注意:输入密码的时候是看不见内容的,不是终端页面出问题了(我自己卡了好久发现,人都傻了)


Username for 'https://gitee.com': your@email.com
Password for 'https://xxxx@xxxx.com@gitee.com': yourPassword(看不到输入内容)


当clone成功后,就已经是配置好了,可以在自己电脑上传文件到配置的仓库,检查下宝塔界面的文件里仓库目录下有没有自动更新刚上传的文件


也可以用下面的方法测试

在仓库的WebHooks功能页面点击测试,进入查看更多查看结果,中间是200则代表测试成功

宝塔里查看WebHook日志

如何在非空目录下 git clone 项目

在非空目录下 git clone 项目时会提示错误信息:

fatal: destination path '.' already exists and is not an empty directory.

解决办法:

进入非空目录,假设是 /dir/jk1

git clone --no-checkout https://git.oschina.net/jankerli/test.git tmp
mv tmp/.git .   
rmdir tmp
git reset --hard HEAD

Git冲突:Please commit your changes or stash them before you merge

这个问题原因是其他人修改了某个文件并提交到版本库中去了,而你本地也修改了同一个,这时候你进行拉取就会出现冲突了,解决方法,原则是不要去更改别人已经提交的代码,如果确实要更改(不建议也不需要),请先跟当事人沟通


方法一:放弃本地修改

(此方法本地修改的代码会被丢弃,不可找回)

git reset --hard

git pull

git reset --hard:撤销工作区中所有未提交的修改内容,将暂存区与工作区都回到上一次版本,并删除之前的所有信息提交

方法二:同样是放弃本地修改

使用TortoiseGit(小乌龟),打开冲突文件所在目录,如下:

方法三:使用git stash

git stash

git pull

git stash pop

git stash:保存当前工作进度,能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录。也可以用git stash save,作用等同于git stash,区别是可以加一些注释

git pull:这个应该不用说了吧!(把服务器仓库的更新拉到本地仓库中)

git stash pop:可以把你刚才stash到本地栈中的代码pop到本地(也可以用git stash apply,区别:使用apply恢复,stash列表中的信息是会继续保留的,而使用pop恢复,会将stash列表中的信息进行删除。)


git stash list:存储到本地栈顶以后,你可以使用git stash list 查看你本地存储的stash日志

git stash clear: 清空Git栈,原来stash的节点都会被清除


总结

把服务器和Gitee仓库绑定同步更新后,平时的代码上传更方便,更新及时,服务器也会备份上一个版本,非常的方便好用。

https://blog.csdn.net/shallow77/article/details/110292878

扫描二维码推送至手机访问。

版权声明:本文由小刚刚技术博客发布,如需转载请注明出处。

本文链接:http://blog.bitefu.net/post/248.html

标签: git
分享给朋友:

相关文章

360浏览器如何禁止切换到兼容模式[本地终极办法]

360浏览器如何禁止切换到兼容模式[本地终极办法]

浏览器内核控制标签meta说明背景介绍由于众所周知的原因,国内的主流浏览器都是双核浏览器:基于Webkit的内核用于常用网站的高速浏览,基于IE的内核主要用于部分网银、政府、办公系统等网站的正常使用。以360浏览器为例,我们优先通过Webk...

php高效检测远程图片是否存在

php高效检测远程图片是否存在function img_exits($url){     $ch = curl_init();    &...

[Windows] Adobe Flash Player 34.0.0.92及可用版修改方法

[Windows] Adobe Flash Player 34.0.0.92及可用版修改方法

随着 2021 年的到来,Adobe Flash Player 也迎来了告别,Adobe 在 2020 年 12 月 31 日后将不再支持 Flash Player。其实早在 2017 年,Adobe 公司就已宣布,计划在 2020 年底逐...

Nginx服务崩溃自动重启脚本(监控进程服务并自动重启进程服务)脚本

有一台服务器运行着Ngin最近突然有一次崩溃,导致使用方当天无法访问网页端,然后我不得不登录服务器,检查各项服务,发现nginx崩溃了,于是重启Nginx,问题解决。后来为了防止Nginx再发生这种情况给运维带来的运维成本,于是写了一个脚本...

在CentOS 5.x 6.x里使用yum源 换阿里云国内源换vault.centos.org源

阿里云CentOS 5 的系统,无法用yum来安装应用软件。  原因:CentOS 5 在2017-03-31日已经结束支持,不再提供维护更新,所以包括阿里云镜像站的文件可能都是过时或已经有部分文件缺失。 &n...

apicloud影视APP源码 无需后台

apicloud影视APP源码 无需后台

介绍集合vip影视接口到一个android app中 方便观看各平台影视资源及直播开源地址:https://gitee.com/web/vip_yingshi软件架构使用apicloud搭建影视APP源码,无后台,调用接口同步api解析网址...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。