1. 程式人生 > >Git操作流程

Git操作流程

安裝git:
    
   1.git官網下載安裝,建立gitdemo資料夾解壓此資料夾,右擊->git bash開啟命令視窗
   2.設定名字和郵箱:
    $ git config --global user.name "Your Name"
    $ git config --global user.email "[email protected]"

一。建立倉庫:
   1.第一步,選擇合適的地方,建立一個空目錄作為版本庫。右擊版本庫->git bash
    $pwd     (命令用於顯示當前目錄)

   2.第二步,通過git init命令把這個目錄變成Git可以管理的倉庫:
    $ git init
    Initialized empty Git repository in /Users/michael/learngit/.git/    (告訴你是一個空的倉庫)
    (提示)當前目錄下多了一個.git的目錄,這個目錄是Git來跟蹤管理版本庫的,沒事千萬不要手動修改這個目錄裡面的檔案,
    不然改亂了,就把Git倉庫給破壞了。如果你沒有看到.git目錄,那是因為這個目錄預設是隱藏的,用ls -ah命令就可以看見。

二。把檔案新增並提交到倉庫:
    1.第一步,用命令git add告訴Git,把檔案新增到倉庫:
    $ git add readme.txt
    (提示)使用命令git add <file>,注意,可反覆多次使用,新增多個檔案;

     2.第二步,用命令git commit告訴Git,把檔案提交到倉庫:
    $ git commit -m "wrote a readme file"
    [master (root-commit) eaadf4e] wrote a readme file
     1 file changed, 2 insertions(+)
     create mode 100644 readme.txt
    (提示)-m後面輸入的是本次提交的說明

    小結:
            初始化一個Git倉庫,使用git init命令。
            新增檔案到Git倉庫,分兩步:
            使用命令git add <file>,注意,可反覆多次使用,新增多個檔案;
            使用命令git commit -m <message>,完成。

三。檔案管理的操作:
    1.修改檔案後檢視倉庫當前的狀態
    $ git status
     2.看看具體修改了什麼內容
    $ git diff  HEAD -- readme.txt 
    知道了對readme.txt作了什麼修改後,再把它提交到倉庫就放心多了,提交修改和提交新檔案是一樣的兩步,第一步是git add:
    $ git add readme.txt
    同樣沒有任何輸出。在執行第二步git commit之前,我們再執行git status看看當前倉庫的狀態:
    $ git status

    小結:
           要隨時掌握工作區的狀態,使用git status命令。
            如果git status告訴你有檔案被修改過,用git diff可以檢視修改內容。

    (一)版本回退:
    1.檢視提交歷史
       $ git log    
       推薦用:$ git log --pretty=oneline    
     ($ git log --pretty=oneline     如果嫌輸出資訊太多,看得眼花繚亂的,可以試試加上--pretty=oneline引數)

    2.回退版本
       $ git reset --hard HEAD^
          在Git中,用HEAD表示當前版本,也就是最新的提交1094adb...(注意我的提交ID和你的肯定不一樣)
         上一個版本就是HEAD^,上上一個版本就是HEAD^^,當然往上100個版本寫100個^比較容易數不過來,所以寫成HEAD~100。
       
        $ cat readme.txt     檢視版本是否回退
        $ git reset --hard 1094a    指定回到未來的某個版本

    3.後悔回退了:
          $ git reflog
         在Git中,總是有後悔藥可以吃的。當你用$ git reset --hard HEAD^回退到add distributed版本時,再想恢復到append GPL
         就必需找到append GPL的commit id。Git提供了一個命令git reflog用來記錄你的每一次命令:

        小結:
        HEAD指向的版本就是當前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令git reset --hard commit_id。
        穿梭前,用git log可以檢視提交歷史,以便確定要回退到哪個版本。
        要重返未來,用git reflog檢視命令歷史,以便確定要回到未來的哪個版本。
       
         (二)工作區和暫存區:
        就是你在電腦裡能看到的目錄,比如我的learngit資料夾就是一個工作區
        工作區有一個隱藏目錄.git,這個不算工作區,而是Git的版本庫。
        Git的版本庫裡存了很多東西,其中最重要的就是稱為stage(或者叫index)的暫存區
        第一步是用git add把檔案新增進去,實際上就是把檔案修改新增到暫存區;
        第二步是用git commit提交更改,實際上就是把暫存區的所有內容提交到當前分支。
          (三)管理修改:
         為什麼Git比其他版本控制系統設計得優秀,因為Git跟蹤並管理的是修改,而非檔案
         你會問,什麼是修改?比如你新增了一行,這就是一個修改,刪除了一行
          每次修改,如果不用git add到暫存區,那就不會加入到commit中

          (四)撤銷修改:
          $ git checkout -- readme.txt    當你在工作區修改了檔案想撤銷時用
          $ git reset HEAD readme.txt    當你在提交到暫存區想撤銷時用,(撤銷到工作區然後再撤銷)

        命令git checkout -- readme.txt意思就是,把readme.txt檔案在工作區的修改全部撤銷,這裡有兩種情況:
             一種是readme.txt自修改後還沒有被放到暫存區,現在,撤銷修改就回到和版本庫一模一樣的狀態;
             一種是readme.txt已經新增到暫存區後,又作了修改,現在,撤銷修改就回到新增到暫存區後的狀態。
         
    小結:
        場景1:當你改亂了工作區某個檔案的內容,想直接丟棄工作區的修改時,用命令git checkout -- file。
        場景2:當你不但改亂了工作區某個檔案的內容,還新增到了暫存區時,想丟棄修改,分兩步,第一步用命令git reset HEAD     <file>,就回到了場景1,第二步按場景1操作。
        場景3:已經提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節,不過前提是沒有推送到遠端庫。

            (五)刪除檔案:
         $ rm test.txt    刪除工作區的檔案
         $ git rm test.txt    刪除暫存區的檔案
     
     小結:
        git checkout其實是用版本庫裡的版本替換工作區的版本,無論工作區是修改還是刪除,都可以“一鍵還原”。


