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

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

admin2周前 (05-04)技术分享69

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

分享给朋友:

相关文章

Linux/centos inode 占用100%的解决办法

当你的 Linux 系统无法创建新文件时,有可能是你的磁盘满了,还有可能是你的磁盘的 inode 用光了,我们今天要说的就是后一种情况,要解决这个问题,只能是删除一些文件,但是一般情况下,其实是你的系统中的某个地方产生了大量的你并不需要的文...

python3 selenium webdriver.Chrome php 爬取汽车之家所有车型详情数据[开源版]

介绍本接口是车型库api的补充,用于爬取汽车之家所有车型详情数据开源地址:https://gitee.com/web/CarApi/tree/master/python软件架构python3 selenium webdriver.Chrom...

PHP AES加解密 (ECB模式/sha1prng算法/PKCS5Padding和PKCS7Padding补码) ECB 模式不需求设置 iv

php7+ 版本/**  * [AesSecurity aes加密,支持PHP7+]  * 算法模式:ECB  * 密钥长度:128  * 补...

对比 Git 与 SVN,这篇讲的很易懂

导语本文从 Git 与 SVN 的对比入手,介绍如何通过 Git-SVN 开始使用 Git,并总结平时工作高频率使用到的 Git 常用命令。一、Git vs SVNGit 和 SVN 孰优孰好,每个人有不同的体验。Git是分布式的,SVN是...

用CMD命令查询域名的DNS解析记录:A,NS,MX,CNAME,TXT

1、查询域名的A记录nslookup -qt=A bitefu.net当然查询A记录你直接用ping命令来ping域名也可以获得A记录。2、查询域名的NS记录nslookup -qt=NS bitefu.net3、查询域名的MX记录nslo...

百度云网盘高速下载方法[测试可用]

百度云网盘高速下载方法[测试可用]

大前提这是一个油猴脚本,安装脚本之前,必须先安装油猴浏览器扩展(如已安装则跳过):【第一步】下载油猴 --> 如有提示安装,则直接安装即可,否则继续执行第二步【第二步】安装油猴 --> 参考其中章节:&nbs...

发表评论

访客

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