git安装使用

一、git安装

官网下载git安装版本。
在这里插入图片描述
配置可按图中选取,剩余步骤直接next到完成:
在这里插入图片描述

二、基础配置

1.配置全局名称和邮箱

git config --global user.name Account
git config --global user.email GerritEmail
  1. 替换为你的账号
  2. 替换为你的Gerrit登录邮箱

2.配置CommitMessage模板

1.编辑模板

在git安装路径或自定义路径创建commit-template文件,填写以下内容。

[Trace Info]: #{issuekeys}# - {summary}
[Type]        : {type}
[Module]      : {module}
----------------------------------------------------------------------
[Code change tested and verified on the target board?] : Yes/NA
[Coding rules are followed?]                           : Yes
[Necessary comments added?]                            : Yes
[Change history of the source files updated?]          : Yes
  1. issuekeys:事务ID
  2. summary:提交总结

2.添加模板

git bash运行以下命令:
git config --global commit.template TemplateFilePath

  1. TemplateFilePath:模板文件绝对路径。

3.配置commitmessage编写程序

  • git commit默认使用vim编写;
  • 在vscoder使用配置如下:
git config --global core.editor "code --wait"

备注:通过git commit直接提交,会弹出message编辑文本,完成编辑,关闭执行后去操作。

  • linux中使用nano
git config --global core.editor nano

三.完整的拉去和提交流程

1拉去流程

# 克隆仓库  
git clone https://github.com/username/repo-name.git  
  
# 进入仓库目录  
cd repo-name  
  
# 切换到特定分支(如果分支已存在于本地)  
git switch branch-name  
  
# 或者,如果分支不存在于本地但存在于远程,则创建并切换到它  
git switch -c branch-name origin/branch-name

2提交流程

1.流程:

工作区(代码编辑窗口,修改代码)>暂存区(将修改的代码加入暂存区)>本地仓库(将暂存区内容放入本地仓库)>远程仓库(如果使用gerrit,会将代码提交到审阅的分支仓库)

2.使用

1.工作区以及暂存区使用

使用git status查看更改

git status

使用 git add <file> 添加需要提交的文件到暂存区。
使用 git add . 添加所有更改到暂存区(谨慎使用)。

git add .
2.提交本地

使用 git commit -m “详细的提交信息” 提交暂存区的内容到本地仓库。
确保提交信息清晰,并包含 Change-Id(如果使用 Gerrit)

git commit -m
3.拉取避免冲突

使用 git pull 命令从远程仓库拉取最新的更改到你的本地分支。避免覆盖其他人已提交的内容。
具体来说,git pull做了以下几件事:

  1. 拉取(Fetch):首先,Git会从远程仓库获取最新的更改(commit)和元数据,但不会自动合并或修改你本地的工作目录或本地仓库中的任何内容。这些更改被存储在本地仓库的“远程跟踪分支”中,例如origin/master(如果origin是你的远程仓库名称,且你正在操作master分支)。
  2. 合并(Merge)或变基(Rebase):然后,Git会根据你的配置(或命令中指定的选项)自动将远程跟踪分支中的更改合并到你当前的本地分支,或者将它们变基到你的本地分支上。这个合并或变基操作是在本地仓库中进行的,而不是直接在工作区中。
  3. 如果你使用的是默认的合并策略,Git会尝试将远程更改与你的本地更改合并。如果合并过程中出现冲突,Git会暂停合并过程,并让你解决这些冲突。
git pull

git pull是将远程仓库中的更改拉取到本地仓库,并根据你的配置将它们合并或变基到你的本地分支上。

4.推送

使用 git push origin HEAD:refs/for/branch 将提交推送到远程仓库。
确保在推送前解决所有冲突,并且提交信息符合要求。

git push origin HEAD:refs/for/branch
5.分支合并

切换到要合并的分支上,将feature合并到develop。
(合并分支通常指的是在本地仓库中合并两个不同的分支)

1.git checkout develop
2.git merge feature

四.常用命令

1.git branch查看当前代码块所在分支git branch

git branch

2.git branch -a要查看所有本地分支和远程分支,可以使用。

git branch -a

3.git branch -r查看远程分支

git branch -r

4.git push origin HEAD:refs/for/branch提交代码详解

git push origin HEAD:refs/for/branch
  1. origin
    origin 是一个远程仓库的名字。在大多数情况下,当你克隆一个 Git 仓库时,默认的远程仓库名字就是 origin。

  2. HEAD
    HEAD 是一个特殊指针,指向当前工作所在的分支。在 Git 中,HEAD 指向的是你最近检出的分支的顶端,也就是最后一次提交的位置。当你在一个分支上工作时,HEAD 就是指向该分支的最新提交。

5.git reset HEAD~1回退操作

git reset HEAD~1
git reset HEAD^^
git reset commitID
  1. git reset HEAD~1/git reset HEAD^:这个命令将当前分支的HEAD指针回退两个提交,即提交到本地仓库的commit操作。添加--mixed,同时将暂存区的更改移除;添加--hard,同时将工作区的变动移除。

  2. .git reset commitID:这个命令将HEAD指针移动到指定的 commitID 所代表的提交上。通过git log查看提交记录获取commitID。

