如何使用Git上傳項目代碼到github

github是一個基于git的代碼托管平臺本刽,付費用戶可以建私人倉庫赫冬,我們一般的免費用戶只能使用公共倉庫讽坏,也就是代碼要公開。這對于一般人來說公共倉庫就已經(jīng)足夠了蜕企。

image

注冊賬戶以及創(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命令行备蚓,截圖效果如下:

image

第一次在本地倉庫操作需要先執(zhí)行git init命令

$ git init
image

為了把本地的倉庫傳到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上注冊的那個郵箱:

image

直接點回車粗悯,說明會在默認文件id_rsa上生成ssh key。

然后系統(tǒng)要求輸入密碼同欠,直接按回車表示不設密碼


image

重復密碼時也是直接回車样傍,之后提示你shh key已經(jīng)生成成功。

image

然后我們進入提示的地址下查看ssh key文件铺遂。 我的電腦的地址是C:\Users*lilu*.ssh 衫哥,其中l(wèi)ilu是我的電腦的名稱

image

打開id_rsa.pub,復制里面的key襟锐。里面的key是一對看不懂的字符數(shù)字組合撤逢,不用管它,直接復制粮坞。

回到github網(wǎng)站蚊荣,進入Account Settings,左邊選擇SSH Keys莫杈,Add SSH Key,

title隨便填互例,粘貼key。

image

3)驗證是否成功筝闹,在git bash下輸入

$ ssh -T git@github.com

回車就會看到:You’ve successfully authenticated, but GitHub does not provide shell access 媳叨。這就表示已成功連上github。

image

4)接下來我們要做的就是把本地倉庫傳到github上去关顷,在此之前還需要設置username和email糊秆,因為github每次commit都會記錄他們

$ git config --global user.name "your name"
$ git config --global user.email "your_email@youremail.com"

分別輸入上述命令行 回車, 我的界面顯示如下


image

5)進入要上傳的倉庫议双,右鍵git bash痘番,添加遠程地址

$ git remote add origin git@github.com:yourName/yourRepo.git

后面的yourName和yourRepo表示你再github的用戶名和剛才新建的倉庫,加完之后進入.git聋伦,打開config夫偶,這里會多出一個remote “origin”內(nèi)容,這就是剛才添加的遠程地址觉增,也可以直接修改config來配置遠程地址兵拢。

image

與github上的對應


image

提交上傳

1)接下來在本地倉庫里添加一些文件,比如README

在本地新建一個README文件


image

然后在命令行輸入一下命令

$ git add README

$ git commit -m "first commit"

我的執(zhí)行界面如下


image

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

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蛹锰,隨后出現(xiàn)的幾起案子深胳,更是在濱河造成了極大的恐慌,老刑警劉巖铜犬,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件舞终,死亡現(xiàn)場離奇詭異,居然都是意外死亡癣猾,警方通過查閱死者的電腦和手機权埠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來煎谍,“玉大人,你說我怎么就攤上這事龙屉∧耪常” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵转捕,是天一觀的道長作岖。 經(jīng)常有香客問我,道長五芝,這世上最難降的妖魔是什么痘儡? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮枢步,結果婚禮上沉删,老公的妹妹穿的比我還像新娘。我一直安慰自己醉途,他們只是感情好矾瑰,可當我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著隘擎,像睡著了一般殴穴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上货葬,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天采幌,我揣著相機與錄音,去河邊找鬼震桶。 笑死欺殿,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的售睹。 我是一名探鬼主播,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼炒瘸,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了寝衫?” 一聲冷哼從身側響起顷扩,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎慰毅,沒想到半個月后隘截,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡汹胃,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年婶芭,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片着饥。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡犀农,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出宰掉,到底是詐尸還是另有隱情呵哨,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布轨奄,位于F島的核電站孟害,受9級特大地震影響,放射性物質發(fā)生泄漏挪拟。R本人自食惡果不足惜挨务,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望玉组。 院中可真熱鬧谎柄,春花似錦、人聲如沸球切。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吨凑。三九已至捍歪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間鸵钝,已是汗流浹背糙臼。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留恩商,地道東北人变逃。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像怠堪,于是被迫代替她去往敵國和親揽乱。 傳聞我的和親對象是個殘疾皇子名眉,可洞房花燭夜當晚...
    茶點故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 1.設置 初次使用需要設置姓名和郵箱git config --global user.name "git用戶名"g...
    jrg陳咪咪sunny閱讀 753評論 0 1
  • 1.git的安裝 1.1 在Windows上安裝Git msysgit是Windows版的Git,從https:/...
    落魂灬閱讀 12,649評論 4 54
  • 陳小冠幼兒園圖書漂流凰棉,就是小朋友帶書到幼兒園相互交換损拢,我家這次漂回來的竟然是它: 今天了解了一下才知道這個故事20...
    木木sani閱讀 127評論 0 0
  • 我們現(xiàn)在開發(fā)的應用一般都會將前臺和后臺進行數(shù)據(jù)傳輸,或者是我們的應用服務器需要提供數(shù)據(jù)給多個應用使用的時候撒犀,要注意...
    子龍愛彈琴閱讀 2,138評論 0 7
  • 如果恰好失眠或舞,如果半夜恰好手機振動荆姆,而我想也不用想,就知道肯定是那幾個“拼命三娘”剛發(fā)完文映凳。自從加入了寫作群胆筒,讓我...
    王玬錦閱讀 454評論 0 1