Git操作详细总结

Git的使用

基础操作

  • git init 初始化一个仓库
  • git add readme.txt 添加一个文件到版本控制
  • git commit -m "add a readme file" 提交文件并添加一个说明
  • git status 查看仓库的当前状态,下面的命令告诉我们,readme文件被修改了,但是还没有提交。
PS D:\learngit> git status
On branch master

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:   readme.txt

no changes added to commit (use "git add" and/or "git commit -a")
  • git diff readme.txt 查看具体修改内容,13,14行表名了文档内容修改部分
PS D:\learngit> git diff readme.txt

diff --git a/readme.txt b/readme.txt

index d8036c1..7b4104a 100644

--- a/readme.txt

+++ b/readme.txt

@@ -1,2 +1,2 @@

-Git is a version control system.
+Git is a distributed  version control system.

 Git is free software.

\ No newline at end of file
  • git log (--pretty=oneline) 显示从最近到最远的提交日志,一行显示。前面的一长串字母加数字的组合是SHA1值
PS D:\learngit> git log
commit 7e4d2e7ca2c64acba9d4580112f2d111681ae30e
Author: Sunxin <sunxin0630@gmail.com>
Date:   Wed Jun 28 16:53:17 2017 +0800

    append GPL

commit 8ba42d2299510a66489741269a789e9a3fa31691
Author: Sunxin <sunxin0630@gmail.com>
Date:   Wed Jun 28 16:51:36 2017 +0800

    add distributed

commit 67ae9c91bce5b91e54a722d091f13c1de425b9a3
Author: Sunxin <sunxin0630@gmail.com>
Date:   Wed Jun 28 16:36:25 2017 +0800

    wrote a readme file
    
PS D:\learngit> git log --pretty=oneline
7e4d2e7ca2c64acba9d4580112f2d111681ae30e append GPL
8ba42d2299510a66489741269a789e9a3fa31691 add distributed
67ae9c91bce5b91e54a722d091f13c1de425b9a3 wrote a readme file

版本回退

  • git reset --hard HEAD^ 回退到上一个版本,在git中HEAD代表当前版本,HEAD代表上个版本,HEAD^代表上上个版本,HEAD是一个指针
PS D:\learngit> git reset --hard HEAD^
HEAD is now at 8ba42d2 add distributed
PS D:\learngit> cat readme.txt
Git is a distributed  version control system.
Git is free software.
  • git reset --hard 7e4d2e7 回退过版本之后又后悔了,想要回去怎么办,只需要记着原来的commit id即可,这样就可以指定回到未来的某个版本
PS D:\learngit> git reset --hard 7e4d2e7
HEAD is now at 7e4d2e7 append GPL
PS D:\learngit> cat readme.txt
Git is a distributed  version control system.
Git is free software distributed under the GPL.
  • git reflog 想要回到未来却找不到commit id怎么办,此命令用来记录用户操作的每一次命令,这样就可以找到每一次操作的commit id了。
PS D:\learngit> git reflog
7e4d2e7 HEAD@{0}: reset: moving to 7e4d2e7
8ba42d2 HEAD@{1}: reset: moving to HEAD^
7e4d2e7 HEAD@{2}: commit: append GPL
8ba42d2 HEAD@{3}: commit: add distributed
67ae9c9 HEAD@{4}: commit (initial): wrote a readme file

工作区和暂存区

工作区(Working Directory):能看到的一个目录

暂存区(stage):隐藏目录不算工作区,而是版本库,版本库中存放着名为stage or index 的暂存区,还有git自动为我们创建的第一个分支master,以及指向master的一个指针HEAD

  • git add 是把文件添加进去,实际上就是把文件修改添加到暂存区
  • **git commit **提交更改,实际上就是把暂存区的文件提交到当前分支

管理修改

为什么Git比其他版本控制系统设计的优秀?因为git跟踪管理的是文件的修改,而非文件。

小结:每次修改,如果不add到暂存区,那就不会加入到commit

  • git diff HEAD -- readme.txt 查看工作去和版本库里面最新版本的区别

撤销修改

  • git checkout -- readme.txt 当修改了工作区的某个文件的内容,想直接丢弃工作区的修改时使用。
  • git reset HEAD readme.txt 当修改了工作区的某个文件内容并且添加到了暂存区,使用该命令就可以回到添加暂存区之前,然后使用第一个命令就可以撤销修改。
  • 如果已经把修改commit,想要撤销修改,可以进行版本回退,前提是没有提交远程仓库。

