在linux中,安裝git的命令是“yum install git”;yum是“Yellow dog Updater Modified”的簡(jiǎn)稱(chēng),yum用于自動(dòng)化地升級(jí)、安裝、移除rpm包,收集rpm包的相關(guān)信息,檢查依賴(lài)性并自動(dòng)提示用戶(hù)解決,因此可以利用yum來(lái)安裝git。
本教程操作環(huán)境:linux7.3系統(tǒng)、Dell G3電腦。
linux安裝git的命令是什么
Git官網(wǎng)
https://git-scm.com/
安裝Git
[root@git ~]# yum install git #git的安裝,直接使用yum安裝
查看版本
[root@git ~]# git --version #查看git的版本git version 1.8.3.1
擴(kuò)展知識(shí):
git個(gè)人身份設(shè)置
git是分布式版本控制系統(tǒng),所以每個(gè)開(kāi)發(fā)者都應(yīng)該在自己的筆記本上安裝Git,然后在git上設(shè)置自己的個(gè)人身份信息。
[root@git ~]# git config --global user.name "lisi" #設(shè)置用戶(hù)姓名[root@git ~]# git config --global user.emain "456789123@qq.com" #設(shè)置郵箱[root@git ~]# git config --global color.ui true #enable ui顏色[root@git ~]# git config --list #查看配置user.name=lisi user.emain=456789123@qq.com color.ui=true[root@git ~]#
Git 的三大核心框架
工作區(qū)域(Working Directory):就是開(kāi)發(fā)者平時(shí)存放項(xiàng)目代碼的目錄;
暫存區(qū)域(Stage):用于臨時(shí)存放開(kāi)發(fā)者代碼的改動(dòng),事實(shí)上它只是一個(gè)文件,保存即將提交的文件列表信息;
Git 倉(cāng)庫(kù)(Repository):就是安全存放數(shù)據(jù)的位置,git倉(cāng)庫(kù)有開(kāi)發(fā)者提交的所有版本的數(shù)據(jù)代碼,其中,HEAD 指向最新放入倉(cāng)庫(kù)的版本。
Git 的工作流程一般是:
1、在工作目錄中添加、修改代碼文件;
2、將需要進(jìn)行版本管理的代碼文件放入暫存區(qū)域;
3、將暫存區(qū)域的文件提交到 Git 倉(cāng)庫(kù)。
因此,Git 管理的文件有三種狀態(tài):已修改(modified)、已暫存(staged)和已提交(committed),依次對(duì)應(yīng)上邊的每一個(gè)流程。
git命令實(shí)踐
1、創(chuàng)建并初始化一個(gè)項(xiàng)目目錄,在該目錄下進(jìn)行存放編輯代碼;
[root@git ~]# mkdir Dosier_Project #創(chuàng)建一個(gè)項(xiàng)目代碼目錄 [root@git ~]# cd Dosier_Project/ #進(jìn)入目錄 [root@git Dosier_Project]# git init #初始化目錄,讓目錄受到git版本控制 Initialized empty Git repository in /root/Dosier_Project/.git/ #初始化了一個(gè)空的git倉(cāng)庫(kù) [root@git Dosier_Project]# ll -al #查看該目錄 total 0 drwxr-xr-x 3 root root 18 Jan 31 16:15 . dr-xr-x---. 5 root root 215 Jan 31 16:14 .. drwxr-xr-x 7 root root 119 Jan 31 16:15 .git #發(fā)現(xiàn)git init初始化命令就是生成了.git目錄,這個(gè).git目錄就是git倉(cāng)庫(kù),以后在Dosier_Project目錄下做的所有操作就可以受到git版本控制了 [root@git Dosier_Project]#
2、模擬開(kāi)發(fā)工程師開(kāi)發(fā)代碼文件
[root@git Dosier_Project]# cd /root/Dosier_Project/ #進(jìn)去到項(xiàng)目目錄 [root@git Dosier_Project]# vim dossier.sh #創(chuàng)建一個(gè)代碼文件 [root@git Dosier_Project]#
3、git add把代碼文件提交到暫存區(qū)
[root@git Dosier_Project]# git status #查看狀態(tài) # On branch master # # Initial commit # # Untracked files: # (use "git add <file>..." to include in what will be committed) # # dossier.sh nothing added to commit but untracked files present (use "git add" to track) #解釋?zhuān)篣ntracked files 說(shuō)明存在未跟蹤的文件(下邊紅色的那個(gè)) #所謂的“未跟蹤”文件,是指那些新添加的并且未被加入到暫存區(qū)域或提交的文件。它們處于一個(gè)逍遙法外的狀態(tài),當(dāng)你一旦將它們加入暫存區(qū)域或提交到 Git 倉(cāng)庫(kù),它們就開(kāi)始受到 Git 的“跟蹤”了 [root@git Dosier_Project]# git add dossier.sh #用git add命令把文件提交暫存區(qū) [root@git Dosier_Project]# git status #再次查看狀態(tài) # On branch master # # Initial commit # # Changes to be committed: #意思是要提交的更改,等待提交 # (use "git rm --cached <file>..." to unstage) # # new file: dossier.sh #暫存區(qū)已經(jīng)有一個(gè)文件了 # [root@git Dosier_Project]#
4、git commit 把暫存區(qū)的所有文件提交到git倉(cāng)庫(kù)
git commit 是把暫存區(qū)的所有文件提交到git倉(cāng)庫(kù),并不是指提交某個(gè)文件。
[root@git Dosier_Project]# git commit -m "lisi add dossier.sh file" #提交暫存區(qū)內(nèi)的文件到git倉(cāng)庫(kù),-m參數(shù)表示寫(xiě)的注釋 [master (root-commit) c2b3806] lisi add dossier.sh file 1 file changed, 2 insertions(+) create mode 100644 dossier.sh [root@git Dosier_Project]# git status #再次查看狀態(tài),提示暫存區(qū)沒(méi)有要commit的,工作目錄文件也沒(méi)有編輯過(guò) # On branch master nothing to commit, working directory clean [root@git Dosier_Project]#
5、繼續(xù)模擬版本2、版本3
#模擬版本2,模擬版本2為修改dossier_1.sh文件,新加一個(gè)dossier_2.sh文件 [root@git ~]# cd ~/Dosier_Project/ [root@git Dosier_Project]# echo "I am good dossier_1" >> dossier_1.sh #修改了dossier_1.sh文件 [root@git Dosier_Project]# touch dossier_2.sh #新加dossier_2.sh文件 [root@git Dosier_Project]# echo "I am dossier_2" >> dossier_2.sh [root@git Dosier_Project]# git add * #星號(hào)匹配所有(等價(jià)于--all),把所有文件提交暫存區(qū) [root@git Dosier_Project]# git commit -m "modified dossier_1.sh,add dossier_2.sh" #git commit提交暫存區(qū)文件到倉(cāng)庫(kù) [master beff2ea] modified dossier_1.sh,add dossier_2.sh 2 files changed, 2 insertions(+) create mode 100644 dossier_2.sh [root@git Dosier_Project]# git status #查看狀態(tài),三大區(qū)域已經(jīng)一致 # On branch master nothing to commit, working directory clean #繼續(xù)模擬版本3,繼續(xù)模擬版本3為新加一個(gè)dossier_3.sh文件 [root@git Dosier_Project]# touch dossier_3.sh #新加一個(gè)dossier_3.sh文件 [root@git Dosier_Project]# echo "I am dossier_3">> dossier_3.sh [root@git Dosier_Project]# git add dossier_3.sh #把dossier_3.sh提交到暫存區(qū) [root@git Dosier_Project]# git commit -m "Add dossier_3.sh" #把暫存區(qū)內(nèi)容提交到git倉(cāng)庫(kù) [master 72cd563] Add dossier_3.sh 1 file changed, 1 insertion(+) create mode 100644 dossier_3.sh [root@git Dosier_Project]# git status #查看狀態(tài),三大區(qū)域已經(jīng)一致 # On branch master nothing to commit, working directory clean [root@git Dosier_Project]# 以上,我們就創(chuàng)建了3個(gè)版本,版本1為創(chuàng)建dossier_1.sh文件,版本2為修改dossier_1.sh文件,新加一個(gè)dossier_2.sh文件,模擬版本3為新加一個(gè)dossier_3.sh文件 #查看狀態(tài),三大區(qū)域已經(jīng)一致# On branch masternothing to commit, working directory clean[root@git Dosier_Project]# 以上,我們就創(chuàng)建了3個(gè)版本,版本1為創(chuàng)建dossier_1.sh文件,版本2為修改dossier_1.sh文件,新加一個(gè)dossier_2.sh文件,模擬版本3為新加一個(gè)dossier_3.sh文件
6、git log 命令、git reflog 命令查看git倉(cāng)庫(kù)中有哪些版本
git log 和git reflog 命令都可以查看git倉(cāng)庫(kù)中有哪些版本,但兩者的區(qū)別在于git log只能看得到當(dāng)前的版本,而git reflog可以看得到所有的版本,也就是說(shuō)當(dāng)你回退版本之后,git reflog可以查看得到回退之前的版本,所有一般使用git reflog即可。
[root@git Dosier_Project]# git log #git log命令查看git倉(cāng)庫(kù)中有哪些版本commit 72cd563e2e0241670d7ebe8c541f28a12875e1e8 Author: lisi <456789123@qq.com>Date: Mon Jan 31 18:05:42 2022 +0800 Add dossier_3.sh commit beff2eaf816f345ba39779494752228a06ac1499 Author: lisi <456789123@qq.com>Date: Mon Jan 31 18:01:03 2022 +0800 modified dossier_1.sh,add dossier_2.sh commit ae2c1b8752efd01ef265e2227dd0b4ceb81310f4 Author: lisi <456789123@qq.com>Date: Mon Jan 31 17:53:32 2022 +0800 Add dossier_1.sh[root@git Dosier_Project]# git reflog #git reflog命令查看git倉(cāng)庫(kù)中有哪些版本72cd563 HEAD@{0}: commit: Add dossier_3.sh beff2ea HEAD@{1}: commit: modified dossier_1.sh,add dossier_2.sh ae2c1b8 HEAD@{2}: commit (initial): Add dossier_1.sh[root@git Dosier_Project]#
7、git reset –hard 版本號(hào),實(shí)現(xiàn)版本自由回退
[root@git Dosier_Project]# git reflog #git reflog命令查看git倉(cāng)庫(kù)中有哪些版本,前面的字符就是版本號(hào)72cd563 HEAD@{0}: commit: Add dossier_3.sh beff2ea HEAD@{1}: commit: modified dossier_1.sh,add dossier_2.sh ae2c1b8 HEAD@{2}: commit (initial): Add dossier_1.sh[root@git Dosier_Project]# git reset --hard beff2ea #回退到版本2,即修改dossier_1.sh文件,新加dossier_2.shHEAD is now at beff2ea modified dossier_1.sh,add dossier_2.sh[root@git Dosier_Project]# ll #查看文件,已經(jīng)沒(méi)有了dossier_3.sh文件total 8-rw-r--r-- 1 root root 35 Jan 31 17:56 dossier_1.sh -rw-r--r-- 1 root root 15 Jan 31 17:56 dossier_2.sh[root@git Dosier_Project]# cat dossier_1.sh #dossier_1.sh的最后一行也確實(shí)實(shí)在版本2時(shí)候添加的I am dossier_1 I am good dossier_1[root@git Dosier_Project]# git reset --hard ae2c1b8 #回退到版本1HEAD is now at ae2c1b8 Add dossier_1.sh[root@git Dosier_Project]# lltotal 4-rw-r--r-- 1 root root 15 Jan 31 18:38 dossier_1.sh #已經(jīng)回退到版本1[root@git Dosier_Project]# cat dossier_1.sh #已經(jīng)回退到版本1I am dossier_1 [root@git Dosier_Project]#[root@git Dosier_Project]# git reflog #git reflog命令可以看到你所有的版本已經(jīng)回退版本的記錄ae2c1b8 HEAD@{0}: reset: moving to ae2c1b8 beff2ea HEAD@{1}: reset: moving to beff2ea 72cd563 HEAD@{2}: commit: Add dossier_3.sh beff2ea HEAD@{3}: commit: modified dossier_1.sh,add dossier_2.sh ae2c1b8 HEAD@{4}: commit (initial): Add dossier_1.sh[root@git Dosier_Project]# git reset --hard 72cd563 #為了后面實(shí)驗(yàn),現(xiàn)在還是回退到版本3吧HEAD is now at 72cd563 Add dossier_3.sh[root@git Dosier_Project]# ll #已經(jīng)回退到版本3了total 12-rw-r--r-- 1 root root 35 Jan 31 18:44 dossier_1.sh -rw-r--r-- 1 root root 15 Jan 31 18:44 dossier_2.sh -rw-r--r-- 1 root root 15 Jan 31 18:44 dossier_3.sh[root@git Dosier_Project]#
8、git checkout – filename,撤銷(xiāo)文件修改(文件未提交到暫存區(qū))
開(kāi)發(fā)工程師修改了某個(gè)文件,文件未提交到暫存區(qū),需要撤銷(xiāo)文件修改,可以通過(guò)刪除文件內(nèi)容達(dá)到恢復(fù)文件最開(kāi)始狀態(tài),但如果是修改了很多,甚至連自己都不知道要?jiǎng)h除哪些內(nèi)容了,這時(shí)可以使用git checkout命令:
[root@git Dosier_Project]# echo "testesshfkshdsjdhjshka" >> dossier_3.sh [root@git Dosier_Project]# cat dossier_3.shI am dossier_3 testesshfkshdsjdhjshka[root@git Dosier_Project]# git checkout -- dossier_3.sh #撤銷(xiāo)文件修改,注意命令--后面是空格接文件名[root@git Dosier_Project]# cat dossier_3.sh #已經(jīng)撤銷(xiāo)成功I am dossier_3[root@git Dosier_Project]#
9、git reset HEAD file,撤銷(xiāo)暫存區(qū)的文件
[root@git Dosier_Project]# echo "boss is good ">>dossier_3.sh #編輯一點(diǎn)內(nèi)容[root@git Dosier_Project]# git add dossier_3.sh #提交暫存區(qū),這時(shí)突然反悔了,需要從暫存區(qū)撤銷(xiāo)該文件[root@git Dosier_Project]# git status# On branch master# Changes to be committed:# (use "git reset HEAD <file>..." to unstage) #這里已經(jīng)提示了,撤銷(xiāo)暫存區(qū)文件使用git reset HEAD## modified: dossier_3.sh#[root@git Dosier_Project]# git reset HEAD dossier_3.sh #撤銷(xiāo)暫存區(qū)內(nèi)的指定文件Unstaged changes after reset: M dossier_3.sh[root@git Dosier_Project]#
10、刪除一個(gè)文件并git rm提交到暫存區(qū)
[root@git Dosier_Project]# rm -rf dossier_1.sh #當(dāng)文件不需要了直接rm -rf刪除一個(gè)文件[root@git Dosier_Project]# git status #查看狀態(tài)# On branch master# Changes not staged for commit:# (use "git add/rm <file>..." to update what will be committed) #這里其實(shí)已經(jīng)提示你使用add或rm參數(shù)了# (use "git checkout -- <file>..." to discard changes in working directory)## deleted: dossier_1.sh#no changes added to commit (use "git add" and/or "git commit -a")[root@git Dosier_Project]# git rm dossier_1.sh #提交暫存區(qū)[root@git Dosier_Project]# git commit -m "delete dossier_1.sh" #把暫存區(qū)內(nèi)容commit提交git倉(cāng)庫(kù)
推薦學(xué)習(xí):Linux視頻教程