Git常用命令合集

1. 配置git全局账号信息

git 是分布式版本控制系统,因此每台机器都必须自报家门,也就是配置你的用户名和邮箱。

  • 配置用户名、邮箱
git config --global user.name "Your Name"
git config --global user.email "email@example.com"
  • 查看用户名、邮箱
git config user.name
git config user.email
  • 修改用户名、邮箱
git config --global --replace-all user.name "New Name"
git config --global --replace-all user.email "new@xx.com"

2. 创建版本库,提交修改到版本库

什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。

  • 通过git init 将这个目录变成Git可以管理的仓库

    git init

  • git add 命令告知git,把文件添加到本地仓库;

    // 1. 添加指定文件
    git add xxx.txt
    
    // 2. 添加所有修改文件
    git add .
  • git commit 命令告知git, 把文件提交到本地仓库。
    git commit -m "本次提交的说明"

3. 版本回退

当你不断对文件进行修改,然后不断提交修改到版本库里,就好比玩RPG游戏时,每通过一关就会自动把游戏状态存盘,如果某一关没过去,你还可以选择读取前一关的状态。有些时候,在打Boss之前,你会手动存盘,以便万一打Boss失败了,可以从最近的地方重新开始。

Git也是一样,每当你觉得文件修改到一定程度的时候,就可以“保存一个快照”,这个快照在Git中被称为commit。一旦你把文件改乱了,或者误删了文件,还可以从最近的一个commit恢复,然后继续工作,而不是把几个月的工作成果全部丢失。

  • 使用 git log 命令显示从最近到最远的提交日志
git-log.png

如果嫌输出信息太多,看得眼花缭乱的,可以试试加上 --pretty=oneline 参数。

  • 使用 git reset 命令回退到指令的版本
    // 第1种回退方式:
    // HEAD^表示上一个版本,HEAD^^表示上上一个版本,
    // HEAD~100表示上一百个版本
    git reset --hard HEAD^
    
    // 第2种回退方式:
    // 指定commit id 方式,commit id不需要写全,git 会自动匹配
    git reset --hard 109abd
  • Git提供 git reflog 命令来记录每一次Git操作命令
git-reflog.png

4. 撤销修改

  1. 当你把 工作区 的代码改乱了之后,想直接丢弃工作区的修改时,使用如下命令:

    git checkout -- readme.txt

  2. 当你把改乱的代码添加到 暂存区 之后,想要把暂存区的修改回退到工作区,使用如下命令:

    git reset HEAD readme.txt

    git reset 命令不仅可以回退版本,还可以把暂存区的修改回退到工作区。

  3. 如果已经提交到版本库,可以通过 版本回退 进行回滚,前提是没有提交到远程仓库。

5. 创建分支与合并分支

  • 创建分支,并切换到该分支

    1. git checkout -b dev
    2. 上述命令相当于执行了 git branch devgit checkout dev
    3. git branch : 列出所有分支,当前分支用 * 标记。
  • 合并分支

    1. git merge dev
    2. git merge 用于合并分支到当前分支;
    3. 合并完成后,可以删除dev分支(git branch -d dev)。

6. 解决冲突

  • 代码冲突的原因:

    1. 不同的分支中,同时提交了对相同文件的修改。
    2. 不同分支(不同的本地分支、本地与远程分支)。
  • 代码冲突的解决:

    1. 使用 git merge 命令进行合并,这种情况下Git无法执行快速合并,只能试图将各自的修改合并起来,但这种合并可能就存在冲突。

    2. 当出现冲突时(如下图所示),就需要我们手动解决冲突后在提交。


      git-merge-conflict.png
    3. Git用 <<<<<<<=======>>>>>>> 标记出不同分支的内容。

      git-merge-conflict-2.png

    4. 提交手动解决冲突后的代码。

  • 提示:出现冲突时 git status 也可以用于查看冲突原因。

7. 分支管理策略

通常,合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息。如果要强制禁用Fast forward模式,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息。

  • 禁用Fast forward模式进行分支合并
    git merge --no-ff -m "禁用快速模式合并信息" dev

  • 分支管理策略

    1. master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活。
    2. dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本。
    3. 你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

8. Bug分支

软件开发中,bug就像家常便饭一样。有了bug就需要修复,在Git中,由于分支是如此的强大,所以,每个bug都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除。

  • 当你正在dev分支干活时(工作只进行一半),突然要创建bug分支fix bug,但是创建并切换分支需要提交当前代码,而你又不想提交该怎么办???

    1. 使用 git stash 命令,将当前工作现场存储起来,等以后再恢复现场再继续工作。

      git-stash.png

    2. 切换到Bug分支进行bug 修复。

    3. 切换回dev分支,进行现场恢复。

      • 查看之前的工作现场,使用 git stash list 命令查看;

      • 使用 git stash apply stash@{0}恢复现场,stash内容并不删除,你需要用 git stash drop来删除;

      • 使用 git stash pop stash@{0} ,恢复的同时把stash内容也删了。

9. Feature分支

添加一个新功能时,你肯定不希望因为一些实验性质的代码,把主分支搞乱了,所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。

  • 开发一个新feature,最好新建一个分支;
  • 如果要丢弃一个没有被合并过的分支,可以通过 git branch -D <name> 强行删除。

10. 多人协作

当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin。

  • 查看远程分支信息

    1. git remote
    2. git remote -v 查看详细的远程分支信息
  • 推送分支,使用 git push origin 分支名

  • 抓取分支,使用 git pull origin 分支名

11. 忽略特殊文件

有些时候,你必须把某些文件放到Git工作目录中,但又不能提交它们,比如保存了数据库密码的配置文件啦,等等,每次git status都会显示Untracked files ...

这个问题解决起来也很简单,在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件。不需要从头写.gitignore文件,GitHub已经为我们准备了各种配置文件,只需要组合一下就可以使用了。
所有配置文件可以直接在线浏览:gitignore

相关文章:
Git教程

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容

  • 声明:这篇文章来源于廖雪峰老师的官方网站,我仅仅是作为学习之用 Git简介 Git是什么? Git是目前世界上最先...
    横渡阅读 3,948评论 3 27
  • Git 是目前最流行的分布式版本控制系统之一。 版本控制指的是,记录每次版本变更的内容和时间等细节,保留各版本之间...
    神齐阅读 1,412评论 0 7
  • 一:Git是什么? Git是目前世界上最先进的分布式版本控制系统。 二:SVN与Git的最主要的区别? SVN是集...
    Splendid飞羽阅读 317评论 0 0
  • 教程网址:http://www.liaoxuefeng.com/wiki/0013739516305929606d...
    maybenai阅读 683评论 0 1
  • 安装Git Git的下载地址:Git官网下载地址 Git本地仓库和命令 配置用户 下载完Git后,右键会有一个Gi...
    TokyoZ阅读 4,497评论 1 7