github是一個基于git的代碼托管平臺本刽,付費用戶可以建私人倉庫赫冬,我們一般的免費用戶只能使用公共倉庫讽坏,也就是代碼要公開。這對于一般人來說公共倉庫就已經(jīng)足夠了蜕企。
注冊賬戶以及創(chuàng)建倉庫
要想使用github第一步當然是注冊github賬號了咬荷。之后就可以創(chuàng)建倉庫了(免費用戶只能建公共倉庫),Create a New Repository轻掩,填好名稱后Create幸乒,之后會出現(xiàn)一些倉庫的配置信息,這也是一個git的簡單教程唇牧。步驟如下:
打開https://github.com 直接在首頁上注冊
點按鈕注冊成功之后罕扎,在頁面上方用戶菜單上選擇 “+”->New repository 創(chuàng)建一個新的倉庫
為倉庫取一個名字,點擊創(chuàng)建倉庫按鈕 你將成功創(chuàng)建一個倉庫
安裝git客戶端
github是服務端丐重,要想在自己電腦上使用git我們還需要一個git客戶端腔召,
windows用戶請下載 http://msysgit.github.com/
mac用戶請下載 http://code.google.com/p/tortoisegit/
一路next,安裝成功后扮惦, 回到C盤臀蛛,或任何文件夾下,點鼠標右鍵會多出一些菜單
如 Git Init Hear崖蜜、Git Bash浊仆、Git Gui , 說明安裝成功豫领。
配置Git
我們先在電腦硬盤里找一塊地方存放本地倉庫抡柿,比如我們把本地倉庫建立在C:\MyRepository\1ke_test文件夾下
進入1ke_test文件夾 鼠標右鍵操作如下步驟:
1)在本地倉庫里右鍵選擇Git Init Here,會多出來一個.git文件夾等恐,這就表示本地git創(chuàng)建成功洲劣。右鍵Git Bash進入git命令行备蚓,截圖效果如下:
第一次在本地倉庫操作需要先執(zhí)行git init命令
$ git init
為了把本地的倉庫傳到github,還需要配置ssh key闪檬。
2)在本地創(chuàng)建ssh key
$ ssh-keygen -t rsa -C "your_email@youremail.com"
后面的your_email@youremail.com改為你的郵箱星著。我的郵箱是lilu@1ke.co,也是在github上注冊的那個郵箱:
直接點回車粗悯,說明會在默認文件id_rsa上生成ssh key。
然后系統(tǒng)要求輸入密碼同欠,直接按回車表示不設密碼
重復密碼時也是直接回車样傍,之后提示你shh key已經(jīng)生成成功。
然后我們進入提示的地址下查看ssh key文件铺遂。 我的電腦的地址是C:\Users*lilu*.ssh 衫哥,其中l(wèi)ilu是我的電腦的名稱
打開id_rsa.pub,復制里面的key襟锐。里面的key是一對看不懂的字符數(shù)字組合撤逢,不用管它,直接復制粮坞。
回到github網(wǎng)站蚊荣,進入Account Settings,左邊選擇SSH Keys莫杈,Add SSH Key,
title隨便填互例,粘貼key。
3)驗證是否成功筝闹,在git bash下輸入
$ ssh -T git@github.com
回車就會看到:You’ve successfully authenticated, but GitHub does not provide shell access 媳叨。這就表示已成功連上github。
4)接下來我們要做的就是把本地倉庫傳到github上去关顷,在此之前還需要設置username和email糊秆,因為github每次commit都會記錄他們
$ git config --global user.name "your name"
$ git config --global user.email "your_email@youremail.com"
分別輸入上述命令行 回車, 我的界面顯示如下
5)進入要上傳的倉庫议双,右鍵git bash痘番,添加遠程地址
$ git remote add origin git@github.com:yourName/yourRepo.git
后面的yourName和yourRepo表示你再github的用戶名和剛才新建的倉庫,加完之后進入.git聋伦,打開config夫偶,這里會多出一個remote “origin”內(nèi)容,這就是剛才添加的遠程地址觉增,也可以直接修改config來配置遠程地址兵拢。
與github上的對應
提交上傳
1)接下來在本地倉庫里添加一些文件,比如README
在本地新建一個README文件
然后在命令行輸入一下命令
$ git add README
$ git commit -m "first commit"
我的執(zhí)行界面如下
2)上傳到github
$ git push origin master
git push命令會將本地倉庫推送到遠程服務器逾礁。
git pull命令則相反说铃。
注:首次提交访惜,先git pull下,修改完代碼后腻扇,使用git status可以查看文件的差別债热,使用git add 添加要commit的文件。
大功告成幼苛,現(xiàn)在你知道如何將本地的項目提交到github上了窒篱。
gitignore文件
.gitignore顧名思義就是告訴git需要忽略的文件,這是一個很重要并且很實用的文件舶沿。一般我們寫完代碼后會執(zhí)行編譯墙杯、調試等操作,這期間會產(chǎn)生很多中間文件和可執(zhí)行文件括荡,這些都不是代碼文件高镐,是不需要git來管理的。我們在git status的時候會看到很多這樣的文件畸冲,如果用git add -A來添加的話會把他們都加進去嫉髓,而手動一個個添加的話也太麻煩了。這時我們就需要.gitignore了邑闲。
Git命令
查看算行、添加、提交监憎、刪除纱意、找回,重置修改文件
git help <command> # 顯示command的help
git show # 顯示某次提交的內(nèi)容 git show $id
git co -- <file> # 拋棄工作區(qū)修改
git co . # 拋棄工作區(qū)修改
git add <file> # 將工作文件修改提交到本地暫存區(qū)
git add . # 將所有修改過的工作文件提交暫存區(qū)
git rm <file> # 從版本庫中刪除文件
git rm <file> --cached # 從版本庫中刪除文件鲸阔,但不刪除文件
git reset <file> # 從暫存區(qū)恢復到工作文件
git reset -- . # 從暫存區(qū)恢復到工作文件
git reset --hard # 恢復最近一次提交過的狀態(tài)偷霉,即放棄上次提交后的所有本次修改
git ci <file> git ci . git ci -a # 將git add, git rm和git ci等操作都合并在一起做 git ci -am "some comments"
git ci --amend # 修改最后一次提交記錄
git revert <$id> # 恢復某次提交的狀態(tài),恢復動作本身也創(chuàng)建次提交對象
git revert HEAD # 恢復最后一次提交的狀態(tài)
查看文件diff
git diff <file> # 比較當前文件和暫存區(qū)文件差異 git diff
git diff <id1><id2> # 比較兩次提交之間的差異
git diff <branch1>..<branch2> # 在兩個分支之間比較
git diff --staged # 比較暫存區(qū)和版本庫差異
git diff --cached # 比較暫存區(qū)和版本庫差異
git diff --stat # 僅僅比較統(tǒng)計信息
查看提交記錄
git log git log <file> # 查看該文件每次提交記錄
git log -p <file> # 查看每次詳細修改內(nèi)容的diff
git log -p -2 # 查看最近兩次詳細修改內(nèi)容的diff
git log --stat #查看提交統(tǒng)計信息
tig
Mac上可以使用tig代替diff和log褐筛,brew install tig
Git 本地分支管理
查看类少、切換、創(chuàng)建和刪除分支
git br -r # 查看遠程分支
git br <new_branch> # 創(chuàng)建新的分支
git br -v # 查看各個分支最后提交信息
git br --merged # 查看已經(jīng)被合并到當前分支的分支
git br --no-merged # 查看尚未被合并到當前分支的分支
git co <branch> # 切換到某個分支
git co -b <new_branch> # 創(chuàng)建新的分支渔扎,并且切換過去
git co -b <new_branch> <branch> # 基于branch創(chuàng)建新的new_branch
git co $id # 把某次歷史提交記錄checkout出來硫狞,但無分支信息,切換到其他分支會自動刪除
git co $id -b <new_branch> # 把某次歷史提交記錄checkout出來晃痴,創(chuàng)建成一個分支
git br -d <branch> # 刪除某個分支
git br -D <branch> # 強制刪除某個分支 (未被合并的分支被刪除的時候需要強制)
分支合并和rebase
git merge <branch> # 將branch分支合并到當前分支
git merge origin/master --no-ff # 不要Fast-Foward合并残吩,這樣可以生成merge提交
git rebase master <branch> # 將master rebase到branch,相當于: git co <branch> && git rebase master && git co master && git merge <branch>
Git補丁管理(方便在多臺機器上開發(fā)同步時用)
git diff > ../sync.patch # 生成補丁
git apply ../sync.patch # 打補丁
git apply --check ../sync.patch #測試補丁能否成功
Git暫存管理
git stash # 暫存
git stash list # 列所有stash
git stash apply # 恢復暫存的內(nèi)容
git stash drop # 刪除暫存區(qū)
Git遠程分支管理
git pull # 抓取遠程倉庫所有分支更新并合并到本地
git pull --no-ff # 抓取遠程倉庫所有分支更新并合并到本地倘核,不要快進合并
git fetch origin # 抓取遠程倉庫更新
git merge origin/master # 將遠程主分支合并到本地當前分支
git co --track origin/branch # 跟蹤某個遠程分支創(chuàng)建相應的本地分支
git co -b <local_branch> origin/<remote_branch> # 基于遠程分支創(chuàng)建本地分支泣侮,功能同上
git push # push所有分支
git push origin master # 將本地主分支推到遠程主分支
git push -u origin master # 將本地主分支推到遠程(如無遠程主分支則創(chuàng)建,用于初始化遠程倉庫)
git push origin <local_branch> # 創(chuàng)建遠程分支紧唱, origin是遠程倉庫名
git push origin <local_branch>:<remote_branch> # 創(chuàng)建遠程分支
git push origin :<remote_branch> #先刪除本地分支(git br -d <branch>)活尊,然后再push刪除遠程分支
Git遠程倉庫管理
git remote -v # 查看遠程服務器地址和倉庫名稱
git remote show origin # 查看遠程服務器倉庫狀態(tài)
git remote add origin git@ github:robbin/robbin_site.git # 添加遠程倉庫地址
git remote set-url origin git@ github.com:robbin/robbin_site.git # 設置遠程倉庫地址(用于修改遠程倉庫地址) git remote rm <repository> # 刪除遠程倉庫
創(chuàng)建遠程倉庫
git clone --bare robbin_site robbin_site.git # 用帶版本的項目創(chuàng)建純版本倉庫
scp -r my_project.git git@ git.csdn.net:~ # 將純倉庫上傳到服務器上
mkdir robbin_site.git && cd robbin_site.git && git --bare init # 在服務器創(chuàng)建純倉庫
git remote add origin git@ github.com:robbin/robbin_site.git # 設置遠程倉庫地址
git push -u origin master # 客戶端首次提交
git push -u origin develop # 首次將本地develop分支提交到遠程develop分支隶校,并且track
git remote set-head origin master # 設置遠程倉庫的HEAD指向master分支
也可以命令設置跟蹤遠程庫和本地庫
git branch --set-upstream master origin/master
git branch --set-upstream develop origin/develop