6.创建新的分支,保存旧的更改。

对于Git 2.23及之前版本:

git checkout -b new-branch-name <commit-id>

对于Git 2.23及以后版本:

git switch -c new-branch-name <commit-id>

6.git checkout -b branch-name origin/branch-name

-b(或–branch)选项的作用是创建一个新的本地分支,并立即切换到该分支。这个命令实际上是结合了git branch命令的创建分支功能和git checkout命令的切换分支功能于一体的快捷方式。。

git checkout -b branch-name origin/branch-name

检查远程分支:Git首先查找名为origin/branch-name的远程分支,确保它存在于你的远程仓库引用中。
创建新分支:如果远程分支存在,-b选项会指示Git创建一个新的本地分支,分支名由branch-name指定,并且这个新分支的起点(即它的第一个提交)是远程分支origin/branch-name当前指向的提交。
设置上游跟踪(可选,但通常Git会这样做):新创建的本地分支可能会自动设置为跟踪对应的远程分支(即origin/branch-name),但这取决于Git的版本和配置。即使不是自动的,你也可以稍后使用git branch --set-upstream-to=origin/branch-name branch-name命令来手动设置。
切换分支:最后,Git会切换到新创建的本地分支。此时,你的工作目录和暂存区将更新为该分支的最新状态。。

7.git switch -c branch-name origin/branch-name

Git命令git switch -c branch-name origin/branch-name中,-c(或–create)选项的作用是创建一个新的本地分支,并将其与指定的远程分支(在本例中是origin/branch-name)的当前状态相关联。

git switch -c branch-name origin/branch-name

检查远程分支:Git首先查找名为origin/branch-name的远程分支,确保它存在于你的远程仓库引用中。
创建新分支:如果远程分支存在,-c(或–create)选项会指示Git创建一个新的本地分支,分支名由branch-name指定。
设置上游跟踪:新创建的本地分支会自动设置为跟踪对应的远程分支(即origin/branch-name)。这意味着,当你在这个新分支上执行git pull或git push时,Git会知道应该从哪个远程分支拉取或推送更改。
切换分支:最后,Git会切换到新创建的本地分支。此时,你的工作目录和暂存区将更新为该分支的最新状态。

8.git reflog

git reflog

显示本地仓库的引用日志(reference log)。记录了 HEAD 和分支引用的变化历史,包括你何时切换了分支、何时创建了新的分支或标签、何时执行了 git reset、git commit --amend 或 git rebase 等操作。
运行 git reflog 命令时,它会列出一系列的操作,每个操作都有一个唯一的引用(通常是一个十六进制数),紧接着是操作的简短描述和对应的 HEAD 指向的提交 ID。

9.多分支项目git clone

git clone

Git 实际上会获取远程仓库中所有分支的提交历史,并将它们存储在本地仓库的数据库中。(初始获取了所有分支提交代码)
默认只会创建一个指向远程仓库默认分支(通常是master或main。同时,Git 还会为远程仓库中的其他分支创建对应的远程跟踪分支。(初始只会有一个默认分支,当切换分支时,本地若已经存在,则会将本地仓库HEAD指向对应分支,并加载该分支对应的代码和文件到你的工作目录和暂存区)
使用git switch(或git checkout,在较旧的Git版本中)命令切换分支时,你实际上是在改变本地仓库中HEAD指针的指向,以便让它指向你希望工作的分支。如果分支已经存在于本地仓库中,Git 会直接切换到该分支,并加载该分支对应的代码和文件到你的工作目录和暂存区(如果之前的工作目录和暂存区中有未提交的更改,Git 可能会阻止你切换分支,直到你解决了这些更改)。

五.报错处理以及近似命令异同

1.change_id缺失

remote: ERROR: commit 81f6790: missing Change-Id in message footer
remote:
remote: Hint: to automatically insert a Change-Id, install the hook:

提交时需要验证change_id,解决方法:
①.使用git bash,运行:

gitdir=$(git rev-parse --git-dir)
scp -P 29418 xxxxx@00.000.00.00:hooks/commit-msg $gitdir/hooks/

1.xxxxxx是你的用户名,
2.00.000.00.00是你的 Gerrit 服务器地址,
3. 29418 是默认的 SSH 端口号。
安装完成后,当你创建新的提交时,commit-msg 钩子将会自动添加 Change-Id。

git commit --amend --no-edit

这个命令会修改最后一个提交的信息,并保留之前的提交信息内容。如果你之前没有手动添加 Change-Id,现在它应该会被自动添加到提交信息的末尾。
②.使用如下命令,在项目刚获取时使用:

curl http://00.000.00.000/files/hooks/commit-msg -o .git/hooks/commit-msg
  1. curl 命令是从指定的服务器地址下载 commit-msg 文件,
  2. 并将其保存到当前仓库的 .git/hooks/ 目录下。
  3. 这条命令的目的是获取一个可以自动生成 Change-Id 的 commit-msg 钩子脚本。
  4. http://00.000.00.000/files/hooks/commit-msg:这个 URL 指定了一个 HTTP 服务器的地址,该服务器托管了一个名为 commit-msg 的文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值