删除文件

  • 在工作区删除了一个已经提交到仓库的文件,可能有两种情况:

  • 误删,这时候就要工作区和版本库就不一致了,可以把误删的文件恢复

**`git checkout -- test.txt`** 用版本库里面的版本替换工作区的版本,一键还原
  • 真的想删除该文件

    git rm test.txt

    git commit -m "remove test.txt"

命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容


分支管理

使用情景:

​ 假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工作。

分支的切换时使用HEAD指针,所以git切换分支速度很快。


创建与合并分支

  • git branch 查看分支
  • git branch <name> 创建分支
  • git checkout <name> 切换分支
  • git checkout -b <name> 创建+切换分支
  • git merge <name> 合并某分支到当前分支
  • git branch -d <name> 删除分支

解决冲突

当两个分支修改了文件的同一个地方并且都分别有了新的提交,在这种情况下,Git无法执行“快速合并”,只能试图把新的提交合并起来,这样就可能造成冲突。我们必须手动解决冲突之后再提交,git status 也可以查看冲突的文件

PS D:\learngit> git status
On branch master
You have unmerged paths.
  (fix conflicts and run "git commit")

Unmerged paths:
  (use "git add <file>..." to mark resolution)

        both modified:   readme.txt

no changes added to commit (use "git add" and/or "git commit -a")

也可以直接查看源文件

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.
Creating a new branch is quick AND simple.
  • 查看分支合并图
PS D:\learngit> git log --graph --pretty=oneline --abbrev-commit
*   2b7d8c2 conflict fixed
|\
| * f8cde07 AND simple
* | ec07ee4 & simple
|/
* 0057b61 branch test
* 5fc1cd2 remove test.txt
* e1161a9 add a test file

分支策略

在实际开发中,我们应该按照几个基本原则进行分支管理:

首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;

那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;

你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

所以,团队合作的分支看起来就像这样:

git-br-policy
git-br-policy
  • 合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。

Bug分支

修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除;

当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug,修复后,再git stash pop,回到工作现场。

Feature分支

当需要开发一个新功能的时候,最好开一个Feature分支进行开发。在上面开发完成,合并,最后删除Feature分支。

  • git branch -D name丢弃一个没有被合并过的分支

多人协作

  • git remote 查看远程库的信息
  • git remote -v 显示更详细的信息
推送分支

把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上

  • git push origin master
  • git push origin dev
抓取分支
  • git pull 把最新的提交从仓库中抓取下来

多人协作的工作模式:

  1. 首先,可以试图用git push origin branch-name推送自己的修改;
  2. 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
  3. 如果合并有冲突,则解决冲突,并在本地提交;
  4. 没有冲突或者解决掉冲突后,再用git push origin branch-name推送就能成功!

如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream branch-name origin/branch-name


标签管理(tag)

用来为发布的正式版打上版本号

  • git tag v1.0 在master分支上打tag,默认tag是打在最新提交的commit上。
  • git tag v0.8 commit id 如果忘了打标签,可以使用commit id找到历史提交,再去打标签。
  PS D:\learngit> git tag v0.9 ac3f8e4
  PS D:\learngit> git tag
  v0.8
  v1.0
  • git show v0.9查看标签信息
  • git tag -a v0.1 -m "version 0.1 released" 67ae9c9 创建一个带有说明的标签
  • 命令git push origin <tagname>可以推送一个本地标签;
  • 命令git push origin --tags可以推送全部未推送过的本地标签;
  • 命令git tag -d <tagname>可以删除一个本地标签;
  • 命令git push origin :refs/tags/<tagname>可以删除一个远程标签。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • Git是目前最流行的版本管理系统,也是最先进的分布式版本控制系统(distributed version cont...
    pro648阅读 5,587评论 1 17
  • 写react也快半年了,讲一下自己对于生命周期的理解及各个生命周期的作用 首先,看一下一个组件的构造 当然前段时间...
    Evan_zhan阅读 68,594评论 6 51
  • 我自己得过重度抑郁。成为心理咨询师后,我又接触了很多抑郁症患者。我发现,得抑郁症的人似乎有一些共同点,其中最主要的...
    心理师静怡阅读 5,777评论 4 3
  • 一个小男孩,在海边玩儿,他正醉心于他的沙堡, 却隐约听见一个声音从边上的水塘传来,显然,这个水塘是因为大海涨...
    黎瀞文阅读 647评论 0 0
  • 身为一名女性,打从第一次知道“月经”,并被一种来自腹部的深切疼痛包裹起来的时候,我那还未完整的人生观险些崩塌掉。 ...
    九月星辰阅读 302评论 0 0