Git学习手册(收藏)

安装和配置

Git 安装

首先,我们必须安装 Git 才能使用它!这里分 Linux 和 Windows 来演示:

在 Linux 上安装 Git

sudo apt-get install git

在 Windows 上安装 Git

直接在Git - Downloads里面,下载最新版的 Git,默认安装就可以了。

安装完成后,在开始菜单里找到 Git->Git Bash,点击后出现一个类似命令行窗口的东西,就说明 Git 安装成功。

Git 配置

可以保存 Git 用户名和电子邮件,这样就不必在以后的 Git 命令中再次输入它们。

config 配置指令

在命令行中配置本地仓库的账号和邮箱:

$ git config --global user.name "zhangsan"  
$ git config --global user.email "zhangsan@qq.com"  

config 配置有system级别 global(用户级别) 和local(当前仓库)三个 设置先从system-》global-》local  底层配置会覆盖顶层配置 分别使用--system/global/local 可以定位到配置文件

好多人都不知道的小技巧是,你可以为 Git 启用一些额外的颜色,这样就可以更容易地阅读命令的输出!

git config --global color.ui true

查看系统config

git config --system --list

查看当前用户(global)配置

git config --global  --list

查看当前仓库配置信息

git config --local  --list


Git工作流程

初始化 Git

现在,我们可以开始对项目进行版本控制。使用 cd 命令导航到要在终端中设置版本控制的目录,现在你可以像这样初始化 Git 存储库:

git init

这将创建一个名为 .git 的新子目录(Windows 下该目录为隐藏的),其中包含所有必需的存储库文件(Git 存储库框架)。至此,你的项目中尚未跟踪任何内容。

添加并提交

要开始对现有文件进行版本控制,你应该先跟踪这些文件并进行初始提交。要做到这一点,你首先需要将文件添加到 Git 中,并将它们附加到 Git 项目中。

git add <file>
git commit -m 'first commit'

远程备份

已经开始在本地对项目进行版本控制。如果你想远程保存和备份项目,则需要在 GitHub 上创建一个远程存储库(它是免费的!)。因此,首先转到 http://github.com 并创建一个存储库。然后,使用存储库的链接将其添加为本地 git 项目的来源,即该代码的存储位置。

# 示例
git remote add origin https://github.com/your_name/repo.git 
# 以我的一个仓库为例
git remote add origin https://github.com/your_name/JDKSourceCode1.8.git

然后,你可以继续将代码推送到 GitHub!哇,你已经成功备份了你的代码!

git push origin master   # push到远程仓(origin)的master分支

git查看远程仓库地址

git remote -v    //查看远程仓

状态检查

git status 命令用于确定哪些文件处于哪种状态,它使你可以查看哪些文件已提交,哪些文件尚未提交。如果在所有文件都已提交并推送后运行此命令,则应该看到类似以下内容:

$ git status
# On branch master
nothing to commit (working directory clean)

如果你将新文件添加到项目中,而该文件之前不存在,则在运行 git status 时,你应该看到未跟踪的文件,如下所示:

$ git status
# On branch master
# Untracked files:
#   (use "git add <file>..." to include in what will be committed)
#
#   README
nothing added to commit but untracked files present (use "git add" to track)

使用 git status 对于快速检查你已经备份的内容和你仅在本地拥有的内容非常有用。

高级文件添加

还有一些更高级的方法可以将文件添加到 Git 中,从而使你的工作流程更高效。我们可以执行以下操作,而不是试图查找所有有更改的文件并逐个添加它们:

# 逐个添加文件
git add filename

# 添加当前目录中的所有文件
git add -A

# 添加当前目录中的所有文件更改
git add .

# 选择要添加的更改(你可以 Y 或 N 完成所有更改)
git add -p

高级提交

我们可以使用 git commit -m '提交信息' 来将文件提交到 Git。对于提交简短消息来说,这一切都很好,但是如果你想做一些更精细的事情,你需要来学习更多的操作:

### 提交暂存文件,通常用于较短的提交消息
git commit -m 'commit message'

