集中化的版本控制系統( Centralized Version Control Systems,簡稱 CVCS )。這類系統,諸如 CVS,Subversion 以及 Perforce 等,都有一個單一的集中管理的服務器,保存所有文件的修訂版本,而協同工作的人們都通過客戶端連到這臺服務器,取出最新的文件或者提交更新。多年以來,這已成為版本控制系統的標準做法。
分布式版本控制系統( Distributed Version Control System,簡稱 DVCS )。在這類系統中,像 Git,Mercurial,Bazaar 以及 Darcs 等,客戶端并不只提取最新版本的文件快照,而是把代碼倉庫完整地鏡像下來。這么一來,任何一處協同工作用的服務器發生故障,事后都可以用任何一個鏡像出來的本地倉庫恢復。因為每一次的提取操作,實際上都是一次對代碼倉庫的完整備份。
GitHub是一個用于使用Git版本控制系統的項目的基于互聯網的存取服務。它是由GitHub公司(先前被稱作用Logical Awesome)的開發者Chris Wanstrath, PJ Hyett, 和 Tom Preston-Werner 使用Ruby on Rails寫成的。GitHub同時提供商業賬戶和為開源項目提供的免費賬戶。根據在2009年的Git用戶調查,GitHub是最流行的Git存取站點。
它提供了像 feeds,followers 和顯示開發者們怎樣在他們的版本庫的版本上工作的網絡圖表。簡單來說,git是一個版本控制工具,github是一個用git做版本控制的項目托管平臺。
現在介紹下詳細步驟:
1、git安裝
這里介紹圖形化安裝方式,下載地址(http://git-scm.com/download)
下載后打開.dmg,雙擊.pkg文件即可完成安裝。
終端下可用which git(查看git的安裝目錄)和git --version(查看git的安裝版本)測試是否安裝成功。
如果顯示 ?/usr/bin/git ? 或者 ? ?git version 2.3.2 (Apple Git-55) 說明安裝成功。
2、git本地倉庫使用
? ?1)cd到你本地的工程根目錄
? ?2)$git init?初始git使用環境,當前目錄下會創建一個.git目錄。
?我這是之前init過了,所以會提示reinit。
? ?3)$?git add .?添加當前目錄的所有文件到版本庫,把文件添加到git本地管理目錄中,這類似Svn的add操作,實際上,還沒有提交到本地管理倉庫,通過$ git status可以查看狀態
? ?4)$?git commit -m '你的注釋說明'?這樣就把文件提交到本地倉庫
?當然,你可以再運行$ git status,看一下,還有沒有沒提交的代碼。現在本地倉庫的提交已完成,下節會講到如何把本地倉庫和遠程Github倉庫相關聯。
3、git遠程倉庫使用
? ? 先注冊github賬號,由于你的本地Git倉庫和github倉庫之間的傳輸是通過SSH加密的,所以需要一點設置:
?1)創建SSH Key
? ? ? ?1、在用戶主目錄下,看看有沒有.ssh目錄?
$ cd ~/.ssh
? ? ? ?2、如果有,再看看這個目錄下有沒有id_rsa和id_rsa.pub這兩個文件,則直接跳過下面一步
$ ls
? ? ? ? 3、如果沒有的話,打開命令行,輸入如下命令:
$ ssh -keygen -t rsa –C “xxxx@email.com”
這里的xxxx@email.com就是你注冊github時的郵箱地址,比如我的是 645880027@qq.com
?然后一直回車
如果要修改ssh生成目錄,在粗體位置處輸入要生成的路徑,選擇默認的話,會生成在 ~/.ssh下
?2)在github上添加ssh
1、登陸github,選擇Account Settings-->SSH ?Keys 添加ssh
? ? ? ? Title:xxxxx@gmail.com
? ? ? ? Key:打開你生成的id_rsa.pub文件,將其中內容拷貝至此
找不到id_rsa.pub的話就將你剛才的位置,也就是/Users/tangaofeng/.ssh/id_rsa.pub,通過文本編輯器打開id_rsa.pub
? ? ? 2、打開終端,先測試一下你的帳號跟github連上沒有:
$ ssh -T git@github.com
? ? ? ?如果出現如下提示,表示你連已經連上了.(因為有了第一步,所以不用自己做過多的連接github的操作了,另外,下一次要連接github的時候記得打開第一步的工具).? ??
? ? ? ?Hi gaofengtan! You've successfully authenticated, but GitHub does not provide shell access.
3)接下來就可以上傳你的代碼了,在github下建自己的Repository。添加一個遠程庫Repository name:你自己建的工程的名字??
Repository name:你自己建的工程的名字
Description:對你上傳工程的一個簡單的描述
Public:選擇的是所有人都可見?
Private:可以設置你指定的人可見
?這里我們一般選擇的就是Public,根據自己需要你可以選擇Private
下面的Initialize this repository with a README: 就是給你的工程初始化一個README(工程的用法簡介之類的)的一個文件,這里我們不選,到后面自己創建。
?然后點擊Create repository到下個界面
4、關聯本地倉庫
目前,在GitHub上的這個test倉庫還是空的,GitHub告訴我們,可以從這個倉庫克隆出新的倉庫,也可以把一個已有的本地倉庫與之關聯,然后,把本地倉庫的內容推送到GitHub倉庫。
? ? 1)連接遠程倉庫并建了一個名叫:origin的別?
? ? ? ? $ git remote add origin https://github.com/gaofengtan/CABasicAnimation.git
? ? 2)將本地倉庫的東西提交到地址是origin的地址,master分支下
? ? ? ? $?git push -u origin master
? 到這里,整個工程就添加上去了,刷新一下github的頁面,如下圖,說明成功了
5、更新你的github工程
?用github客戶端來做這件事將是一件非常簡單的事情
1)首先下載github客戶端,點擊github右下角的Clone in Desktop
2)下載完成后安裝,安裝好之后點擊左上角的+
3)選擇你在github上已有的項目,clone到桌面
? ? 4)然后我向里面添加一張圖片
5)然后看看我的github客戶端點擊changes,就會發現新增了一個圖片,然后填上描述(比如我這里寫的是second commit和add picture)提交
6)然后就如圖點擊History就可以看到你的歷史提交記錄,這里我們會發現我剛才提交的也就是second commit后面有一個圓圈,這個的意思就是還沒有同步到github上去,點擊右上角的Sync,就可以同步了,這一步不要忘記,不然你在github上看不到你的更新,如圖
? ? ?7)然后刷新我們的工程主頁,就可以看到提交的更新了???
疑難問題分析和解決
1、如果輸入$ git remote add origingit@github.com:djqiang(github帳號名)/gitdemo(項目名).git
提示出錯信息:fatal: remote origin already exists.
????解決辦法如下:
????1、先輸入$ git remote rm origin
2、再輸入$ git remote add origingit@github.com:djqiang/gitdemo.git就不會報錯了!
????3、如果輸入$ git remote rm origin?還是報錯的話,error: Could not remove config section 'remote.origin'. 我們需要修改gitconfig文件的內容
??? 4、找到你的github的安裝路徑,我的是C:\Users\ASUS\AppData\Local\GitHub\PortableGit_ca477551eeb4aea0e4ae9fcd3358bd96720bb5c8\etc
5、找到一個名為gitconfig的文件,打開它把里面的[remote "origin"]那一行刪掉就好了!
2、如果輸入$ ssh -Tgit@github.com
?出現錯誤提示:Permission denied (publickey).因為新生成的key不能加入ssh就會導致連接不上github。
??? 解決辦法如下:
??? 1、先輸入$ ssh-agent,再輸入$ ssh-add ~/.ssh/id_key,這樣就可以了。
??? 2、如果還是不行的話,輸入ssh-add ~/.ssh/id_key 命令后出現報錯Could not open a connection to your authentication agent.解決方法是key用Git Gui的ssh工具生成,這樣生成的時候key就直接保存在ssh中了,不需要再ssh-add命令加入了,其它的user,token等配置都用命令行來做。
??? 3、最好檢查一下在你復制id_rsa.pub文件的內容時有沒有產生多余的空格或空行,有些編輯器會幫你添加這些的。
3、如果輸入$ git push origin master
?提示出錯信息:error:failed to push som refs to .......
??? 解決辦法如下:
??? 1、先輸入$ git pull origin master //先把遠程服務器github上面的文件拉下來
??? 2、再輸入$ git push origin master
??? 3、如果出現報錯 fatal: Couldn't find remote ref master或者fatal: 'origin' does not appear to be a git repository以及fatal: Could not read from remote repository.
4、則需要重新輸入$ git remote add origingit@github.com:djqiang/gitdemo.git
到這里,代碼就托管到github上了!