git 更新远程代码到本地仓库(一)

2016-3-3 杜世伟 git

当多个人共同开发一个项目的时候,有时候我们需要从服务器上更新别人提交的最新代码!今天我们看下如何从远程Git仓库获取更新到本地,我们可以尝试以下方式进行远程代码更新到本地。

1)首先查看远程分支,通过如下命令可以查看远程仓库(我这里有一个origin仓库)
#git remote -v
origin http://ops-gitlab.***.net/test.git (fetch)
origin http://ops-gitlab.***.net/test.git (push)
2)接来下从远程获取最新代码到本地(我们通过使用如下命令在本地创建一个temp临时分支并将远程origin仓库中master分支的代码下载到本地临时temp分支中:
#git fetch origin master:temp
remote: Counting objects: 18, done.
remote: Compressing objects: 100% (6/6), done.
remote: Total 11 (delta 3), reused 0 (delta 0)
Unpacking objects: 100% (11/11), done.
From ops-gitlab.***.net/test
 * [new branch]      master     -> temp
   c07bdc7..40f902d  master     -> origin/master

(注释:此处通过git fetch 方式更新远程代码,在实际使用中,git fetch更安全一些因为在merge前,我们可以查看更新情况然后再决定是否合并)

3)比较本地仓库与刚才的临时temp分支的代码,使用如下命令进行比较:
#git diff temp
diff --git a/README.md b/README.md
deleted file mode 100644
index 76699ed..0000000
--- a/README.md
+++ /dev/null
@@ -1,6
+0,0
@@
-test
-==========
-
。。。
4)合并temp分支到本地的master分支:
#git merge temp
Updating c07bdc7..40f902d
Fast-forward
 README.md                                                  | 6 ++++++
 test/test.php | 4 ++--
 2 files changed, 8 insertions(+), 2 deletions(-)
 create mode 100644 README.md

 5)删除刚才创建的临时分支:
 #git branch -d temp
 Deleted branch temp (was 40f902d).

 如果删除该临时temp分支的时候代码之前没有merge到本地,那么删除该分支的时候会报错,可以通过使用

#git branch -D temp强制删除该分支


 通过以上操作步骤,我们可以顺利的把远程仓库的代码更新到本地了。不过还有其他的更新方式,慢慢尝试!!!
 通过罗马的大路不止一条,解决问题的方法不止一种!
 发现问题解决问题,更好的成就自己!!!

标签: linux git pull fetch

Powered by emlog 沪ICP备2023034538号-1