git 使用筆記

git 使用筆記

  1. 安裝好之後,想要本地傳文件,必須配置一個本機公鑰,

  2. 在GitHub 點擊頭像,setting(設置),SSH,生成公鑰之後(就用第一句代碼,回車兩次即可),在C:\Users\taohang文件夾下有一個.ssh文件夾,把文件夾下的的id_rsa.pub放在github上

  3. 然後在gitBash裏面:全局配置郵箱賬戶

    git config --global user.email "[email protected]"
    git config --global user.name "Javatk"
    

    把本機和github連接起來

  4. 在項目目錄下面直接 git init 創建github倉庫

    git status  查看需要上傳的文件
    git add .  提交所有上傳的文件
    git commit -m "first commit"  提交第一個版本
    

    接着把github新建的項目出現的兩行代碼運行,

    git remote add origin https://github.com/Javatkh/test_vue.git
    git push -u origin master
    

項目中使用流程:

每天早上 git status 出現:

On branch master
Your branch is up to date with 'origin/master'.
nothing to commit, working tree clean

然後再 git pull,
再git status
每次提交代碼之前:git status
git add .
git status
git commit -m “我修改了xxx”
git status
git pull
git status
git push
git status

記住每次git都要穿插git status

其他:

1.初始化

  1. 初始化一個Git倉庫,使用git init命令。
  2. 添加文件到Git倉庫,分兩步。
  3. 使用命令git add ,注意,可反覆多次使用,添加多個文件。
  4. 使用命令git commit -m ,完成。

2.查看狀態

  1. 要隨時掌握工作區的狀態,使用git status命令。
  2. 如果git status告訴你有文件被修改過,用git diff可以查看修改內容。

3.日誌,回退

  1. HEAD指向的版本就是當前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令git reset --hard commit_id。
  2. 穿梭前,用git log可以查看提交歷史(日誌),以便確定要回退到哪個版本。
  3. 要重返未來,用git reflog查看命令歷史,以便確定要回到未來的哪個版本。

4.多分支原理

  1. Git的版本庫裏存了很多東西,其中最重要的就是稱爲stage(或者叫index)的暫存區,還有Git爲我們自動創建的第一個分支master,以及指向master的一個指針叫HEAD。

5.撤銷修改

  1. 場景1:當你改亂了工作區某個文件的內容,想直接丟棄工作區的修改時,用命令git checkout – file。
  2. 場景2:當你不但改亂了工作區某個文件的內容,還添加到了暫存區時,想丟棄修改,分兩步,第一步用命令git reset HEAD ,就回到了場景1,第二步按場景1操作。
  3. 場景3:已經提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節,不過前提是沒有推送到遠程庫

6.刪除

  1. 命令git rm用於刪除一個文件。如果一個文件已經被提交到版本庫,那麼你永遠不用擔心誤刪,但是要小心,你只能恢復文件到最新版本,你會丟失最近一次提交後你修改的內容。

6.GitHub

  1. 要克隆一個倉庫,首先必須知道倉庫的地址,然後使用git clone命令克隆。
  2. Git支持多種協議,包括https,但通過ssh支持的原生git協議速度最快。
  3. 要關聯一個遠程庫,使用命令git remote add origin git@server-name:path/repo-name.git;
  4. 關聯後,使用命令git push -u origin master第一次推送master分支的所有內容;
  5. 此後,每次本地提交後,只要有必要,就可以使用命令git push origin master推送最新修改;

7.分支

  1. 查看分支:git branch
  2. 創建分支:git branch
  3. 切換分支:git checkout
  4. 創建+切換分支:git checkout -b
  5. 合併某分支到當前分支:git merge
    例如:把dev合併到master上,先切換到master,再合併
  6. 刪除分支:git branch -d

8.版本衝突

  1. git status也可以告訴我們衝突的文件
  2. 用git log --graph命令可以看到分支合併圖。

9.創建標籤

  1. 命令git tag 用於新建一個標籤,默認爲HEAD,也可以指定一個commit id;
  2. 命令git tag -a -m "blablabla…"可以指定標籤信息;
  3. 命令git tag可以查看所有標籤。

10.bug

  1. 修復bug時,我們會通過創建新的bug分支進行修復,然後合併,最後刪除;
  2. 當手頭工作沒有完成時,先把工作現場git stash一下,然後去修復bug,修復後,再git stash pop,回到工作現場。

11.Feature分支

  1. feature-vulcan分支還沒有被合併,如果刪除,將丟失掉修改,如果要強行刪除,需要使用大寫的-D參數。
  2. git branch -D feature-vulcan

12.協作

  1. 查看遠程庫信息,使用git remote -v;
  2. 本地新建的分支如果不推送到遠程,對其他人就是不可見的;
  3. 從本地推送分支,使用git push origin branch-name,如果推送失敗,先用git pull抓取遠程的新提交;
  4. 在本地創建和遠程分支對應的分支,使用git checkout -b branch-name origin/branch-name,本地和遠程分支的名稱最好一致;
  5. 建立本地分支和遠程分支的關聯,使用git branch --set-upstream branch-name origin/branch-name;
  6. 從遠程抓取分支,使用git pull,如果有衝突,要先處理衝突。

13.多人協作一般流程

  1. 首先,可以試圖用git push origin 推送自己的修改;
  2. 如果推送失敗,則因爲遠程分支比你的本地更新,需要先用git pull試圖合併;
  3. 如果合併有衝突,則解決衝突,並在本地提交;
  4. 沒有衝突或者解決掉衝突後,再用git push origin 推送就能成功!
  5. 如果git pull提示no tracking information,則說明本地分支和遠程分支的鏈接關係沒有創建,用命令git branch --set-upstream-to origin/。
  6. 這就是多人協作的工作模式,一旦熟悉了,就非常簡單。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章