git常用命令
注意:請確保已經安裝里git客戶端
git使用幫助
git --help? ? //git使用幫助,可以查看git使用指令
一般配置
git --version ???? //查看git的版本信息
git config --global user.name 'username'? ?????//配置當前登錄的用戶
git config --global user.email 'email'? ?//配置當前登錄用戶的郵箱
git初始化
git init
查看目錄
ls? 或者 ls -al
查看文件
cat filename
增加到暫存區、取消增加
git add filename? ? //添加單個文件
git add . 或者git add -a? ? ?//添加所有未被忽略的文件
git reset HEAD index.html? ? ? //取消
增加到版本庫中
git commit -m "提交備注信息"
查看歷史提交
git log
比較差異
git diff? ?//比較的是暫存區和工作區的差異
git diff --cached? ? ?//比較的是暫存區和歷史區的差異
git diff master? ? //比較的是歷史區和工作區的差異(修改)
刪除
rm fileName? ? ?//刪除文件
git rm index.html --cached? ? //刪除暫存區
回滾
git reset --hard HEAD/commit_id
分支管理
git branch dev? ? //創建分支
git check dev? ? ?//切換分支
git checkout -b dev? ? //創建分支并切換分支
git branch -d dev? ? //刪除分支
git commit -a -m 'dev1' //分支上提交
git merge dev? //合并分支
git stash? ? //保留改動
git stash drop? ? //廢棄保留的內容
git stash pop? ? ?//使用保留的內容
git rebase? ? //合并分支
添加到遠程倉庫
git push -u origin master???? //獲取最新代碼
git remote add origin 倉庫的地址? ? //連接遠程倉庫
git remote -v? ? //查看遠程倉庫
git remote rm origin? ? //刪除遠程倉庫
更新代碼,合并沖突
git pull? ? ?//更新代碼
解決沖突(具體遇到時再貼圖完善)
根據更新代碼時的沖突日志,找到沖突文件,合并代碼,重新提交
以上為基礎的使用方式,以后有時間再完善。
git submodule 管理項目子模塊
使用場景:
當項目越來越龐大之后,不可避免的要拆分成多個子模塊,我們希望各個子模塊有獨立的版本管理,并且由專門的人去維護,這時候我們就要用到git的submodule功能。
什么是Submodule?
git Submodule是一個很好的多項目使用共同類庫的工具,他允許類庫項目做為repository,子項目做為一個單獨的git項目存在父項目中,子項目可以有自己的獨立的commit,push,pull。而父項目以Submodule的形式包含子項目,父項目可以指定子項目header,父項目中會的提交信息包含Submodule的信息,再clone父項目的時候可以把Submodule初始化。
常用指令:
git clone git地址?--recursive 遞歸的方式克隆整個項目
git submodule add 添加子模塊
git submodule init 初始化子模塊
git submodule update 更新子模塊
git submodule foreach git pull 拉取所有子模塊
使用:
1. 創建帶子模塊的版本庫
例如我們要創建如下結構的項目
project??
|--moduleA
|--readme.txt
創建project版本庫,并提交readme.txt文件
git init --bare project.git
git clone project.git project1
cd project1
echo"This is a project."> readme.txt
git add .
git commit -m "add readme.txt"
git push origin master
cd..
創建moduleA版本庫,并提交a.txt文件
git init --bare moduleA.git
git clone moduleA.git moduleA1
cd moduleA1
echo"This is a submodule."> a.txt
git add .
git commit -m"add a.txt"
git push origin master
cd..
在project項目中引入子模塊moduleA,并提交子模塊信息
cd project1
git submodule add ../moduleA.git moduleA
git status
git diff
git add .
gitcommit-m"add submodule"
git push originmastercd ..
使用git status可以看到多了兩個需要提交的文件,其中.gitmodules指定submodule的主要信息,包括子模塊的路徑和地址信息,moduleA指定了子模塊的commit id,使用git diff可以看到這兩項的內容。這里需要指出父項目的git并不會記錄submodule的文件變動,它是按照commit id指定submodule的git header,所以.gitmodules和moduleA這兩項是需要提交到父項目的遠程倉庫的。
Onbranch masterYour branchisup-to-datewith'origin/master'.Changestobe committed:? (use"git reset HEAD ..."tounstage)newfile:? .gitmodulesnewfile:? moduleA
2. 克隆帶子模塊的版本庫
方法一,先clone父項目,再初始化submodule,最后更新submodule,初始化只需要做一次,之后每次只需要直接update就可以了,需要注意submodule默認是不在任何分支上的,它指向父項目存儲的submodule commit id。
git clone project.git project2
cd project2
git submodule init
git submodule update
cd..
方法二,采用遞歸參數--recursive,需要注意同樣submodule默認是不在任何分支上的,它指向父項目存儲的submodule commit id。
git clone project.git project3 --recursive
3. 修改子模塊
修改子模塊之后只對子模塊的版本庫產生影響,對父項目的版本庫不會產生任何影響,如果父項目需要用到最新的子模塊代碼,我們需要更新父項目中submodule commit id,默認的我們使用git status就可以看到父項目中submodule commit id已經改變了,我們只需要再次提交就可以了。
先提交子模塊
cd project1/moduleA
git add .git commit -m"add b.txt"
git push origin master
再提交project
cd..
git status
git diff
git add .
git commit -m"update submodule add b.txt"
git push origin mastercd..
4. 更新子模塊
更新子模塊的時候要注意子模塊的分支默認不是master。
方法一,先pull父項目,然后執行git submodule update,注意moduleA的分支始終不是master。
cd project2
git pull
git submodule update
cd..
方法二,先進入子模塊,然后切換到需要的分支,這里是master分支,然后對子模塊pull,這種方法會改變子模塊的分支。
cd project3/moduleA
git checkout master
cd..
git submodule foreach git pull
cd..
5. 刪除子模塊
網上有好多用的是下面這種方法
git rm--cached moduleA
rm -rf moduleA
rm .gitmodules
vim .git/config
刪除submodule相關的內容,例如下面的內容
[submodule"moduleA"]? ? ? url =/Users/nick/dev/nick-doc/testGitSubmodule/moduleA.git
然后提交到遠程服務器
git add .
gitcommit-m"remove submodule"
但是我自己本地實驗的時候,發現用下面的方式也可以,服務器記錄的是.gitmodules和moduleA,本地只要用git的刪除命令刪除moduleA,再用git status查看狀態就會發現.gitmodules和moduleA這兩項都已經改變了,至于.git/config,仍會記錄submodule信息,但是本地使用也沒發現有什么影響,如果重新從服務器克隆則.git/config中不會有submodule信息。
git rm moduleA
git status
gitcommit-m"remove submodule"
git push origin master
Jenkins應用git submodule
Jenkins用來做項目的持續集成,如果使用了Git Submodule,每次Jenkins更新版本庫的時候還需要更新submodule的內容。
1、確保你已經下載并能使用Jenkins,如果沒有,自己去下載Jenkins
2、具體配置
新建自由風格項目,設置項目更新submodule
?Add Credentials(訪問git用到的用戶配置,不然會連接不上git倉庫)
其他構建配置:
具體構建問題可以通過構建日志去查看,排查,解決,這里就不做詳細說明了。