git的使用教程

來源廖雪峯git教程https://www.liaoxuefeng.com/wikireact

在Windows上安裝Git

  • 在Windows上使用Git,能夠從Git官網直接下載安裝程序,(網速慢的同窗請移步國內鏡像),而後按默認選項安裝便可。
  • 安裝完成後,在開始菜單裏找到「Git」->「Git Bash」,蹦出一個相似命令行窗口的東西,就說明Git安裝成功!
  • 安裝完成後,還須要最後一步設置,在命令行輸入: $ git config --global user.name "Your Name" $ git config --global user.email "email@example.com"

建立版本庫

  1. 首先,選擇一個合適的地方,建立一個空目錄:
  • 切換根目錄命令:$ cd /d
  • 建立文件夾:$ mkdir app
  • pwd命令用於顯示當前目錄
  1. 經過git init命令把這個目錄變成Git能夠管理的倉庫:
  • $ git init
  • 瞬間Git就把倉庫建好了,並且告訴你是一個空的倉庫.
  • 若是你沒有看到.git目錄,那是由於這個目錄默認是隱藏的,用ls -ah命令就能夠看見。
  1. 添加文件到Git倉庫 git add . 將全部文件添加到暫存區 第一步,使用命令git add ,注意,可反覆屢次使用,添加多個文件;
  • 簡單解釋一下git commit命令,-m後面輸入的是本次提交的說明,能夠輸入任意內容,固然最好是有意義的。
  • $ git commit -m "wrote a readme file"

第二步,使用命令git commit,完成。git

4.修改文件後github

  • git status命令可讓咱們時刻掌握倉庫當前的狀態,上面的命令告訴咱們,readme.txt被修改過了,但尚未準備提交的修改。
  • git diff顧名思義就是查看difference

小結:

  • 要隨時掌握工做區的狀態,使用git status命令。
  • 若是git status告訴你有文件被修改過,用git diff能夠查看修改內容。

版本回退

  1. git log命令顯示從最近到最遠的提交日誌 (若是嫌輸出信息太多,看得眼花繚亂的,能夠試試加上--pretty=oneline參數)
  2. 若要回退到上個版本,咱們要知道當前版本是哪一個版本。在Git中,用HEAD表示當前版本,上一個版本就是HEAD^,上上一個版本就是HEAD^^,固然往上100個版本寫100個^比較容易數不過來,因此寫成HEAD~100
  3. 回到過去:回退命令$ git reset --hard HEAD^
  4. 從過去去將來:若果你又想回退到操做以前的版本,命令窗口未關閉,咱們能夠找到他的commitId,咱們就可使用 git reset --hard 4356475,回到將來
  5. 若是你把窗口關閉後,你又想去將來,那你能夠用git reflog來查詢你每次的命令
  6. 小結
  • HEAD指向的版本就是當前版本,所以,Git容許咱們在版本的歷史之間穿梭,使用命令git reset --hard commit_id。bash

  • 穿梭前,用git log能夠查看提交歷史,以便肯定要回退到哪一個版本。app

  • 要重返將來,用git reflog查看命令歷史,以便肯定要回到將來的哪一個版本。ssh

工做去和暫存區

  • 工做區有一個隱藏目錄.git,這個不算工做區,而是Git的版本庫。
  • 前面講了咱們把文件往Git版本庫裏添加的時候,是分兩步執行的:
  1. 第一步是用git add把文件添加進去,實際上就是把文件修改添加到暫存區;
  2. 第二步是用git commit提交更改,實際上就是把暫存區的全部內容提交到當前分支。

管理修改

  • 第一次修改 -> git add -> 第二次修改 -> git add -> git commit
  • git commit只負責把暫存區的修改提交了

撤銷修改

  1. git checkout -- file能夠丟棄工做區的修改
  2. 命令git checkout -- readme.txt意思就是,把readme.txt文件在工做區的修改所有撤銷,這裏有兩種狀況:
  • 一種是readme.txt自修改後尚未被放到暫存區,如今,撤銷修改就回到和版本庫如出一轍的狀態;
  • 一種是readme.txt已經添加到暫存區後,又做了修改,如今,撤銷修改就回到添加到暫存區後的狀態。
  • 總之,就是讓這個文件回到最近一次git commit或git add時的狀態。 3.小結
  • 場景1:當你改亂了工做區某個文件的內容,想直接丟棄工做區的修改時,用命令git checkout -- file。
  • 場景2:當你不但改亂了工做區某個文件的內容,還添加到了暫存區時,想丟棄修改,分兩步,第一步用命令git reset HEAD file,就回到了場景1,第二步按場景1操做。
  • 場景3:已經提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節,不過前提是沒有推送到遠程庫。

