SourceTree + Gerrit

通过Mac 上的SourceTree向Gerrit服务推送代码

通过sourcetree向gerrit服务推送资源时不能直接推送。因为在gerrit上需要审查代码,审查代码之后才会合并到master。

不清楚gerrit工作流程的可以查阅下面的文档gerrit的工作流程及使用可以查阅这个文档

可以通过git命令向gerrit推送,但是个人更喜欢sourcetreee可视化的操作,下面就介绍配置流程。

1、git配置

Mac上安装Xcode之后,默认有git工具

2、通过git设置用户名和邮箱

打开终端terminal,
输入下面两个命令:$ git config --global user.name "Zeke"//这里需要使用自己的名字$ git config --global user.email "zeke@163.com"//这里需要改成自己的邮箱

3、创建公钥

打开终端terminal,输入下面的命令$ cd ~进入当前的用户目录
检查是否存在.ssh文件夹$ ls -a在显示的列表里看是否有.ssh文件夹

1创建.ssh文件夹.png

如果不存在.ssh文件夹就创建它$ mkdir .ssh
进入.ssh 文件夹$ cd .ssh

检查.ssh文件夹是否有内容$ ls

有内容的话可以看到下面的信息id_rsa id_rsa.pub known_hosts

如果有内容就删除$ rm id_rsa id_rsa.pub

创建公钥$ ssh-keygen -t rsa -C "zeke@163.com"//邮箱换成自己的
然后一直Enter ,直到完成

查看生成的key$ ls

id_rsa id_rsa.pub known_hosts

查看公钥内容$ cat id_rsa.pub

这里的公钥内容后面要用到

配置ssh公钥到gerrit网页

使用自己的账号登陆gerrit之后,在自己账户的setting下添加公钥

2在gerrit添加.ssh公钥.jpeg

配置本地gerrit

进入到之前创建的.ssh文件夹 这个文件夹里创建一个文件config,在该文件里输入以下内容

host gitserver
hostname 172.16.99.59//换成自己的gerrit服务ip地址
user zeke //换成自己在gerrit上的用户名
port 29418

host gerrit
hostname 172.16.99.59 //换成自己的gerrit服务ip地址
user zeke //换成自己在gerrit上的用户名
port 29418
KexAlgorithms +diffie-hellman-group1-sha1

拉取代码

3souretree上拉取gerrita仓库.png

这里之所以能通过gerrit:/xxx来拉取xxx项目的代码,是因为我们在.ssh文件夹里配置好了config,其中包含对gerrit的配置。所以在sourceTree上通过gerrit:/xxx可以拉取到代码。

推送代码

推送代码需要注意,自己不能直接推送,直接推送无法推到gerrit服务。我们需要在sourcetree上单独定义推送操作。另外需要在拉取的本地仓库文件夹的.git文件夹中需要有hooks文件夹。具体就是下面两点:

1、 需要有hooks文件夹,并且拉取远程仓库里的commit-msg文件。
2、 在sourcetree上自定义推送命令

查看hooks文件夹

如果你拉取的代码放在本地仓库fishFile文件夹里,请cd 到这个目录
然后$ ls -a

查看该目录下的所有内容

.       .DS_Store   .gitignore
..      .git        FitnessApp(这是我自己的项目)

我们需要关心的是.git文件夹,进入这个文件夹$ cd .git$ ls -a
看是否有hooks文件夹,如果没有这个文件夹就创建$ mkdir hooks

然后在当前的.git目录下输入以下命令$ scp gerrit:hooks/commit-msg hooks/
这样就可以把远程的commit-msg文件拉到本地hooks目录下了。这样做的目的是为了处理自定义推送时sourcetree上缺失change-id,没有change-id我们无法推送

接下来处理sourcetree自定义推送命令

写个脚本录入如下信息:

#!/bin/sh

#  push.sh
#  KeepRunning

# 获取当前分支名
branch=`git symbolic-ref --short -q HEAD`
# push review
git push origin HEAD:refs/for/${branch}

这个脚本的意思是向当前分支推送,一般都是向master分支推送(在gerrit上)。
比如我的脚本名字是:sourcetreeGerritPush.sh
接下来在sourcetree上操作。打开sourcetree->顶部动作->自定义操作->编辑->添加
如下图所示

4sourcetree自定义操作.jpeg

接下来就是提交及推送了

在sourcetree里正常提交之后,推送时不要选择sourcetree上的推送,需要使用自己自定义的操作。
如下图所示:

5sourcetree推送动作.jpeg

到这里通过sourcetree推送到gerrit服务就结束了。可以到gerrit上查看已经推送的内容并审核。

更新时间2019-03-13

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SourceTree是一款免费的Git和Hg客户端管理工具,它支持Git项目的创建、克隆、提交、push、pull和合并等操作。它的界面简洁美观,能够极大地简化开发者与代码库之间的Git操作方式,对于不熟悉Git命令的开发者来说非常实用。 通过使用SourceTree结合Gitee,你可以在Gitee上创建一个云端的Git仓库,并使用SourceTree进行代码的管理和操作。 为了使用SourceTree进行Git操作,你需要先在Mac上配置好Git环境,并安装好SourceTree客户端。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Git 管理工具 SourceTree 的使用(上手简单,不熟悉git命令的开发者必用)](https://blog.csdn.net/weixin_53072519/article/details/124197177)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Mac下配置git环境和客户端SourceTree+Git常用命令大全(Mac 10.12)-附件资源](https://download.csdn.net/download/weixin_42187944/15586091)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值