1、Git簡介、特點及安裝

介紹:

? ? ? 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

分支管理:

http://www.lxweimin.com/p/905fbf0c446c

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,563評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,694評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,672評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,965評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,690評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,019評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,013評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,188評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,718評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,438評論 3 360
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,667評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,149評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,845評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,252評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,590評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,384評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,635評論 2 380