### 添加文件并提交一次
git commit filename -m 'commit message'

### 添加文件并提交暂存文件
git commit -am 'insert commit message'

### 更改你的最新提交消息
git commit --amend 'new commit message' 

# 将一系列提交合并为一个提交,你可能会用它来组织混乱的提交历史记录
git rebase -i
### 这将为你提供核心编辑器上的界面:
# Commands:
#  p, pick = use commit
#  r, reword = use commit, but edit the commit message
#  e, edit = use commit, but stop for amending
#  s, squash = use commit, but meld into previous commit
#  f, fixup = like "squash", but discard this commit's log message
#  x, exec = run command (the rest of the line) using shell

git commit --amend 这条实用命令, 其可以用来修改最后一条提交的 commit message, 也可以追加新的修改.

有时候不小心 amend 了错误的内容, 如何回退呢?

如果只 amend 了一次, 那么直接用 git reset HEAD@{1} 就可以撤销这次 amend. 如果 amend 多次, 就参考 git reflog 进行撤销.

制造错误现场

首先制造事故现场. 追加空行到项目中的 index.html 文件下:

$ echo "" >> index.html 
$ git add .
$ git commit -m "add blank line to index.html"

然后再加一行到 index.html, 并 amend 一下:

$ echo "this line would break the code" >> index.html 
$ git add .
$ git commit --amend

现场已经出现, 我们要撤销 amend 的那个提交.

撤销 amend

首先使用 git reflog 命令查看操作记录:

$ git reflog
c1c1b21 HEAD@{0}: commit (amend): add blank line to index.html
9ff821d HEAD@{1}: commit: add blank line to index.html
b078331 HEAD@{2}: commit: no more commit!
b86e902 HEAD@{3}: commit: so many commit
77e6ce9 HEAD@{4}: commit: this is another commit
ccde039 HEAD@{5}: commit: this is a commit
a49dcf4 HEAD@{6}: clone: from ssh://liux@xxx.xx.xx.xxx:29418/git_test.git

看到 amend 操作之前的最后一个操作就是 HEAD@{1}.
现在可以用 git reset 将当前分支的 HEAD 指向 HEAD@{1}, 即可达到撤销 amend 的目的:

$ git reset --soft HEAD@{1}
$ git status
On branch master
Your branch is ahead of 'origin/master' by 5 commits.
  (use "git push" to publish your local commits)
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

    modified:   index.html

随即使用 git status 查看状态, 发现 amend 的内容已经被撤销 (到工作区) 了.
如果想撤销到暂存区, 就用 git reset --soft HEAD@{1} .
如果想干掉这个修改, 就用 git reset --hard HEAD@{1} .
这和 git reset 操作 commit 的情形是一样的.

如果一个 commit 被 amend 了多次, 也可以用这种方法撤销到任意一次 amend 处

分支与合并

GitHub存储库的master分支应始终包含有效且稳定的代码。但是,你可能还希望备份一些当前正在处理的代码,但这些代码并不完全稳定。也许你要添加一个新功能,你正在尝试和破坏很多代码,但是你仍然希望保留备份以保存进度!

分支使你可以在不影响master分支的情况下处理代码的单独副本。首次创建分支时,将以新名称创建master分支的完整克隆。然后,你可以独立地在此新分支中修改代码,包括提交文件等。一旦你的新功能已完全集成并且代码稳定,就可以将其合并到master分支中!

分支

这是你在分支上创建和工作所需的所有东西:

### 创建一个本地分支
git checkout -b branchname

### 在2个分支之间切换
git checkout prc/dev-wupx
git checkout master

### 将新的本地分支作为备份
git push -u origin branch_2

### 删除本地分支,这不会让你删除尚未合并的分支
git branch -d branch_2

### 删除本地分支,即使尚未合并,这也会删除该分支!
git branch -D branch_2

### 删除远程分支
git push origin --delete remoteBranchName

