介紹:
? ? ? Git 是用于 Linux內核開發的版本控制工具。與常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本庫的方式,不必服務器端軟件支持(wingeddevil注:這得分是用什么樣的服務端,使用http協議或者git協議等不太一樣。并且在push和pull的時候和服務器端還是有交互的。),使源代碼的發布和交流極其方便。 Git 的速度很快,這對于諸如 Linux kernel 這樣的大項目來說自然很重要。 Git 最為出色的是它的合并跟蹤(merge tracing)能力。
特點:
? ? ? ?分布式相比于集中式的最大區別在于開發者可以提交到本地,每個開發者通過克?。╣it clone),在本地機器上拷貝一個完整的Git倉庫。下圖是經典的git開發過程。Git的功能特性:?
? ? ? ? ? ? ? 從一般開發者的角度來看,git有以下功能:
1、從服務器上克隆完整的Git倉庫(包括代碼和版本信息)到單機上。
2、在自己的機器上根據不同的開發目的,創建分支,修改代碼。
3、在單機上自己創建的分支上提交代碼。
4、在單機上合并分支。
5、把服務器上最新版的代碼fetch下來,然后跟自己的主分支合并。
6、生成補丁(patch),把補丁發送給主開發者。
7、看主開發者的反饋,如果主開發者發現兩個一般開發者之間有沖突(他們之間可以合作解決的沖突),就會要求他們先解決沖突,然后再由其中一個人提交。如果主開發者可以自己解決,或者沒有沖突,就通過。
8、一般開發者之間解決沖突的方法,開發者之間可以使用pull 命令解決沖突,解決完沖突之后再向主開發者提交補丁。
? ? ? ?從主開發者的角度(假設主開發者不用開發代碼)看,git有以下功能:
1、查看郵件或者通過其它方式查看一般開發者的提交狀態。
2、打上補丁,解決沖突(可以自己解決,也可以要求開發者之間解決以后再重新提交,如果是開源項目,還要決定哪些補丁有用,哪些不用)。
3、向公共服務器提交結果,然后通知所有開發人員。優點:適合分布式開發,強調個體。公共服務器壓力和數據量都不會太大。速度快、靈活。任意兩個開發者之間可以很容易的解決沖突。離線工作。
? ? ? ?缺點:資料少(起碼中文資料很少)。學習周期相對而言比較長。不符合常規思維。代碼保密性差,一旦開發者把整個庫克隆下來就可以完全公開所有代碼和版本信息。
安裝:
1、在Git官網下載安裝包
2.安裝到一個非中文沒有空格的目錄下
3.選擇組件,默認即可
4.選擇開始菜單文件夾,默認即可
5.選擇默認的文本編輯器
6.然后修改環境變量(選第一完全不修改),下面選項第二個(是被認為安全的)? 第二個默認也行
7.選擇客服端本地庫和遠程庫連接方式(1通用連接? 2使用Windows連接方式)
8.選擇換行符的方式(1檢查文件時LF轉為 CRLF 提交相反)
9.選擇終端(1Git默認終端(是liunx命令)2選擇Windows終端(wind命令))
10.選擇git pu的默認行為
11.使用默認(選擇第二個需要安裝.NET framework c4.5.1以上版本)
NET framework安裝失敗解決方案:
https://jingyan.baidu.com/article/fb48e8bee50ebf6e632e1464.html
12.配置實驗選項,默認即可
13.等待下載完成
14.下載完成,這倆選項都可以不打√
15.回到桌面,右鍵有這倆就說明安裝成功了??!
部分命令
一、新建代碼庫
? ? ? ? ? ? ? ? ? ? ? ? ? ?初始化???git init
? ? ? ? ? ? ? ? ? ? ? ? ? ?初始化并命名? ?git init [project name]
? ? ? ? ? ? ? ? ? ? ? ? ? 下載代碼庫? ?git clone [url]
二、配置
git的配置文件為.gitconfig,可以在用戶主目錄,或者項目目錄。
? ? ? ? ? ? ? ? ? ? ? ? ? ?顯示當前git配置? ?git config --list
? ? ? ? ? ? ? ? ? ? ? ? ? ?編輯git配置? ?git config -e [--global]
? ? ? ? ? ? ? ? ? ? ? ? ? ?設置提交代碼使用的用戶信息? ?git config [--global] user.name "name"
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? git config [--global] user.emal "address"
三、增加、刪除
? ? ? ? ? ? ? ? ? ? ? ? ? ?增加文件或目錄到暫存區? ?git add [file1] [file2]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? git add [dir]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 對于同一個文件的多出變化,可以分次提交? ?git add -p
? ? ? ? ? ? ? ? ? ? ? ? ? ? 刪除工作區文件,并將刪除文件放入暫存區? ?git rm [file1] [file2]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 停止追蹤文件,該文件會保留在工作區? ?git rm --cached [file]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 改名文件,并將這個改名過程放入暫存區? ?git mv [file-old] [file-new]?
四、代碼提交
? ? ? ? ? ? ? ? ? ? ? ? ? ? 提交代碼到倉庫? ?git commit -m [message]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 提交暫存區制定文件到倉庫? ?git commit [file1] [file2] ... -m [message]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 直接提交所有變化到倉庫區? ?git commit -a
? ? ? ? ? ? ? ? ? ? ? ? ? ? 提交時顯示所有diff信息? ?git commit -v
? ? ? ? ? ? ? ? ? ? ? ? ? ? 使用新的commit替代上一次,如果沒有變化,則使用新的commit提交信息
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? git commit --amend -m [message]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 重做上一次commit,并包括指定文件新變化? ?git commit --amend [file1] [file2] ...
五、分支
? ? ? ? ? ? ? ? ? ? ? ? ? ? 列出本地分支? ?git branch
? ? ? ? ? ? ? ? ? ? ? ? ? ? 列出遠程分支? ?git branch -r
? ? ? ? ? ? ? ? ? ? ? ? ? ? 列出所有本地和遠程分支? ?git branch -a
? ? ? ? ? ? ? ? ? ? ? ? ? ? 新建一個分支,但仍停留在當前分支? ?git branch [name]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 新建一個分支,并切換? ?git branch -b [name]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ?新建一個分支,并指定遠程分支追蹤? ?git branch --track [name] [remote-name]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ?切換到分支,并更新工作區? ?git checkout [name]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ?切換到上一個分支? ?git checkout -
? ? ? ? ? ? ? ? ? ? ? ? ? ? 在現有分支與指定遠程分支間建立追蹤? ?git branch --set-upstream [name] [remote-name]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 合并指定分支到當前分支? ?git merge [name]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 選擇一個commit,合并到當前分支? ?git cherry-pick [commit]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 刪除分支? ?git branch -d [name]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 刪除遠程分支? ?git push origin --delete [name]? ?git branch -dr [name/remote-name]
六、標簽
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 列出tag? ?git tag
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 新建一個tag在當前commit? ?git tag [tag]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 新建一個tag在指定commit? ?git tag [tag] [commit]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 刪除本地tag? ?git tag -d [tag]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 刪除遠程tag? ?git push origin:refs/tags/[tagName]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 查看tag信息? ?git show [tag]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 提交指定tag? ?git push [remote] [tag]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 提交所有tag? ?git push [remote] --tags
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 新建一個分支,指向某個tag? ?git checkout -b [branch] [tag]
七、查看信息
? ? ? ? ? ? ? ? ? ? ? ? ?顯示變更? ?git status
? ? ? ? ? ? ? ? ? ? ? ? ?顯示當前分支版本歷史? ?git log
? ? ? ? ? ? ? ? ? ? ? ? ?顯示commit歷史,及變更? ?git log --stat
? ? ? ? ? ? ? ? ? ? ? ? ?搜索提交歷史,根據關鍵詞? ??git log -S [keyword]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示某個commit之后所有變動,每個commit占一行? ?git log [tag] HEAD --pretty=format:%s
? ? ? ? ? ? ? ? ? ? ? ? ?顯示某個commit之后所有變動,提交說明必須符合搜索條件? ?git log [tag] HEAD --grep feature
? ? ? ? ? ? ? ? ? ? ? ? ?顯示某個文件的歷史版本,包括名字改變? ?git log --follow [file]? ?git whatchanged [file]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示指定文件的每一次diff? ?git log -p [file]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示過去5次提交? ?git log -5 --pretty --oneline
? ? ? ? ? ? ? ? ? ? ? ? ?顯示所有提交過的用戶,按次數排序? ??git shortlog -sn
? ? ? ? ? ? ? ? ? ? ? ? ?顯示文件修改詳情? ?git blame [file]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示工作區和暫存區差異? ?git diff
? ? ? ? ? ? ? ? ? ? ? ? ?顯示暫存區和上一個diff差異? ?git diff --cached [file]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示工作區與當前分支最新commit的差異? ?git diff HEAD
? ? ? ? ? ? ? ? ? ? ? ? ?顯示兩次提交之間的差異? ?git diff [first-branch] ... [second-branch]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示今天寫的代碼量? ?git diff --shortstat "@{0 day ago}"
? ? ? ? ? ? ? ? ? ? ? ? ?顯示某次提交元數據和內容變化? ?git show [commit]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示某次提交發生變化的文件? ?git show --name-only [commit]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示某次提交時,某個文件的內容? ?git show [commit]:[filename]
? ? ? ? ? ? ? ? ? ? ? ? ?顯示當前分支的最近幾次提交? ?git reflog
八、遠程同步
? ? ? ? ? ? ? ? ? ? ? ? ? ?下載遠程倉庫所有變動? ?git fetch [remot]
? ? ? ? ? ? ? ? ? ? ? ? ? ?顯示所有遠程倉庫? ?git remote -v
? ? ? ? ? ? ? ? ? ? ? ? ? ?顯示遠程倉庫信息? ?git remote show [remote]
? ? ? ? ? ? ? ? ? ? ? ? ? ?增加一個新的遠程倉庫并命名? ?git remote add [shortname] [url]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 取回遠程倉庫的變化,并與本地分支合并? ?git pull [remote] [branch]
? ? ? ? ? ? ? ? ? ? ? ? ? ?上傳本地指定分支到遠程倉庫? ?git push [remote] [branch]
? ? ? ? ? ? ? ? ? ? ? ? ? ? 強行推送當前分支到遠程倉庫,即使有沖突? ?git push [remote] --force
? ? ? ? ? ? ? ? ? ? ? ? ? ?推送所有分支到遠程倉庫? ?git push [remote] --all
九、撤銷
? ? ? ? ? ? ? ? ? ? ? ? ? ?恢復暫存區的制定文件到工作區? ?git checkout [file]
? ? ? ? ? ? ? ? ? ? ? ? ? ?恢復某個commit的指定文件到暫存區和工作區? ?git checkout [commit] [file]
? ? ? ? ? ? ? ? ? ? ? ? ? ?恢復暫存區的所有文件到工作區? ?git checkout
? ? ? ? ? ? ? ? ? ? ? ? ? ?重置暫存區的指定文件,與上一次commit保持一致,但工作區不變? ?git reset --hard
? ? ? ? ? ? ? ? ? ? ? ? ? ?重置當前分支的指針為制定commit,同時重置暫存區,但工作區不變? ?gite reset [commit]
? ? ? ? ? ? ? ? ? ? ? ? ? ?重置當前分支的HEAD為指定commit,通知重置暫存區和工作區,與指定commit一致
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?git reset --hard [commit]
? ? ? ? ? ? ? ? ? ? ? ? ? ?重置當前HEAD為指定commit,但保持暫存區和工作區不變? ?git reset --keep [commit]
? ? ? ? ? ? ? ? ? ? ? ? ? ?新建一個commit,用以撤銷指定commit,后者所有變化都被前者抵消,并應用到當前分支
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? git revert [commit]
? ? ? ? ? ? ? ? ? ? ? ? ? ?暫時將未提交的變化移除,稍后再移入? ?git stash? ??git stash pop
十、其他
? ? ? ? ? ? ? ? ? ? ? ? ? ?生成一個可供發布的壓縮包? ?git archive
命令行操作:
http://www.lxweimin.com/p/5f2afef2562c