1. 程式人生 > >github常用命令彙總

github常用命令彙總

創立版本庫

mkdir Baidu
cd Baidu
git init

SSH
ssh-keygen -t -rsa -C “[email protected]
(在github上new SSH,內容為id_rsa.pub)

新增遠端庫
(github上新建git倉庫,選擇REAMDE.md
git remote add origin [email protected]:TaylorApril/Baidu.git
git push -u origin master
(報錯)
git pull --rebase origin master
git push -u origin master
git push origin master

提交(檔名字read.txt)
git add read.txt
(所有檔案 git add .)
git commit -m “說明文字”
git push

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

撤銷修改

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

刪除檔案(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

解決衝突(分支名字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 [email protected]{0}恢復指定的stash)

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

多人協作
(檢視遠端庫資訊)
git remote
(檢視遠端庫更詳細資訊)
git remote -v

推送dev分支
git push origin dev

抓取分支
(克隆)
git clone [email protected]: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 [email protected]:TaylorApril/test.git
! [rejected] master -> master (fetch first)
error: failed to push some refs to ‘[email protected]: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