Git

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


  • 创建版本库:

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

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

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

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

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

  • 版本回退:

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

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

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

  • 工作区和暂存区

Git_第1张图片
工作区和暂存区
  • 管理修改:

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

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

  • 撤销修改:

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

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

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

  • 删除文件:

  • rm 删除文件;

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

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

  • 远程仓库

  • 创建SSH Key:

     $ ssh-keygen -t rsa -C "[email protected]"
    
  • 添加远程库:

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

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

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

  • 从远程库克隆

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

$ git clone [email protected]:xxxx/xxx.git
  • 分支管理

  • 创建与合并分支:

  • 查看分支:git branch

  • 创建分支:git branch

  • 切换分支:git checkout

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

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

  • 删除分支:git branch -d

  • 解决冲突:

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

  • 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_第2张图片
冲突合并

  • 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_第3张图片
    ```git log```查看分支

    可以看到,不使用Fast forward模式,merge后就像这样:
    Git_第4张图片
    不使用```Fast forward```模式的merge

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


    Git_第5张图片
    团队合作的分支
  • 标签管理:

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

  • 创建标签:

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

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

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

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

  • 操作标签:

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

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

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

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

  • 使用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 —> unstage
$ git config --global alias. unstage 'rest HEAD'
  • 搭建Git服务器

你可能感兴趣的:(Git)