四、遠端倉庫

    (1)新增遠端庫:
    第一步,建立ssh key.
       $ ssh-keygen -t rsa -C "[email protected]"

    第二步:登陸GitHub,開啟“Account settings”,“SSH Keys”頁面
    然後,點“Add SSH Key”,填上任意Title,在Key文字框裡貼上id_rsa.pub檔案的內容:

    第三步:登入github建立新的倉庫

    第四步:在本地倉庫輸入:
        1.關聯遠端庫:
            $ git remote add origin http://github.com/wanglinyan1995/FirstDemo.git        
        2.推送內容:
            $ git push -u origin master    把本地庫的所有內容推送到遠端庫上
    小結:
        要關聯一個遠端庫,使用命令git remote add origin [email protected]:path/repo-name.git;
        關聯後,使用命令git push -u origin master第一次推送master分支的所有內容;
        此後,每次本地提交後,只要有必要,就可以使用命令git push origin master推送最新修改;

      (2)從遠端庫克隆:
    第一步:建立新的倉庫,勾選Initialize this repository with a README
    第二步:在本地用命令git clone克隆一個本地庫
        $ git clone [email protected]:michaelliao/gitskills.git

    小結:
        要克隆一個倉庫,首先必須知道倉庫的地址,然後使用git clone命令克隆。
        Git支援多種協議,包括https,但通過ssh支援的原生git協議速度最快


五,分支管理
        一。建立與合併分支:
           第一步:建立dev分支,然後切換到dev分支
              $ git checkout -b dev
    
         第二步:檢視當前分支
        $ git branch
    第三步:切換回到master分支
        $ git checkout master
    第四步:把dev分支的工作成果合併到master分支上:
        $ git merge dev
    第五步:合併後刪除dev分支
        $ git branch -d dev

    小結:
        檢視分支:git branch
        建立分支:git branch <name>
        切換分支:git checkout <name>
        建立+切換分支:git checkout -b <name>
        合併某分支到當前分支:git merge <name>
        刪除分支:git branch -d <name>

          二。解決衝突
       發生了衝突無法合併:
        $ git merge feature1
        Auto-merging readme.txt
        CONFLICT (content): Merge conflict in readme.txt
        Automatic merge failed; fix conflicts and then commit the result.
       解決衝突:
        檢視檔案內容並修改。然後再提交。
    
        檢視分支的合併情況:
            $ git log --graph --pretty=oneline --abbrev-commit

       小結:
        當Git無法自動合併分支時,就必須首先解決衝突。解決衝突後,再提交,合併完成。
        解決衝突就是把Git合併失敗的檔案手動編輯為我們希望的內容,再提交。
        用git log --graph命令可以看到分支合併圖。

          三。 分支管理策略:
        禁用Fast forward模式,Git就會在merge時生成一個新的commit,這樣,從分支歷史上就可以看出分支資訊。
         1.建立並切換dev分支:
            $ git checkout -b dev
         2.修改檔案並提交一個新的commit
            $ git add readme.txt 
            $ git commit -m "add merge"
             3.切換回master
            $ git checkout master
         4.合併dev分支,請注意--no-ff引數,表示禁用Fast forward:
            $ git merge --no-ff -m "merge with no-ff" dev
          5.檢視分支歷史:
            $ git log --graph --pretty=oneline --abbrev-commit
            
       小結:
        合併分支時,加上--no-ff引數就可以用普通模式合併,合併後的歷史有分支,能看出來曾經做過合併,而fast forward合併就看不出來曾經做過合併。

           四。bug分支:
        1.Git還提供了一個stash功能,可以把當前工作現場“儲藏”起來,等以後恢復現場後繼續工作   
            $ git stash
        2.回到dev繼續工作:
            $ git checkout dev
            $ git stash list    看看剛才工作現場存在哪裡        
        3. 恢復工作現場同時把stash內容也刪了
            $ git stash pop

        小結:
        修復bug時,我們會通過建立新的bug分支進行修復,然後合併,最後刪除;
        當手頭工作沒有完成時,先把工作現場git stash一下,然後去修復bug,修復後,再git stash pop,回到工作現場。
        如果要丟棄一個沒有被合併過的分支,可以通過git branch -D <name>強行刪除。