赞
踩
$ git checkout -b dev
Switched to a new branch 'dev'
git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:
$ git branch dev
$ git checkout dev
Switched to branch 'dev'
例如在原来的master分支上进行了修改,并不提交,然后使用git checkout -b lab1
命令可以创建并切换到lab1
分支,然后将修改进行commit,然后执行git push origin lab1
就可以看到修改的提交到了lab1
分支了,原来的master分支没有修改。
用git branch命令查看当前分支【本地分支】:
$ git branch
* dev
master
使用git branch -r
查看对应的【】远程分支】:
$ git branch -r
origin/local-v2.0
这是会看到master和dev,而且dev上会有一个星号,这个时候dev是一个本地分支,远程仓库不知道它的存在。
本地分支可以不同步到远程仓库,我们可以在dev开发,然后merge到master,使用master同步代码,当然也可以同步
git branch --all
# 默认只有master分支,所以会看到如下两个分支
# master[本地主分支]
# origin/master[远程主分支]
# 新克隆下来的代码默认master和origin/master是关联的,也就是他们的代码保持同步
从远端拉取分支,并切换
$ git checkout -b springboot origin/springboot
Switched to a new branch 'springboot'
Branch 'springboot' set up to track remote branch 'springboot' from 'origin'.
如果出现如果出现fatal: Cannot update paths and switch to branch 'dev2' at the same time. Did you intend to checkout 'origin/dev2' which can not be resolved as commit?
表示拉取不成功。我们需要先执行
git fetch
然后再执行
git checkout -b 本地分支名 origin/远程分支名
即可。
$ git checkout master
Switched to branch 'master'
发布到远端分支
git push origin dev # 这样远程仓库也有一个dev分支了
git push origin 远端分支名
发布dev分支指的是同步dev分支的代码到远程服务器
git checkout dev # 切换到dev分支进行开发
# 开发代码之后,我们有两个选择
# 第一个:如果功能开发完成了,可以合并主分支
git checkout master # 切换到主分支
git merge dev # 把dev分支的更改和master合并
git push # 提交主分支代码远程
git checkout dev # 切换到dev远程分支
git push # 提交dev分支到远程
# 第二个:如果功能没有完成,可以直接推送
git push # 提交到dev远程分支
# 注意:在分支切换之前最好先commit全部的改变,除非你真的知道自己在做什么
我们用git branch -r
查看远程分支,查看到有两个分支local-v2.0
和master
,我们想删除master
分支。
# origin 表示远程仓库的别名
git push origin --delete master
使用命令git remote -v
可以查看到远程仓库:
old-origin http://192.168.1.100:81/user1/shenzhen.git (fetch)
old-origin http://192.168.1.100:81/user1/shenzhen.git (push)
origin http://192.168.1.101/user1/shenzhen.git (fetch)
origin http://192.168.1.101/user1/shenzhen.git (push)
我们想删除origin
对应的仓库地址,使用命令:
git remote remove origin
这样再通过git remote -v
查看仓库:
old-origin http://192.168.1.100:81/user1/shenzhen.git (fetch)
old-origin http://192.168.1.100:81/user1/shenzhen.git (push)
git branch -m old_branch new_branch # Rename branch locally
git push origin :old_branch # Delete the old branch
git push --set-upstream origin new_branch # Push the new branch, set local branch to track the new remote
git解决每次拉取代码都需要用户名密码。
在命令行里执行git config --global credential.helper store
,这会在gitconfig目录下创建一个文件,用于记录账号和密码;
再执行一次git pull
,输入正确的账号密码,以后就不用再输了
$ git remote -v
origin http://192.168.152.39/duandingyang/shenzhen.git (fetch)
origin http://192.168.152.39/duandingyang/shenzhen.git (push)
git remote add origin https://github.com/vincentduan/selfweixin.git
其中origin
就是为远端仓库所起的名字,一般叫做origin
,其实你也可以叫做jack
或者Rose
什么的,后面的https://github.com/vincentduan/selfweixin.git
就是你的远端仓库的真实地址。
由于当前项目已经有一个远端分支,根据需要需要添加另一个远端分支。
首先需要在远端创建一个仓库:test-python
。
需要注意的是,添加一个远端分支名字不能是origin。
git remote add remote_iie4bu http://IP:81/test/test-python.git
然后查看,可以看到有两个远端分支:
$ git remote -v
origin https://gitee.com/jack/test-python.git (fetch)
origin https://gitee.com/jack/test-python.git (push)
remote_iie4bu http://IP:81/jack/test-python.git (fetch)
remote_iie4bu http://IP:81/jack/test-python.git (push)
使用git push remote_iie4bu 本地分支名
就可以推送到远端分支remote_iie4bu
了
使用git pull remote_iie4bu 本地分支名
就可以将远端分支拉取到本地了
git pull
使用说明
git pull命令用于从另一个存储库或本地分支获取并集成(整合)。git pull命令的作用是:取回远程主机某个分支的更新,再与本地的指定分支合并,它的完整格式稍稍有点复杂。
使用语法
git pull [options] [<repository> [<refspec>…]]
描述
将远程存储库中的更改合并到当前分支中。在默认模式下,git pull是git fetch后跟git merge FETCH_HEAD的缩写。
更准确地说,git pull使用给定的参数运行git fetch,并调用git merge将检索到的分支头合并到当前分支中。 使用–rebase,它运行git rebase而不是git merge。
示例
以下是一些示例 -
$ git pull <远程主机名> <远程分支名>:<本地分支名>
比如,要取回origin主机的next分支,与本地的master分支合并,需要写成下面这样 -
$ git pull origin next:master
如果远程分支(next)要与当前分支合并,则冒号后面的部分可以省略。上面命令可以简写为:
$ git pull origin next
上面命令表示,取回origin/next分支,再与当前分支合并。实质上,这等同于先做git fetch,再执行git merge。
$ git fetch origin
$ git merge origin/next
在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如,在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”origin/master分支。
Git也允许手动建立追踪关系。
$ git branch --set-upstream master origin/next
上面命令指定master分支追踪origin/next分支。
如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名。
$ git pull origin
上面命令表示,本地的当前分支自动与对应的origin主机”追踪分支”(remote-tracking branch)进行合并。
如果当前分支只有一个追踪分支,连远程主机名都可以省略。
$ git pull
上面命令表示,当前分支自动与唯一一个追踪分支进行合并。
如果合并需要采用rebase模式,可以使用–rebase选项。
$ git pull --rebase <远程主机名> <远程分支名>:<本地分支名>
git fetch和git pull的区别
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
git pull origin master
上述命令其实相当于git fetch 和 git merge
在实际使用中,git fetch更安全一些,因为在merge前,我们可以查看更新情况,然后再决定是否合并。
git reset
git reset就是当我们提交了错误的内容后进行回退使用的命令。
git reset 版本号,就是回退到该版本号上。
git reset --hard
命令可以把本地的所有修改都进行撤销。慎用!
使用 sparse clone 实现部分代码的拉取
假设我的项目目录是:
--my_project
--proj1
--proj2
--proj3
--proj4
现在我只想在服务器上拉取 proj2
目录下的东西。
$ mkdir my_project $ cd my_project $ git init Initialized empty Git repository in /home/user1/lib/username/.git/ $ git remote add -f origin http://xxx/user_name/my_project.git #拉取remote的all objects信息 Updating origin remote: Counting objects: 1141, done. remote: Compressing objects: 100% (591/591), done. remote: Total 1141 (delta 659), reused 871 (delta 491) Receiving objects: 100% (1141/1141), 2.65 MiB | 10.07 MiB/s, done. Resolving deltas: 100% (659/659), done. From http://xxx/user_name/my_project * [new branch] local-v2.0 -> origin/local-v2.0 $ git config core.sparsecheckout true #开启sparse clone # 默认没有sparse-checkout文件 $ echo "proj2" >> .git/info/sparse-checkout #设置需要pull的目录,*表示所有,!表示匹配相反的 $ less .git/info/sparse-checkout proj2 $ git pull origin local-v2.0 #拉取 $ ls proj2
假如还想要拉取其他文件或者目录的话,可以通过 git sparse-checkout add
命令来添加。
这就实现了,远程仓库和云服务器仓库之间的定制化同步,需要什么目录和文件就同步什么目录和文件,不需要的可以统统不要。
git sparse-checkout disable
表示禁用 git sparse-checkout
。git sparse-checkout reapply
表示重新启用git sparse-checkout
当前远程分支情况如下:
$ git remote -v
gitee https://gitee.com/jack/proj_1.git (fetch)
gitee https://gitee.com/jack/proj_1.git (push)
origin http://my_ip/rose/proj_1.git (fetch)
origin http://my_ip/rose/proj_1.git (push)
我们输入git push
时,默认会推送到origin
对应的http://my_ip/rose/proj_1.git
路径下。我们希望的是,输入git push
可以推送到https://gitee.com/jack/proj_1.git
下。
git remote set-url origin https://gitee.com/jack/proj_1.git
将origin
连接到https://gitee.com/jack/proj_1.git
下。这样我们输入git remote -v
得到:$ git remote -v
gitee https://gitee.com/jack/proj_1.git (fetch)
gitee https://gitee.com/jack/proj_1.git (push)
origin https://gitee.com/jack/proj_1.git (fetch)
origin https://gitee.com/jack/proj_1.git (push)
这将更改origin
的URL,使其指向我想要提交的远程存储库。现在,当您运行git push
命令时,它将默认将更改推送到https://gitee.com/jack/proj_1.git
。
gitee
删除:git remote remove gitee
。输出如下:origin https://gitee.com/jack/proj_1.git (fetch)
origin https://gitee.com/jack/proj_1.git (push)
git remote add my_remote http://my_ip/rose/proj_1.git
。输入命令git remote -v
my_remote http://my_ip/rose/proj_1.git (fetch)
my_remote http://my_ip/rose/proj_1.git (push)
origin https://gitee.com/jack/proj_1.git (fetch)
origin https://gitee.com/jack/proj_1.git (push)
需求:
目前我们有一个项目从
http://192.168.1.100/proj1.git
拉取的。
我们想要把这个项目迁移到http://192.168.1.101/proj1.git
上。
执行命令:
cd proj1
git remote rename origin old-origin
git remote add origin http://192.168.1.101/proj1.git
git push --set-upstream origin --all
git push --set-upstream origin --tags
git push --set-upstream origin --all
这个命令的含义是将本地的所有分支推送到远程仓库,并且设置这些分支的上游分支(upstream branch)为远程仓库的同名分支。这通常用于首次将本地仓库的分支与远程仓库进行关联,以后可以使用简化的 git push
命令来推送更改而不需要再指定远程分支。
具体解释如下:
git push
: 这是用于将本地更改推送到远程仓库的 Git 命令。--set-upstream
: 这个选项告诉 Git 在推送时设置本地分支与远程分支之间的关联。origin
: 这是远程仓库的名称,通常情况下,“origin” 是默认的远程仓库名称,代表了你的代码托管服务(如 GitHub、GitLab、Bitbucket)上的仓库。--all
: 这个选项告诉 Git 推送所有本地分支到远程仓库。因此,当你运行这个命令后,Git 会将所有本地分支的更改推送到远程仓库,并且为每个本地分支设置相应的上游分支,以后你可以使用 git push
来推送更改,Git 将自动知道要将更改推送到哪个远程分支。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。