zoukankan      html  css  js  c++  java
  • Git远程操作详解

    https://git-scm.com/    官方网站           
    讲解博客 http://www.ruanyifeng.com/blog/2014/06/git_remote.html
    git:常用命令
    1、git clone 从远程服务器克隆版本库
          (1)生成目录与远程目录同名称
       $ git clone <版本库的网址>
       $ git clone https://github.com/jquery/jquery.git
    (2)生成目录与远程目录不同名称
       $ git clone <版本库的网址> <本地目录名>
      (3)git clone 支持多种协议 除了HTTP(s)以外,还支持SSH、Git、本地文件协议等,下面是一些例子。
          $ git clone http[s]://example.com/path/to/repo.git/
          $ git clone ssh://example.com/path/to/repo.git/
          $ git clone git://example.com/path/to/repo.git/
          $ git clone /opt/git/project.git 
          $ git clone file:///opt/git/project.git
          $ git clone ftp[s]://example.com/path/to/repo.git/
          $ git clone rsync://example.com/path/to/repo.git/
    SSH协议还有另一种写法。
          $ git clone [user@]example.com:path/to/repo.gi
         通常来说,Git协议下载速度最快,SSH协议用于需要用户认证的场合。各种协议优劣的详细讨论请参考官方文档
    (4)克隆版本库的时候,所使用的远程主机自动被Git命名为
    origin
    。如果想用其他的主机名,需要用git clone命令的-o选项指定。
           $ git clone -o jQuery https://github.com/jquery/jquery.git
           $ git remote
           jQuery       (命令表示,克隆的时候,指定远程主机叫做jQuery。)
    2、git remote 为了便于管理,Git要求每个远程主机都必须指定一个主机名。
    (1)
    git remote
    命令就用于管理主机名。
    带选项的时候,git remote命令列出所有远程主机。
             $ git remote
               origin
    (2)
    git remote -v
    选项,可以参看远程主机的网址。
             $ git remote -v
              origin  git@github.com:jquery/jquery.git (fetch)(只有一台远程主机,叫做origin,以及它的网址。)
              origin  git@github.com:jquery/jquery.git (push)
    (3)$ git remote show <主机名> 查看该主机的详细信息。
    (4)$ git remote add
    <主机名> <网址> 添加远程主机。
    (5)$ git remote rm <
    主机名> 删除主机名
         (6)$ git remote rename <原主机名> <新主机名>   重启名称   
    3、git fetch 一旦远程主机的版本库有了更新(Git术语叫做commit),需要将这些更新取回本地,这时就要用到
    git fetch
    命令。
    (1)
    $ git fetch <远程主机名>
    将某个远程主机的更新,取回所有分支(branch)的更新(默认情况)
    通常用来查看其他人的进程,因为它取回的代码对你本地的开发代码没有影响。
    (2)$ git fetch <远程主机名> <分支名> 取回特定分支的更新,指定分支名。($ git fetch origin master)
    (3)所取回的更新,在本地主机上要用"远程主机名/分支名"的形式读取。比如origin主机的master,就要用origin/master读取。
    (4)git branch命令的-r选项,可以用来查看远程分支,-a选项查看所有分支。
         $ git branch -r 可以用来查看远程分支,-a选项查看所有分支。
            $ git branch -r
              origin/master
            $ git branch -a
              * master (本地分支)
              remotes/origin/master(远程分支)
    (5)取回远程主机的更新以后,可以在它的基础上,使用git checkout命令创建一个新的分支。
            $ git checkout -b newBrach origin/master
    (6)此外,也可以使用
    git merge
    命令或者git rebase命令,在本地分支上合并远程分支。
         $ git merge origin/master
         # 或者
         $ git rebase origin/master
    4、git pull git pull命令的作用是,取回远程主机某个分支的更新,再与本地的指定分支合并。它的完整格式稍稍有点复杂。
         (1) $ git pull <远程主机名> <远程分支名>:<本地分支名>
           比如,取回origin主机的next分支,与本地的master分支合并,需要写成下面这样。  
             $ git pull orgin  next:master
    如果远程分支是与当前分支合并,则冒号后面的部分可以省略。
             $ git pull orgin next 
    上面命令表示,取回
    origin/next
    分支,再与当前分支合并。实质上,这等同于先做git fetch,再做git merge
    (2)在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如,在git clone的时候,
    所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动"追踪"origin/master分支。 
    Git也允许手动建立追踪关系。  git branch --set-upstream master origin/next (上面命令指定master分支追踪origin/next分支.)
         (3)如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名。
            $ git pull origin 就可以拉下来当前分支对应的远端分支内容
         上面命令表示,本地的当前分支自动与对应的origin主机"追踪分支"(remote-tracking branch)进行合并。
    (4)如果当前分支只有一个追踪分支,连远程主机名都可以省略。
           $ git pull 上面命令表示,当前分支自动与唯一一个追踪分支进行合并。
    (5)如果合并需要采用rebase模式,可以使用--rebase选项。
            $ git pull --rebase <远程主机名> <远程分支名>:<本地分支名>
            如果远程主机删除了某个分支,默认情况下,git pull 不会在拉取远程分支的时候,删除对应的本地分支。
    这是为了防止,由于其他人操作了远程主机,导致git pull不知不觉删除了本地分支。
    但是,你可以改变这个行为,加上参数 -p 就会在本地删除远程已经删除的分支。
              $ git pull -p
              # 等同于下面的命令
              $ git fetch --prune origin 
              $ git fetch -p
    5、git push 将本地分支的更新,推送到远端分支
              (1)$ git push <远程主机名> <本地分支名>:<远程分支名>
             git pull是<远程分支>:<本地分支>,而git push是<本地分支>:<远程分支>。
         $ git push orgin master:master
           (2)$ git push origin master 省略远程分支,直接推送到追踪分支,如果远程分支不存在会被重新创建
           (3)$ git push orgin 表示将当前分支推送到追踪关系的分支上
    (4)$ git push 当前分支只有一个追踪分支(所有远程主机中)
          如果当前分支与多个主机存在追踪关系,则可以使用
    -u
    选项指定一个默认主机,这样后面就可以不加任何参数使用git push
            $ git push -u origin master
    (5)不带任何参数的
    git push
    ,默认只推送当前分支,这叫做simple方式。此外,还有一种matching方式,会推送所有有
    对应的远程分支的本地分支。Git 2.0版本之前,默认采用matching方法,现在改为默认采用simple方式。
    如果要修改这个设置,可以采用git config命令
    $ git config --global push.default matching # 或者 $ git config --global push.default simple
    (6)还有一种情况,就是不管是否存在对应的远程分支,将本地的所有分支都推送到远程主机,这时需要使用
    --all选项。
    $ git push --all origin(上面命令表示,将所有本地分支都推送到origin主机。)
    (7)如果远程主机的版本比本地版本更新,推送时Git会报错,要求先在本地做
    git pull合并差异,然后再推送到远程主机。这时,如果你一定要推送,可以使用--force选项。
    $ git push --force origin (这种提交不会出现在分支图中)
    上面命令使用
    --force选项,结果导致远程主机上更新的版本被覆盖。除非你很确定要这样做,否则应该尽量避免使用--force选项。
    (7)最后,git push不会推送标签(tag),除非使用--tags选项。
            $ git push origin --tags
        (8)如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。        
           $ git push origin  :master (表示删除origin主机的master分支.)
           # 等同于
           $ git push origin --delete master

  • 相关阅读:
    Java实现 LeetCode 802 找到最终的安全状态 (DFS)
    Java实现 LeetCode 802 找到最终的安全状态 (DFS)
    Java实现 LeetCode 802 找到最终的安全状态 (DFS)
    Java实现 LeetCode 804 唯一摩尔斯密码词 (暴力)
    Java实现 LeetCode 803 打砖块 (DFS)
    Java实现 LeetCode 804 唯一摩尔斯密码词 (暴力)
    Java实现 LeetCode 803 打砖块 (DFS)
    Java实现 LeetCode 804 唯一摩尔斯密码词 (暴力)
    英文标点
    post sharp 与log4net 结合使用,含执行源码 转拷
  • 原文地址:https://www.cnblogs.com/shuaiandjun/p/6042606.html
Copyright © 2011-2022 走看看