美文网首页
git常用命令

git常用命令

作者: fanderboy | 来源:发表于2019-12-31 11:48 被阅读0次

    1.git拉取远程分支,整理了五种方法,我常用最后一种,这五种方法(除了第4中已经写了fetch的步骤)执行前都需要执行git fetch来同步远程仓库

    (1)git checkout -b 本地分支名 origin/远程分支名

    (2)git checkout --track origin/远程分支名 (这种写法是上面的简化版,效果完全一样)

    (3)git checkout -t origin/远程分支名(这种写法是2的简化版)

    (4)fetch指定的一个分支:

              git fetch [repo] [remote_branch_name]:[local_branch_name]
              git checkout [local_branch_name]
    

    (第一行的:[local_branch_name]如果不写,则本地新建的分支名默认与远程分支名相同)

    (5)git fetch 获取远程所有分支

          git branch -r 可以看到所有远程分支,假设有一个分支叫origin/mybranch
    
          git checkout mybranch即可,会在本地新建一个同名分支,并与该远程分支关联
    
          (git checkout origin/mybranch 会进入detached head状态,不会在本地新建分支,不要这样写)
    

    2.创建新分支:git branch branchName
    切换到新分支:git checkout branchName
    然后,上面两个命令也可以合成为一个命令:
    git checkout -b branchName

    3.git add -A和 git add . git add -u在功能上看似很相近,但还是存在一点差别

    git add . :他会监控工作区的状态树,使用它会把工作时的所有变化提交到暂存区,包括文件内容修改(modified)以及新文件(new),但不包括被删除的文件。

    git add -u :他仅监控已经被add的文件(即tracked file),他会将被修改的文件提交到暂存区。add -u 不会提交新文件(untracked file)。(git add --update的缩写)

    git add -A :是上面两个功能的合集(git add --all的缩写)

    4.git push

    git push的一般形式为 git push <远程主机名> <本地分支名> <远程分支名> ,例如 git push origin master:refs/for/master ,即是将本地的master分支推送到远程主机origin上的对应master分支, origin 是远程主机名,第一个master是本地分支名,第二个master是远程分支名。
    (1)git push origin master
    如果远程分支被省略,如上则表示将本地分支推送到与之存在追踪关系的远程分支(通常两者同名),如果该远程分支不存在,则会被新建
    (2)git push origin :refs/for/master
    如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支,等同于 git push origin --delete master
    (3)git push origin
    如果当前分支与远程分支存在追踪关系,则本地分支和远程分支都可以省略,将当前分支推送到origin主机的对应分支
    (4)git push
    如果当前分支只有一个远程分支,那么主机名都可以省略,形如 git push,可以使用git branch -r ,查看远程的分支名
    (5) git push 的其他命令
    这几个常见的用法已足以满足我们日常开发的使用了,还有几个扩展的用法,如下:

    (5.1) git push -u origin master 如果当前分支与多个主机存在追踪关系,则可以使用 -u 参数指定一个默认主机,这样后面就可以不加任何参数使用git push,

    不带任何参数的git push,默认只推送当前分支,这叫做simple方式,还有一种matching方式,会推送所有有对应的远程分支的本地分支, Git 2.0之前默认使用matching,现在改为simple方式

    如果想更改设置,可以使用git config命令。git config --global push.default matching OR git config --global push.default simple;可以使用git config -l 查看配置

    (5.2) git push --all origin 当遇到这种情况就是不管是否存在对应的远程分支,将本地的所有分支都推送到远程主机,这时需要 -all 选项

    (5.3) git push --force origin git push的时候需要本地先git pull更新到跟服务器版本一致,如果本地版本库比远程服务器上的低,那么一般会提示你git pull更新,如果一定要提交,那么可以使用这个命令。

    (5.4) git push origin --tags //git push 的时候不会推送分支,如果一定要推送标签的话那么可以使用这个命令
    (6) 关于 refs/for
    // refs/for 的意义在于我们提交代码到服务器之后是需要经过code review 之后才能进行merge的,而refs/heads 不需要

    相关文章

      网友评论

          本文标题:git常用命令

          本文链接:https://www.haomeiwen.com/subject/ypsboctx.html