### Viewing all current branches for the repository, including both ### local and remote branches. Great to see if you already have a ### branch for a particular feature addition, especially on bigger ### projects
### 查看存储库的所有当前分支,包括本地和远程分支。
git branch -a

### 查看已合并到您当前分支中的所有分支,包括本地和远程。 非常适合查看所有代码的来源!
git branch -a --merged

### 查看尚未合并到当前分支中的所有分支,包括本地和远程
git branch -a --no-merged

### 查看所有本地分支
git branch

### 查看所有远程分支
git branch -r

# 将主分支重新设置为本地分支
$ git rebase origin/master

# 将分支推送到远程存储库源并对其进行跟踪
$ git push origin branchname

合并

将新功能添加到分支中之后,你需要将其合并回master分支,以便您的master具有所有最新的代码功能。

方法如下:

### 首先确保你正在查看 master 分支
git checkout master

### 现在将你的分支合并到 master 
git merge prc/dev-name

你可能必须修复分支与主服务器之间的任何代码冲突,但是 Git 将向你展示在键入该 merge 命令后如何执行所有这些操作。

git fetch 

例子1:从默认远程仓库获取更改

$ git fetch

此命令将从默认远程仓库获取最新更改,并将其存储在本地仓库中的“远程跟踪分支”中。

例子2:从特定分支获取更改

$ git fetch origin master

此命令将从“origin”远程仓库的“master”分支获取最新更改,并将其存储在本地仓库的“远程跟踪分支”中。

例子3:从多个远程仓库拉取更新

$ git remote add upstream <upstream-repo-url>
$ git remote -v
$ git fetch upstream

这个命令会添加一个名为“upstream”的新的远程仓库。git remote -v命令会显示所有可用的远程仓库。git fetch upstream命令会从"upstream"远程仓库中获取最新的更新,并将它们存储在本地仓库的"remote-tracking branch"中。

例子4:从特定远程仓拉取更新

格式:git fetch <远程仓> <远程分支名> :<本地分支名>

  • git fetch origin 远程分支:本地分支1

首先执行上面的fetch操作,使用远程个人仓分支在本地创建分支1,如果本地不存在分支1, 则会自动创建一个新的分支1,
如果本地存在分支1, 并且是`fast forward’, 则自动合并两个分支, 否则, 会阻止以上操作.

  • git fetch mian 远程分支:本地分支1

首先执行上面的fetch操作,使用远程仓分支在本地创建分支1,如果本地不存在分支1, 则会自动创建一个新的分支1,
如果本地存在分支1, 并且是`fast forward’, 则自动合并两个分支, 否则, 会阻止以上操作.

isource如何同步主仓新增分支信息到个人仓

1、将isource个人仓clone到本地
git clone -b master ssh://git@isource-yy.xxx.com:2222/{工号}/{项目}.git

2、进入本地目录
cd {项目}

3、将isource主仓添加为远程库main(名字可随意起)
git remote add main ssh://git@isource-yy.xxx.com:2222/{产品}/{项目}.git

4、同步一下远程库main(isource主仓)的所有分支信息到本地
git fetch main
或git fetch main master:A

5、在本地创建一个同名分支{A},并同步远程库main(isource主仓)分支{A}的代码到本地
git checkout -b {A} main/{A}

6、将本地新增分支推送到isource的个人仓
git push origin {A}

修复错误和回溯

发生错误......它们经常在编码中发生!重要的是我们能够修复它们。

不要慌!Git 提供了你所需的一切,以防你在所推送的代码中犯错,改写某些内容或者只是想对所推送的内容进行更正。

### 切换到最新提交的代码版本
git reset HEAD 
git reset HEAD -- filename # for a specific file
### 切换到最新提交之前的代码版本
git reset HEAD^ -- filename
git reset HEAD^ -- filename # for a specific file
### 切换回3或5次提交
git reset HEAD~3 -- filename
git reset HEAD~3 -- filename # for a specific file
git reset HEAD~5 -- filename
git reset HEAD~5 -- filename # for a specific file
### 切换回特定的提交,其中 0766c053 为提交 ID
git reset 0766c053 -- filename
git reset 0766c053 -- filename # for a specific file
### 先前的命令是所谓的软重置。 你的代码已重置,但是git仍会保留其他代码的副本,以备你需要时使用。 另一方面,--hard 标志告诉Git覆盖工作目录中的所有更改。
git reset --hard 0766c053

