文章出處

一、創建遠程倉庫(GitHub)

1.GitHub網站地址:https://github.com/,這個網站就是提供Git倉庫托管服務的,所以,只要注冊一個GitHub賬號,就可以免費獲得Git遠程倉庫。

2.由于本地Git倉庫和GitHub倉庫之間的傳輸是通過SSH加密的,所以,需要如下設置:

第1步:創建SSH Key。在用戶主目錄下(例如:C:\Users\Administrator\),看看有沒有.ssh目錄,如果有,再看看這個目錄下有沒有id_rsa和id_rsa.pub這兩個文件,如果已經有了,可直接跳到下一步。如果沒有,打開Shell(Windows下打開Git Bash),創建SSH Key:

$ ssh-keygen -t rsa -C "wheeky@163.com"

你需要把郵件地址換成你自己的郵件地址,然后一路回車,全部使用默認值即可;

如果一切順利的話,可以在用戶主目錄里找到.ssh目錄,里面有id_rsa和id_rsa.pub兩個文件,這兩個就是SSH Key的秘鑰對,id_rsa是私鑰,不能泄露出去,id_rsa.pub是公鑰,可以放心地告訴任何人。

第2步:登陸GitHub,打開“Account settings”,“SSH Keys”頁面,然后,點“Add SSH Key”,填上任意Title,在Key文本框里粘貼id_rsa.pub文件的內容,最后點擊“Add Key”按鈕完成。

說明:為什么GitHub需要SSH Key呢?因為GitHub需要識別出你推送的提交確實是你推送的,而不是別人冒充的,而Git支持SSH協議,所以,GitHub只要知道了你的公鑰,就可以確認只有你自己才能推送。當然,GitHub允許你添加多個Key。假定你有若干電腦,你一會兒在公司提交,一會兒在家里提交,只要把每臺電腦的Key都添加到GitHub,就可以在每臺電腦上往GitHub推送了。

二、添加遠程庫

1.登錄GitHub網站,并按網站要求創建一個新的倉庫;

2.根據GitHub網站提示,可以從這個倉庫克隆出新的倉庫,也可以把一個已有的本地倉庫與之關聯,然后,把本地倉庫的內容推送到GitHub倉庫。

3.本地倉庫與GitHub上相應的倉庫建立關聯,代碼如下:(git@github.com:wheeky/ZControls.git為我新建的倉庫路徑)

$ git remote add origin git@github.com:wheeky/ZControls.git

添加后,遠程庫的名字就是origin,這是Git默認的叫法,也可以改成別的,但是origin這個名字一看就知道是遠程庫。

4.把本地庫的內容推送到遠程庫上,用git push命令,實際是把當前分支master推送到遠程。

$ git push -u origin master

由于遠程庫是空的,我們第一次推送master分支時,加上了-u參數,Git不但會把本地的master分支內容推送的遠程新的master分支,還會把本地的master分支和遠程的master分支關聯起來,在以后的推送或者拉取時就可以簡化命令(不用帶-u參數)。

當你第一次使用Git的clone或者push命令連接GitHub時,會得到一個警告,這是因為Git使用SSH連接,而SSH連接在第一次驗證GitHub服務器的Key時,需要你確認GitHub的Key的指紋信息是否真的來自GitHub的服務器,輸入yes回車即可。

5.通過GitHub上的倉庫來克隆出新的本地倉庫,代碼如下:(克隆出新的本地倉庫文件夾為:ZControls)

$ git clone git@github.com:wheeky/ZControls.git

Git支持多種協議,默認的git://使用ssh,但也可以使用https等其他協議,使用https除了速度慢以外,還有個最大的麻煩是每次推送都必須輸入口令,但是在某些只開放http端口的公司內部就無法使用ssh協議而只能用https

三、分支管理

1.分支的作用:創建一個屬于你自己的分支,別人看不到,還繼續在原來的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到開發完畢后,再一次性合并到原來的分支上,這樣,既安全,又不影響別人工作。

2.創建分支(dev):

$ git checkout -b dev //git checkout命令加上-b參數表示創建并切換,相當于以下兩條命令:
$ git branch dev
$ git checkout dev

git branch命令查看當前分支,git branch命令會列出所有分支,當前分支前面會標一個*號。

用git checkout命令切換分支,如下代碼,切換到master分支:

$ git checkout master

3.合并分支:(用git merge命令合并指定分支到當前分支)

$ git merge dev //默認啟用Fast forward模式,若合并后再刪除分支,則刪除分支后,會丟掉分支信息
$ git merge --no-ff -m "merge with no-ff" dev //使用--no-ff參數,表示禁用Fast forward模式,Git就會在合并時生成一個新的commit,這樣,從分支歷史上就可以看出分支信息。  

4.刪除分支:

$ git branch -d dev //若需要強制刪除,則-d參數應改變為大寫,如:git branch -D dev

5.查看分支合并情況:

git log --graph

 6.臨時隱藏工作區:(常見的場景是,當我們需要臨時處理其它事情【如:解決BUG】時而不得不暫時中斷目前的主要開發任務)

$ git stash //隱藏目前工作區
$ git checkout master //切換到需要建立臨時分支的分支,比如:master
$ git checkout -b issue-101 //建立并切換到臨時分支,issue-101
$ git add file //添加到暫存區
$ git commit -m "fix bug 101" //提交到臨時分支倉庫
$ git checkout master //回到master分支
$ git merge --no-ff -m "merged bug fix 101" issue-101 //合并臨時分支,這里禁用fast foward模式,保留提交記錄以便日后可查或恢復
$ git branch -d issue-101 //刪除臨時分支

查看被隱藏的工作區信息:

$ git stash list

恢復工作區:

$ git stash pop //相當于以下兩條命令
$ git stash apply //恢復工作區
$ git stash drop //清除隱藏區

 7.查看遠程庫:

$ git remote
$ git remote -v //加上-v參數可以查看詳細信息

8.推送分支到遠程庫分支:

$ git push origin 分支名

9.創建本地分支并關聯遠程分支:

$ git checkout -b 分支名 origin/分支名 //origin/dev為遠程分支路徑
$ git branch --set-upstream 分支名 origin/分支名 //若本地已有分支,可通過該命令來關聯遠程分支

10.解決沖突:

  10.1若是本地多分支之前合并產生沖突,可以先用git status命令查看原因,并依據提示修改相應的文件后,再重試即可;

  10.2若是多人協作,向遠程推送提交時產生沖突,則需先用git pull把最新的提交從origin/dev抓下來,然后,在本地合并,解決沖突,再推送,如下:

$ git pull //從遠程獲取分支
$ git commit -m "marge files" //本地更新合并
$ git push origin dev //推送提交到遠程分支

 


文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()