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

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

admin7个月前 (05-04)技术分享1994

(超详细避坑)实现服务器的代码与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

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

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

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

标签: git
分享给朋友:

相关文章

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

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

关于微信第三方平台(全网发布检测)检测流程以及踩到的坑

关于微信第三方平台(全网发布检测)检测流程以及踩到的坑

能点到全网发布这一步,说明你已经弄好了获取component_verify_ticket,component_access_token等这些参数,通常这个时候点击全网发布只会有这两个失败。如果其他失败的那就要好好检查一下你的代码了,或者查看...

centos 配置Let's Encrypt 泛域名https证书

centos 配置Let's Encrypt 泛域名https证书

前言2018年1月份Letsencrypt可以申请泛域名证书,这让我们部署多域名、多站点https省了很多功夫,终于可以不用维护多个域名的https证书。笔者以acme.sh为例,手把手教你配置https证书~本教程适用于centos 6....

安装Windows 10X 教你如何安装Win10X正式版 及下载地址

安装Windows 10X 教你如何安装Win10X正式版 及下载地址

安装Windows 10X 教你如何安装Win10X正式版:Windows 10X是Windows 10操作系统的新版本,主要针对双屏电脑。由于即将运行Windows 10X的双屏电脑(例如即将面世的Surface Neo)的开发遇到挫折,...

VirtualXposed 不支持32位应用 32位无法安装问题解决办法

VirtualXposed 不支持32位应用 32位无法安装问题解决办法

VirtualXposed 是基于VirtualApp 和 epic 在非ROOT环境下运行Xposed模块的实现(支持5.0~10.0)。与 Xposed 相比,目前 VirtualXposed 有...

php Aes 加密模式ECB填充pkcs5padding base64

最近做支付项目用到了aes加密不过试了好多办法总是和官方给出的结果不一样,找了很久终于找到了测试结果同 http://tool.chacuo.net/cryptaes/ <?php /**  * [Aes&nb...

发表评论

访客

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