克隆遠(yuǎn)程倉(cāng)庫(kù):git clone
我們先進(jìn)入github上fork了個(gè)項(xiàng)目挖息,然后獲取clone地址栖袋,如果你已經(jīng)配置好了公鑰独榴,你可以點(diǎn)擊黃色區(qū)域切換成SHH地址clone
在終端中輸入(先用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
接收對(duì)象中: 100% (3074/3074), 7.62 MiB | 859.00 KiB/s, 完成.
處理 delta 中: 100% (1454/1454), 完成.
如果你不指定克隆到的文件夾名稱谍失,默認(rèn)會(huì)使用你鏈接最后的項(xiàng)目名做文件夾名琼了,如果你想自己命名: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
接收對(duì)象中: 100% (3074/3074), 7.62 MiB | 859.00 KiB/s, 完成.
處理 delta 中: 100% (1454/1454), 完成.
然后你就會(huì)在你指定的目錄下找到該克隆的目錄谨究。進(jìn)去該目錄恩袱,執(zhí)行g(shù)it status看看
frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git status
位于分支 master
您的分支與上游分支 'origin/master' 一致。
無(wú)文件要提交胶哲,干凈的工作區(qū)
查看遠(yuǎn)程倉(cāng)庫(kù) :git remote
如果我們想查看一個(gè)clone來(lái)的項(xiàng)目的遠(yuǎn)程倉(cāng)庫(kù)有哪些畔塔,該怎么辦呢,git remote
還是以當(dāng)前項(xiàng)目為例
frc@frc:~/GitHub/study/GoodProjectForStudy/android-UniversalMusicPlayer$ git remote
origin
它告訴我們的有個(gè)叫origin的遠(yuǎn)程倉(cāng)庫(kù)鸯屿,origin一般是你clone地址的遠(yuǎn)程倉(cāng)庫(kù)澈吨。
那么難道還有其他的遠(yuǎn)程倉(cāng)庫(kù)?當(dāng)然有寄摆,這就是git體現(xiàn)分布式的地方谅辣,團(tuán)隊(duì)開(kāi)發(fā)的時(shí)候,你的搭檔們的倉(cāng)庫(kù)也是你的遠(yuǎn)程倉(cāng)庫(kù)婶恼,當(dāng)然這個(gè)之后再講屈藐。
看一下我之前開(kāi)發(fā)項(xiàng)目中的情況:
frc@frc:~/SRT/YXTrain_Android$ git remote
hezhen
origin
yjj
你會(huì)發(fā)現(xiàn)我有三個(gè)遠(yuǎn)程倉(cāng)庫(kù)榔组,一個(gè)是clone的遠(yuǎn)程倉(cāng)庫(kù),其他兩個(gè)則是同事的遠(yuǎn)程倉(cāng)庫(kù)联逻。
如果你覺(jué)得這樣太簡(jiǎn)潔搓扯,想看他們遠(yuǎn)程倉(cāng)庫(kù)的地址: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)
你會(huì)發(fā)現(xiàn)有2個(gè)地址,fetch 包归,push這個(gè)我們后面會(huì)用到锨推,先有個(gè)印象。
如果我們想值查看某個(gè)倉(cāng)庫(kù)的詳情可以使用:git remote show remote-name:
frc@frc:~/SRT/YXTrain_Android$ git remote show yjj
* 遠(yuǎn)程 yjj
獲取地址:git@git.oschina.net:yangjunjian/YXTrain_Android.git
推送地址:git@git.oschina.net:yangjunjian/YXTrain_Android.git
HEAD分支:master
遠(yuǎn)程分支:
hotfix 已跟蹤
hotfix_huawei6.0 已跟蹤
master 已跟蹤
temp 已跟蹤
為 'git push' 配置的本地引用:
master 推送至 master (本地已過(guò)時(shí))
添加遠(yuǎn)程倉(cāng)庫(kù):git remote add remote-name pathUrl
之前看到我工作中的項(xiàng)目中有三個(gè)遠(yuǎn)程倉(cāng)庫(kù)公壤,那么除了origin外其他兩個(gè)是怎么添加的呢换可? git remote add remote-name pathUrl
我想在這個(gè)項(xiàng)目下添加我同事的遠(yuǎn)程倉(cāng)庫(kù):
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)
通過(guò)git remote -v 可以看到我們添加成功了
刪除遠(yuǎn)程倉(cāng)庫(kù):git remote remove remote-name
看上面的hz倉(cāng)庫(kù)的遠(yuǎn)程地址,很明顯是另外一個(gè)項(xiàng)目的倉(cāng)庫(kù),所以我們要把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
通過(guò)git remote 可以看到只剩origin了沾鳄,說(shuō)明刪除成功。
抓取遠(yuǎn)程倉(cāng)庫(kù)代碼:git fetch remote-name
既然我們能從orgin上clone下代碼确憨,那么我們?nèi)绾潍@取其他遠(yuǎn)程倉(cāng)庫(kù)的代碼呢译荞?
還記得我們給git remote -v時(shí),會(huì)給每個(gè)倉(cāng)庫(kù)名對(duì)應(yīng)了兩個(gè)地址休弃,一個(gè)是fetch 吞歼,一個(gè)是push的。所以我只需要 git fech 遠(yuǎn)程倉(cāng)庫(kù)名 就行了塔猾。
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)
展開(kāi)對(duì)象中: 100% (12/12), 完成.
來(lái)自 git.oschina.net:yangjunjian/YXTrain_Android
* [新分支] master -> yjj/master
我們抓取下yjj這個(gè)遠(yuǎn)程倉(cāng)庫(kù)的代碼篙骡,看看你與我們的有什么差異。
當(dāng)然我們也可以fetch origin丈甸,因?yàn)槟闳绻P(guān)注的是個(gè)三方的開(kāi)源項(xiàng)目糯俗,該項(xiàng)目完全可能在你clone后更新,你可以通過(guò)fetch origin來(lái)保持同步更新睦擂。
推送到遠(yuǎn)程倉(cāng)庫(kù):git push remote-name
既然可以抓取得湘,就能推送。你可以把你本地的修改推送到遠(yuǎn)程倉(cāng)庫(kù)上祈匙,當(dāng)然這中間如果是多人合作開(kāi)發(fā)忽刽,肯定還有許多合并以及權(quán)限問(wèn)題:
frc@frc:~/SRT/YXTrain_Android$ git push yjj
To git.oschina.net:yangjunjian/YXTrain_Android.git
! [rejected] master -> master (non-fast-forward)
error: 無(wú)法推送一些引用到 'git@git.oschina.net:yangjunjian/YXTrain_Android.git'
提示:更新被拒絕,因?yàn)槟?dāng)前分支的最新提交落后于其對(duì)應(yīng)的遠(yuǎn)程分支夺欲。
提示:再次推送前跪帝,先與遠(yuǎn)程變更合并(如 'git pull ...')。詳見(jiàn)
提示:'git push --help' 中的 'Note about fast-forwards' 小節(jié)些阅。
你看我想將我在這項(xiàng)目上的更改推送到y(tǒng)jj的遠(yuǎn)程倉(cāng)庫(kù)就失敗了伞剑。
但是如果推送到自己的項(xiàng)目就ok了(如果推送到origin上,可以不寫(xiě)origin)
frc@frc:~/SRT/YXSanKe_Android$ git push
Username for 'https://git.oschina.net': fengrongcheng
Password for 'https://fengrongcheng@git.oschina.net':
對(duì)象計(jì)數(shù)中: 21, 完成.
Delta compression using up to 4 threads.
壓縮對(duì)象中: 100% (18/18), 完成.
寫(xiě)入對(duì)象中: 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