目录
git pull <远程主机名> <远程分支名>:<本地分支名>
以码云平台,用户账号下命名为 HelloGitee
的仓库为例。对应的仓库地址为:https://gitee.com/用户个性地址/HelloGitee.git
GitHub地址
https://github.com/用户名/仓库名.git
git@github.com:用户名/仓库名.git
码云地址
https://gitee.com/用户名/仓库名.git
git@gitee.com:用户名/仓库名.git
方法1、先将项目clone到本地,修改后再push到码云的项目仓库
$ git clone https://gitee.com/用户个性地址/HelloGitee.git #将远程仓库克隆到本地
把代码添加到本地仓库后,接下来提交到远程仓库
$ git push origin master #将本地提交推送到远程仓库
方法2、本地初始化一个项目,设置远程仓库地址后再做push(前提是已经在码云建立HelloGitee仓库)
$ git init
$ git remote add origin https://gitee.com/用户个性地址/HelloGitee.git
$ git pull origin master
$ git push origin master
方法2进行代码拉取时候可能报 fatal: refusing to merge unrelated histories错误,因为两个根本不相干的 git 库,一个是本地库, 一个是远端库, 然后本地要去推送到远端, 远端觉得这个本地库跟自己不相干, 所以告知无法合并.解决方法:
$ git pull origin master --allow-unrelated-histories
后面加上 --allow-unrelated-histories
, 把两段不相干的 分支进行强行合并
git remote add——添加远程仓库
格式:git remote add [shortname] [url] shortname 为本地的版本库,url为远程仓库地址 git remote add origin git@github.com:github-book/git-tutorial.git Git 会自动将远程仓库的名称设置为 origin
git push——推送至远程仓库
git push的一般形式为 (注意 英文格式冒号":"的前面和后面没有空格)
git push <远程主机名> <本地分支名>:<远程主机分支名>
例如 git push origin master:refs/for/master ,即是将本地的master分支推送到远程主机origin上的对应master分支, origin 是远程主机名,第一个master是本地分支名,第二个master是远程分支名。
refs/for/mybranch需要经过code review之后才可以提交;
refs/heads/mybranch不需要code review。
git push origin master
将本地的master
分支推送到origin
主机的master
分支。如果master
不存在,则会被新建。
git push origin :master
如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。
$ git push origin :master
# 等同于
$ git push origin --delete master
git push origin
将当前分支推送到origin
主机的对应分支。如果当前分支只有一个追踪分支,那么主机名都可以省略。$ git push
git push -u origin master
将本地的master
分支推送到origin
主机,同时指定origin
为默认主机,后面就可以不加任何参数使用git push
了。
不带任何参数的git push
,默认只推送当前分支,这叫做simple
方式。
git push --all origin
将所有本地分支都推送到origin
主机。
$ git push origin HEAD
将当前分支推送到远程的同名的简单方法
git push origin HEAD:master
将当前分支推送到源存储库中的远程引用匹配主机。 这种形式方便推送当前分支,而不考虑其本地名称。如下
将当前的feature-a分支推送到master2分支
git pull——获取最新的远程仓库分支
将远程存储库中的更改合并到当前分支中。在默认模式下,git pull = git fetch
+ git merge FETCH_HEAD
。
更准确地说,git pull
使用给定的参数运行git fetch
,并调用git merge
将检索到的分支头合并到当前分支中。 使用--rebase
,它运行git rebase
而不是git merge
。
git pull <远程主机名> <远程分支名>:<本地分支名>
git pull 的一般形式为 (注意 英文格式冒号":"的前面和后面没有空格)
git pull <远程主机名> <远程分支名>:<本地分支名>
要取回origin
主机的next
分支,与本地的master
分支合并,需要写成下面这样
$ git pull origin next:master
如果远程分支(next
)要与当前分支合并,则冒号后面的部分可以省略。上面命令可以简写为:
$ git pull origin next
在git clone
的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master
分支自动”追踪”origin/master
分支。Git也允许手动建立追踪关系。指定master
分支追踪origin/next
分支。
$ git branch --set-upstream master origin/next
如果当前分支与远程分支存在追踪关系,git pull
就可以省略远程分支名。
$ git pull origin
git fetch和git pull的区别
1. git fetch:相当于是从远程获取最新版本到本地,不会自动合并。
$ git fetch origin master
$ git log -p master..origin/master
$ git merge origin/master
- 首先从远程的
origin
的master
主分支下载最新的版本到origin/master
分支上 - 然后比较本地的
master
分支和origin/master
分支的差别 - 最后进行合并
上述过程其实可以用以下更清晰的方式来进行:
$ git fetch origin master:tmp
$ git diff tmp
$ git merge tmp
2. git pull:相当于是从远程获取最新版本并merge
到本地
git pull origin master
上述命令其实相当于git fetch
和 git merge
在实际使用中,git fetch
更安全一些,因为在merge
前,我们可以查看更新情况,然后再决定是否合并。
里面很多内容摘自《GitHub入门与实践》
git官方中文文档:https://git-scm.com/book/zh/v2
码云git大全:https://gitee.com/all-about-git