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

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

admin3年前 (2022-05-04)技术分享5039

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

相关文章

linux centos svn搭建及网站同步更新

以前上线的项目都是用ftp来更新的.后来技术人员多了,ftp的弊端就出来了.所以在这里给大家介绍一下我们现在正在使用的svn同步修改更新的方案.原理很简单主要是用到了svn的hooks功能.即本地提交到服务器的svn服务器.然后svn服务器...

thinkphp等框架开发中容易忽略的xss攻击及应对XSS攻击方法

thinkphp等框架开发中容易忽略的xss攻击及应对XSS攻击方法

虽然说现在的web开发框架都是挺成熟的框架,在性能、安全等方面都有比较好的表现,但问题往往出现在业务逻辑上,如上周我再公司发现的一个跨站脚本攻击,(通常公司是这么过滤的,max(0,$_GET[‘a’])、strip_tags($_GET[...

百度云,天翼云盘解析网页地址 收集分享

百度云解析http://p.106666.xyz/https://pan.kdbaidu.com/https://pan.kdpd.me/https://yun.kdbaidu.com/http://blog.xxatf.top/https...

input search更改默认删除按钮的样式

改input输入框search属性下输入文字之后会在输入框最后出现一个默认样式的X不过这个样式不太好看想自定义怎么办呢方法一input[type="search"]::-webkit-search-cancel-butt...

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

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

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

[教程] WTG备份新方法——FFU镜像格式

[教程] WTG备份新方法——FFU镜像格式

FFU(Full Flash Update) 格式是一种基于扇区的磁盘镜像文件格式,默认使用快速哈夫曼压缩(Xpress-Huffman)算法压缩,在捕获和部署时会生成哈希表进行校验,并可以使用DISM修改捕获的镜像。FFU格式很适合WTG...

发表评论

访客

看不清,换一张

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