Git系列篇

Git基础三:对远程仓库的操作

2017-06-13  本文已影响73人  拙峰朽木

克隆远程仓库:git clone

我们先进入github上fork了个项目,然后获取clone地址,如果你已经配置好了公钥,你可以点击黄色区域切换成SHH地址clone

image.png

在终端中输入(先用HTTPS的地址) : git clone https://github.com/rongcheng2017/android-UniversalMusicPlayer.git

frc@frc:~/GitHub/study/GoodProjectForStudy$ git clone https://github.com/rongcheng2017/android-UniversalMusicPlayer.git
正克隆到 'android-UniversalMusicPlayer'...
remote: Counting objects: 3074, done.
remote: Total 3074 (delta 0), reused 0 (delta 0), pack-reused 3074
接收对象中: 100% (3074/3074), 7.62 MiB | 859.00 KiB/s, 完成.
处理 delta 中: 100% (1454/1454), 完成.

如果你不指定克隆到的文件夹名称,默认会使用你链接最后的项目名做文件夹名,如果你想自己命名:git cloen xxxx fileName就行了

frc@frc:~/GitHub/study/GoodProjectForStudy$ git clone https://github.com/rongcheng2017/android-UniversalMusicPlayer.git
正克隆到 'android-UniversalMusicPlayer'...
remote: Counting objects: 3074, done.
remote: Total 3074 (delta 0), reused 0 (delta 0), pack-reused 3074
接收对象中: 100% (3074/3074), 7.62 MiB | 859.00 KiB/s, 完成.
处理 delta 中: 100% (1454/1454), 完成.

然后你就会在你指定的目录下找到该克隆的目录。进去该目录,执行git status看看

frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git status
位于分支 master
您的分支与上游分支 'origin/master' 一致。
无文件要提交,干净的工作区

查看远程仓库 :git remote

如果我们想查看一个clone来的项目的远程仓库有哪些,该怎么办呢,git remote
还是以当前项目为例

frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git remote 
origin

它告诉我们的有个叫origin的远程仓库,origin一般是你clone地址的远程仓库。
那么难道还有其他的远程仓库?当然有,这就是git体现分布式的地方,团队开发的时候,你的搭档们的仓库也是你的远程仓库,当然这个之后再讲。
看一下我之前开发项目中的情况:

frc@frc:~/SRT/YXTrain_Android$ git remote
hezhen
origin
yjj

你会发现我有三个远程仓库,一个是clone的远程仓库,其他两个则是同事的远程仓库。
如果你觉得这样太简洁,想看他们远程仓库的地址:git remote -v

frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git remote -v
origin  https://github.com/rongcheng2017/android-UniversalMusicPlayer.git (fetch)
origin  https://github.com/rongcheng2017/android-UniversalMusicPlayer.git (push)

你会发现有2个地址,fetch ,push这个我们后面会用到,先有个印象。

如果我们想值查看某个仓库的详情可以使用:git remote show remote-name:

frc@frc:~/SRT/YXTrain_Android$ git remote show yjj
* 远程 yjj
  获取地址:git@git.oschina.net:yangjunjian/YXTrain_Android.git
  推送地址:git@git.oschina.net:yangjunjian/YXTrain_Android.git
  HEAD分支:master
  远程分支:
    hotfix           已跟踪
    hotfix_huawei6.0 已跟踪
    master           已跟踪
    temp             已跟踪
  为 'git push' 配置的本地引用:
    master 推送至 master (本地已过时)

添加远程仓库:git remote add remote-name pathUrl

之前看到我工作中的项目中有三个远程仓库,那么除了origin外其他两个是怎么添加的呢? git remote add remote-name pathUrl
我想在这个项目下添加我同事的远程仓库:

frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git remote add hz git@git.oschina.net:zhenheli/YXTrain_Android.git
frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git remote -v
hz  git@git.oschina.net:zhenheli/YXTrain_Android.git (fetch)
hz  git@git.oschina.net:zhenheli/YXTrain_Android.git (push)
origin  https://github.com/rongcheng2017/android-UniversalMusicPlayer.git (fetch)
origin  https://github.com/rongcheng2017/android-UniversalMusicPlayer.git (push)

通过git remote -v 可以看到我们添加成功了

删除远程仓库:git remote remove remote-name

看上面的hz仓库的远程地址,很明显是另外一个项目的仓库,所以我们要把hz移除。能添加肯定能移除:

rc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git remote
hz
origin
frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git remote remove hz
frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git remote
origin

通过git remote 可以看到只剩origin了,说明删除成功。

抓取远程仓库代码:git fetch remote-name

既然我们能从orgin上clone下代码,那么我们如何获取其他远程仓库的代码呢?
还记得我们给git remote -v时,会给每个仓库名对应了两个地址,一个是fetch ,一个是push的。所以我只需要 git fech 远程仓库名 就行了。

frc@frc:~/SRT/YXTrain_Android$ git remote
hezhen
origin
yjj
frc@frc:~/SRT/YXTrain_Android$ git fetch yjj
remote: Counting objects: 12, done.
remote: Compressing objects: 100% (9/9), done.
remote: Total 12 (delta 7), reused 0 (delta 0)
展开对象中: 100% (12/12), 完成.
来自 git.oschina.net:yangjunjian/YXTrain_Android
 * [新分支]            master           -> yjj/master

我们抓取下yjj这个远程仓库的代码,看看你与我们的有什么差异。
当然我们也可以fetch origin,因为你如果关注的是个三方的开源项目,该项目完全可能在你clone后更新,你可以通过fetch origin来保持同步更新。

推送到远程仓库:git push remote-name

既然可以抓取,就能推送。你可以把你本地的修改推送到远程仓库上,当然这中间如果是多人合作开发,肯定还有许多合并以及权限问题:

frc@frc:~/SRT/YXTrain_Android$ git push yjj
To git.oschina.net:yangjunjian/YXTrain_Android.git
 ! [rejected]          master -> master (non-fast-forward)
error: 无法推送一些引用到 'git@git.oschina.net:yangjunjian/YXTrain_Android.git'
提示:更新被拒绝,因为您当前分支的最新提交落后于其对应的远程分支。
提示:再次推送前,先与远程变更合并(如 'git pull ...')。详见
提示:'git push --help' 中的 'Note about fast-forwards' 小节。

你看我想将我在这项目上的更改推送到yjj的远程仓库就失败了。
但是如果推送到自己的项目就ok了(如果推送到origin上,可以不写origin)

frc@frc:~/SRT/YXSanKe_Android$ git push
Username for 'https://git.oschina.net': fengrongcheng
Password for 'https://fengrongcheng@git.oschina.net': 
对象计数中: 21, 完成.
Delta compression using up to 4 threads.
压缩对象中: 100% (18/18), 完成.
写入对象中: 100% (21/21), 1.74 KiB | 0 bytes/s, 完成.
Total 21 (delta 15), reused 0 (delta 0)
To https://git.oschina.net/yanxiu/YXSanKe_Android.git
   2ba646b..acc7e7a  master -> master

上一篇下一篇

猜你喜欢

热点阅读