撤销修改

以提问中修改了两个文件a、b为例,假设需要撤销文件a的修改,则修改后的两个文件:
1、如果没有被git add到索引区

  • git checkout a 便可撤销对文件a的修改

2、如果被git add到索引区,但没有做git commit提交
1)使用git reset将a从索引区移除(但会保留在工作区)

  • git reset HEAD a

2)撤销工作区中文件a的修改

  • git checkout a

3、如果已被提交,则需要先回退当前提交到工作区,然后撤销文件a的修改
1)回退当前提交到工作区

  • git reset HEAD^

2)撤销工作区中文件a的修改

  • git checkout a

单个文件/文件夹:

$ git checkout -- filename

所有文件/文件夹:

$ git checkout .

git查看stash里面的具体内容 

1.查看stash list(所有的stash)

git stash list

2.查看某个stash具体内容

git stash show -p stash@{3}

git中HEAD^和HEAD~区别

^x:  尖头符号,形似箭头,表示要朝那个方向,始终是走一步,x 表示第几个岔路口,代表方向盘
~y:  波浪符号,表示要在该方向上走 y 步,始终沿着该方向,代表油门

当前节点的祖宗节点如下:

自己: HEAD, HEAD^0 或 HEAD~0
父亲: HEAD^, HEAD~
母亲: HEAD^2
爷爷: HEAD^~, HEAD~2, HEAD^^
奶奶: HEAD^^2, HEAD~^2
姥爷: HEAD^2~, HEAD^2^
姥姥: HEAD^2^2

对 Git 有用的提示和技巧

我们已经完成了所有细节部分!以下是一些 Git 提示和技巧,你可能会发现它们对改善工作流程非常有用!

搜索

### 搜索目录中的字符串部分
git grep 'project'

### 在目录中搜索部分字符串,-n 打印出 git 找到匹配项的行号
git grep -n 'project'

### git grep -C <行数> 'something' 搜索带有某些上下文的字符串部分(某些行在我们正在寻找的字符串之前和之后)
git grep -C<number of lines> 'project'

### 搜索字符串的一部分,并在字符串之前显示行
git grep -B<number of lines> 'project'

### 搜索字符串的一部分,并在字符串之后显示行
git grep -A<number of lines> 'something'

看谁写了什么

### 显示带有作者姓名的文件的更改历史记录
git blame 'filename'

### 显示带有作者姓名和 git commit ID 的文件的更改历史记录
git blame 'filename' -l

日志

### 显示存储库中所有提交的列表 该命令显示有关提交的所有信息,例如提交ID,作者,日期和提交消息
git log

### 提交列表仅显示提交消息和更改
git log -p

### 包含您要查找的特定字符串的提交列表
git log -S 'project'

### 作者提交的清单
git log --author 'wupx'

### 显示存储库中提交列表的摘要。显示提交ID和提交消息的较短版本。
git log --oneline

### 显示昨天以来仓库中的提交列表
git log --since=yesterday

### 显示作者日志,并在提交消息中搜索特定术语
git log --grep "project" --author "wupx"

带上别人的MR后的解决办法:

gitk
git log
git reset --hard XXX
git log -2
git push origin -f
git remote -v    //查看远程仓
git pull main DevelopMain
git push origin DevelopMain

冲突解决步骤:

pull——>status——>查看原因并修改——>add——>commit——>status——>push


参考:

  1. git 中如何撤销部分修改? - 知乎
  2. git查看远程仓库地址_Airsanker的博客-CSDN博客_git 查看地址
  3. 看完这篇还不会用Git,那我就哭了! - 知乎
  4. GIT-查看config配置信息 - Merray - 博客园
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值