Git

本文参考廖雪峰的官方网站之《Git教程》,请勿用于商业用途!


  • 创建版本库:

  • 初始化一个Git仓库,使用git init命令;

  • 添加文件到Git仓库,分两步:
    第一步,使用命令git add <file>,注意,可反复多次使用,添加多个文件;
    第二部,使用命令git commit,完成。

  • 时光机穿梭(查看状态、修改):

  • 要随时掌握工作区的状态,使用git status命令;

  • 如果git status告诉你由文件被修改过,用git diff可以查看修改内容。

  • 版本回退:

  • HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id

  • 穿梭前,用git log可以查看提交历史,以便确定要回退到那个版本;

  • 要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本;

  • 工作区和暂存区

工作区和暂存区
  • 管理修改:

  • 提交后,用git diff HEAD -- <file>可以查看工作区和版本库里最新版本的区别;

  • 每次修改,如果不add到暂存区,那就不会加入到commit中。

  • 撤销修改:

  • 当你该乱了工作区某个文件的内容,像直接丢弃工作区的修改时,用命令git checkout -- <file>

  • 当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了前一种状况,第二步按前一种状况操作;

  • 当你已经提交了不合适的修改到版本库时,想要撤销本次提交,参考“版本回退”一节,不过前提时没有推送到远程库。

  • 删除文件:

  • rm <file>删除文件;

  • 如果文件被add过,此时工作区和版本库就不一致了,git status命令会告诉你哪些文件被删除了,如果:

    • 你确实要从版本库中删除该文件,那就用命令git rm <file>删掉,并且git commit
    • 另一种情况是你删错了,可以通过git checkout -- <file>命令把误删的文件恢复到最新版本。
  • git checkout -- <file>其实使用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原“。

  • 远程仓库

  • 创建SSH Key:

     $ ssh-keygen -t rsa -C "email@xxx.com"
    
  • 添加远程库:

  • 要关联一个远程库,使用命令git remote add origin git@gitname:xxx/xxx.git

  • 关联后,使用命令git push -u origin master第一次推送master分支的所有内容;

  • 此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;

  • 从远程库克隆

  • 新建一个远程库,下一步使用命令git clone克隆一个本地库:

$ git clone git@github.com:xxxx/xxx.git
  • 分支管理

  • 创建与合并分支:

  • 查看分支:git branch

  • 创建分支:git branch <name>

  • 切换分支:git checkout <name>

  • 创建+切换分支:git checkout -b <name>

  • 合并某分支到当前分支:git merge <name>

  • 删除分支:git branch -d <name>

  • 解决冲突:

  • 文件存在冲突时,必须手动解决冲突后在提交;

  • Git用如下形式标记处不同分支的内容:

<<<<<<< HEAD
Creating a new branch is quick & simple.
=======
Creating a new branch is quick AND simple.
>>>>>>> branch1

修改如下后保存并提交:

Creating a new branch is quick and simple.

现在,master分支和featurel分支变成了下图所示:

冲突合并

  • git log --graph命令可以看到分支合并图。

  • 分支管理策略:
    通常,合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分之后,会丢掉分支信息。

  • 合并分支时,使用--no-ff参数,表示禁用Fast forward
    (例)

$ git merge --no-ff -m "merge with no-ff" dev
Merge made by the 'recursive' strategy.
  readme.txt |    1 +
  1 file changed, 1 insertion(+)

因为本次合并要创建一个新的commit,所以加上-m参数,把commit描述写进去。

  • 合并后,可以用git log查看分支历史:
    (例)

    ```git log```查看分支

    可以看到,不使用Fast forward模式,merge后就像这样:
    不使用```Fast forward```模式的merge

  • 而团队合作的分支看起来就像这样:


    团队合作的分支
  • 标签管理:

  • 标签(tag)就是一个让人容易记住的有意义的名字,它跟某个commit绑在一起。

  • 创建标签:

  • 命令git tag <name>用于新建一个标签,默认为HEAD,也可以指定一个commit id;

  • git tag -a <tagname> -m "blablabla..."可以指定标签信息;

  • git tag -s <tagname> -m "blablabla..."可以用PGP签名标签;

  • 命令git tag可以查看所有标签。

  • 操作标签:

  • 命令git push origin <tagname>可以推送一个本地标签;

  • 命令git push origin --tags可以推送全部未推送过的本地标签;

  • 命令git tag -d <tagname>可以删除一个本地标签;

  • 命令git push origin :regs/tags/<tagname>可以删除一个远程标签。

  • 使用GITHub

  • 在GitHub上,可以任意Fork开源仓库;

  • 自己拥有Fork后的仓库的读写权限;

  • 可以推送pull request给官方仓库来贡献代码。

  • 自定义Git:

  • 忽略特殊文件

  • 配置别名:

  • st —> status

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

推荐阅读更多精彩内容