「廖雪峯的Git教程」學習筆記

廖雪峯的《Git教程》git

Git簡介

Git的版本

git version
which git

設置Git

git config --global user.name "MiracleWong"
git config --global user.email "youremail@example.com"
git config --global color.ui auto

查看Git的設置

git config --global user.name
git config --global user.email
git config --global color.ui

初始化倉庫

cd project
git init

git init project

查看文件狀態

git status

添加文件到版本庫

git add命令實際上就是把要提交的全部修改放到暫存區(Stage)github

git add readme.txt

提交到倉庫

git commit就能夠一次性把暫存區的全部修改提交到分支app

git commit -m "add readme.txt"

時光穿梭機

查看日誌——提交歷史

git log
git log --pretty=oneline 
git log --pretty=oneline --abbrev-commit  顯示前6位commit-id

HEAD 表示當前版本,上個版本HEAD^,上上個版本HEAD^。ssh

記錄命令歷史

git reflog

回退到上一個版本

git reset --hard HEAD^

查看工做區和版本庫裏面最新版本的區別

git diff HEAD -- readme.txt

撤銷暫存區的內容,從新放回工做區

git reset HEAD readme.txt

丟棄工做區的修改

git checkout -- readme.txt

刪除文件

git rm file
git commit -m "dekete file"

刪錯了文件,恢復

git checkout 實際上是用版本庫裏的版本替換爲工做區的版本fetch

git checkout -- test.txt

遠程倉庫

生成ssh key

ssh-keygen -t rsa -C "youremail@example.com"

添加遠程倉庫

git remote add origin git@github.com:michaelliao/learngit.git

本地內容推送到遠程倉庫

git push -u origin master 第一次推送master分支的全部內容
git push
git push origin master

遠程倉庫克隆

git clone git@github.com:michaelliao/gitskills.git

分支管理

建立分支

git branch <name>

建立+切換分支

git checkou -b dev

列出全部分支

git branch

切換分支

git checkout master

合併某分支到當前分支

git merge dev
git merge <name>

刪除分支

git branch -d <name>

分支合併

--bo-ff強制禁用Fast-Forward模式,生成一個新的commit信息,從分支歷史上能夠看出分支信息ui

git merge --no-ff -m "merge with no-ff" dev

分支策略

master 分支應該是很是穩定的,僅用來發布新版本,平時不在上面幹活。
幹活在dev分支上url

stash功能,儲存當前工做現場

git stash

恢復現場,stash不刪除(默認)

git stash apply stash@{0}
git stash drop (刪除儲存的現場)

恢復現場,stash刪除

git stash pop

查看儲存的現場

git stash list

強行刪除分支

git branch -D <name>

顯示倉庫信息

git remote -v

推送分支

git push origin master
git push origin dev

建立遠程分支到本地

git checkout -b dev origin/dev

創建本地分支和遠程分支的關聯

git branch --set-upstream dev origin/dev

標籤管理

建立標籤

git tag v1.0

查看全部標籤

git tag

補充tag

git tag v0.9 commit-id

顯示標籤tag信息

git show <tagname>

建立帶有說明的標籤

用-a指定標籤名,-m指定說明文字:操作系統

git tag -a v0.1 -m "version 0.1 released" commit-id

用PGP簽名標籤

git tag -s v0.2 -m "signed version 0.2 released" commit-id

刪除標籤

git tag -d v0.1

推送某個標籤到遠程

git push origin v1.0

一次性推送所有還沒有推送到遠程的本地標籤、

git push origin --tags

刪除一個遠程標籤

git push origin :refs/tags/v1.0

Git服務

The world’s leading software development platform · GitHub
碼雲 Gitee — 開源中國基於 Git 和 SVN 的代碼託管和協做開發平臺
Coding - 代碼託管 項目管理 WebIDE 企業服務.net

自定義Git

Git顯示顏色

git config --global color.ui true
git config --global color.ui auto

忽略特殊文件

  1. 忽略操做系統自動生成的文件,好比縮略圖等;
  2. 忽略編譯生成的中間文件、可執行文件等,也就是若是一個文件是經過另外一個文件自動生成的,那自動生成的文件就不必放進版本庫,好比Java編譯產生的.class文件;
  3. 忽略你本身的帶有敏感信息的配置文件,好比存放口令的配置文件。

強制添加忽略文件

git add -f App.class

gitignore命令檢查

git check-ignore -v App.class

設置別名

git config --global alias.st status
git config --global alias.co checkout
git config --global alias.ci commit
git config --global alias.br branch
git config --global alias.unstage 'reset HEAD'
git config --global alias.last 'log -1' 顯示最後一次提交的信息
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"

配置文件

[core]
    repositoryformatversion = 0
    filemode = true
    bare = false
    logallrefupdates = true
    ignorecase = true
    precomposeunicode = true
[remote "origin"]
    url = git@github.com:michaelliao/learngit.git
    fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
    remote = origin
    merge = refs/heads/master

參考資料

相關文章
相關標籤/搜索