刪除文件

1.通常狀況下,你一般直接在文件管理器中把沒用的文件刪了,或者用rm命令刪了: $ rm test.txt 2.從版本庫刪除文件fetch

  • 一是確實要從版本庫中刪除該文件,那就用命令git rm刪掉,而且git commit
  • 另外一種狀況是刪錯了,由於版本庫裏還有呢,因此能夠很輕鬆地把誤刪的文件恢復到最新版本。$ git checkout -- test.txt
  • git checkout . 用版本庫裏的版本替換工做區的版本
  • git checkout實際上是用版本庫裏的版本替換工做區的版本,不管工做區是修改仍是刪除,均可以「一鍵還原」。

遠程倉庫

因爲你的本地Git倉庫和GitHub倉庫之間的傳輸是經過SSH加密的,因此,須要一點設置: 1.第1步:建立SSH Key。在用戶主目錄下,看看有沒有.ssh目錄,若是有,再看看這個目錄下有沒有id_rsa和id_rsa.pub這兩個文件,若是已經有了,可直接跳到下一步。若是沒有,打開Shell(Windows下打開Git Bash),建立SSH Key: $ ssh-keygen -t rsa -C "huwanfei125@gmail.com" 若是一切順利的話,能夠在用戶主目錄裏找到.ssh目錄,裏面有id_rsa和id_rsa.pub兩個文件,這兩個就是SSH Key的祕鑰對,id_rsa是私鑰,不能泄露出去,id_rsa.pub是公鑰,能夠放心地告訴任何人。 2.第2步:登錄GitHub加密

  • 打開「Account settings」,「SSH Keys」頁面
  • 而後,點「Add SSH Key」,填上任意Title,在Key文本框裏粘貼id_rsa.pub文件的內容
  • 點「Add Key」,你就應該看到已經添加的Key
  • 固然,GitHub容許你添加多個Key。假定你有若干電腦,你一下子在公司提交,一下子在家裏提交,只要把每臺電腦的Key都添加到GitHub,就能夠在每臺電腦上往GitHub推送了。

添加遠程庫

1.在github上建立一個倉庫 2.將本地庫於這個倉庫鏈接: 咱們根據GitHub的提示,在本地的learngit倉庫下運行命令 $ git remote add origin git@github.com:WFHu125/learngit.git WFHu125是github的用戶名,origin遠程庫的名字 3.下一步,就能夠把本地庫的全部內容推送到遠程庫上: git push -u origin master.net

  • 因爲遠程庫是空的,咱們第一次推送master分支時,加上了-u參數,Git不但會把本地的master分支內容推送的遠程新的master分支,還會把本地的master分支和遠程的master分支關聯起來,在之後的推送或者拉取時就能夠簡化命令。
  • 以後使用命令git push origin master推送最新修改

從遠程庫克隆

1.建立遠程庫gitskills 2.用命令git clone克隆一個本地庫: $ git clone git@github.com:michaelliao/gitskills.git命令行

分支管理

建立與合併分支

Git鼓勵大量使用分支:

  • 查看分支:git branch

  • 建立分支:git branch

  • 切換分支:git checkout

  • 建立+切換分支:git checkout -b

  • 合併某分支到當前分支:git merge

  • 刪除分支:git branch -d

問題及解決方法

在使用git 對源代碼進行push到gitHub時可能會出錯,信息以下 To github.com:WFHu125/resume.git ! [rejected] master -> master (non-fast-forward) error: failed to push some refs to 'git@github.com:WFHu125/resume.git' hint: Updates were rejected because the tip of your current branch is behind hint: its remote counterpart. Integrate the remote changes (e.g. hint: 'git pull ...') before pushing again. hint: See the 'Note about fast-forwards' in 'git push --help' for details.

緣由

github中的README.md文件不在本地代碼目錄中

解決

能夠經過以下命令進行代碼合併[注:pull=fetch+merge] git pull --rebase origin master

基本操做圖

  1. 打開git bash
  2. 建立本地庫 例如: cd /d cd git $ cd react-music
  3. 初始化 git init
  4. git add .(將本地全部文件添加到暫存區)
  5. git commit -m "初始化" (提交代碼)
  6. 在github上建立一個遠程庫
  7. 將本地庫和遠程庫連接
  • git remote add origin git@github.com:WFHu125/react-music.git
  1. git push -u origin master (將本地代碼上傳到遠程庫中)
相關文章
相關標籤/搜索