github經常使用命令彙總

創立版本庫git

mkdir Baidu
cd Baidu
git initgithub

 


SSH
ssh-keygen -t -rsa -C "TaylorApril947939@gmail"
(在github上new SSH,內容爲id_rsa.pub)
app

 

 

添加遠程庫
(github上新建git倉庫,選擇REAMDE.md)
git remote add origin git@github.com:TaylorApril/Baidu.git
git push -u origin master
(報錯)
git pull --rebase origin master
git push -u origin master
git push origin master
ssh

 

 

提交(文件名字read.txt)
git add read.txt
(全部文件 git add .)
git commit -m "說明文字"
git push
post

 


版本回退
(查看最近到最遠提交日誌)
git log --prtty=oneline
(回退版本計數:HEAD^上一個版本、HEAD~100上與100個版本)
git reset --hard HEAD^
(回退版本號碼:回退版本commit id爲3628df)
git reset --hard 3628df
(想要恢復:使用命令記錄來找回commit id回退)
git reflog
fetch

 


撤銷修改ui

———>              git add files              git commit
working directory--------------stage-------------history
<———         git checkout --files         git reset --filesspa

 

 

刪除文件(read.txt)
rm read.txt
(從版本庫中刪除)
git rm read.txt
git commit -m "delete"
(刪錯了)
git checkout -- read.txt
日誌

 

 

分支(分支名字dev)
建立分支:git branch dev
切換分支:git checkout dev
建立+切換分支:git checkout -b dev
查看當前分支:git branch
切換回master分支:git checkout master
合併指定分支到當前分支:git merge dev
(fast-forward 快進模式)
刪除分支:git branch -d dev
blog

 


解決衝突(分支名字fea)
衝突緣由:master和Dev同時增加。
git checkout -b fea
(修改Creating a new branch is quick AND simple.)
git add read.txt
git commit -m "fea"
git checkout master
(修改Creating a new branch is quick & simple.)
git addread.txt
git commit -m "master"
(此時造成了master和fea各自指着一個分支)
git merge fea
(合併錯誤,git status , cat read.txt能夠查看)
(修改read.txt的文本內容 Creating a new branch is quick and simple.)
git add read.txt
git commit -m 「conf」
(如今master和fea指向同一我的點了,git log可查看合併狀況)
git branch -d fea

 


分支管理策略(--no-ff)(分支名字dev 文件名字read.txt)
git checkout -b dev
git add read.txt
git commit -m "dev"
git checkout master
(注意下個參數--no-ff,表示禁用fast forward)
(fast forward合併看不出曾經作過合併,而--no-ff參數合併後的歷史有分支,negative看出曾經作過合併)
git merge --no-ff -m "merge with --no-ff" dev
(查看分支歷史 git log --graph --pretty=oneline --abbrev-commit)

 


bug分支(bugg分支爲要解決bug的分支)
思想:當手頭還有工做時,先將工做現場git stash(避免bug修復好後將爲完成的工做一塊兒提交),而後修復bug、提交以後,在用git stash pop將原來的工做顯示在工做區 。
(git status查看狀態)
git stash
git checkout -b bugg
(修改bug後)
git add bugg.txt
git commit -m "fixed bug"
git checkout master
git merge --no-ff -m "merge bug" bugg
git branch -d bugg
(接下來回到dev上繼續工做)
git checkout dev
(查看工做區git status)
(用git stash list查看)
git stash list
(恢復的第一種方法:恢復的同時把stash內容同時刪除)
git stash pop
(恢復的第二種方法:恢復的同時不刪除stash內容)
git stash apply
(若使用第二種方法想刪除stash則用git stash drop)
(如果多個文件stash 可用git stash apply stash@{0}恢復指定的stash)

 


feature分支(分支爲dev)
(在沒徹底完成合並時強行刪除)
git branch -D dev

 


多人協做
(查看遠程庫信息)
git remote
(查看遠程庫更詳細信息)
git remote -v

推送dev分支
git push origin dev

抓取分支
(克隆)
git clone git@github.com:TaylorApril/test.git
(查看能見分支 git branch)
(在dev分支上開發,建立遠程origin的dev分支到本地)
git checkout -b dev origin/dev
(修改後,進行提交)
git commit -m "add"
git push origin dev
(在他提交以後你再push的狀況時)
(指定本地dev分支與遠程origin分支連接)
git branch
git pull
git commit -m "fixed"
git push

 

 

報錯

報錯1

$ git push -u origin master
To git@github.com:TaylorApril/test.git
! [rejected] master -> master (fetch first)
error: failed to push some refs to 'git@github.com:TaylorApril/test.git'
hint: Updates were rejected because the remote contains work that you do
hint: not have locally. This is usually caused by another repository pushing
hint: to the same ref. You may want to first integrate the remote changes
hint: (e.g., 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.


解決:
git pull --rebase origin master
git push -u origin master

 

報錯2

$ git checkout master
Switched to branch 'master'
Your branch is ahead of 'origin/master' by 1 commit.
(use "git push" to publish your local commits)

解決:
git push

相關文章
相關標籤/搜索