linux安裝git的命令是什麼

2022-06-30 18:00:38

在linux中,安裝git的命令是「yum install git」;yum是「Yellow dog Updater Modified」的簡稱,yum用於自動化地升級、安裝、移除rpm包,收集rpm包的相關資訊,檢查依賴性並自動提示使用者解決,因此可以利用yum來安裝git。

本教學操作環境:linux7.3系統、Dell G3電腦。

linux安裝git的命令是什麼

Git官網

https://git-scm.com/

安裝Git

[root@git ~]# yum install git						#git的安裝,直接使用yum安裝

檢視版本

[root@git ~]# git --version							#檢視git的版本git version 1.8.3.1

擴充套件知識:

git個人身份設定

git是分散式版本控制系統,所以每個開發者都應該在自己的筆電上安裝Git,然後在git上設定自己的個人身份資訊。

[root@git ~]# git config --global user.name "lisi"						#設定使用者姓名[root@git ~]# git config --global user.emain "[email protected]"			#設定郵箱[root@git ~]# git config --global color.ui true							#enable ui顏色[root@git ~]# git config --list											#檢視設定user.name=lisi
[email protected]
color.ui=true[root@git ~]#

Git 的三大核心框架

工作區域(Working Directory):就是開發者平時存放專案程式碼的目錄;
暫存區域(Stage):用於臨時存放開發者程式碼的改動,事實上它只是一個檔案,儲存即將提交的檔案列表資訊;
Git 倉庫(Repository):就是安全存放資料的位置,git倉庫有開發者提交的所有版本的資料程式碼,其中,HEAD 指向最新放入倉庫的版本。
在這裡插入圖片描述
Git 的工作流程一般是:
1、在工作目錄中新增、修改程式碼檔案;
2、將需要進行版本管理的程式碼檔案放入暫存區域;
3、將暫存區域的檔案提交到 Git 倉庫。

因此,Git 管理的檔案有三種狀態:已修改(modified)、已暫存(staged)和已提交(committed),依次對應上邊的每一個流程。

git命令實踐

1、建立並初始化一個專案目錄,在該目錄下進行存放編輯程式碼;

[root@git ~]# mkdir Dosier_Project									#建立一個專案程式碼目錄
[root@git ~]# cd Dosier_Project/									#進入目錄
[root@git Dosier_Project]# git init									#初始化目錄,讓目錄受到git版本控制
Initialized empty Git repository in /root/Dosier_Project/.git/		#初始化了一個空的git倉庫
[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						
#發現git init初始化命令就是生成了.git目錄,這個.git目錄就是git倉庫,以後在Dosier_Project目錄下做的所有操作就可以受到git版本控制了
[root@git Dosier_Project]#

2、模擬開發工程師開發程式碼檔案

[root@git Dosier_Project]# cd /root/Dosier_Project/				#進去到專案目錄
[root@git Dosier_Project]# vim dossier.sh 						#建立一個程式碼檔案
[root@git Dosier_Project]#

3、git add把程式碼檔案提交到暫存區

[root@git Dosier_Project]# git status								#檢視狀態
# 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)
#解釋:Untracked files 說明存在未跟蹤的檔案(下邊紅色的那個)
#所謂的「未跟蹤」檔案,是指那些新新增的並且未被加入到暫存區域或提交的檔案。它們處於一個逍遙法外的狀態,當你一旦將它們加入暫存區域或提交到 Git 倉庫,它們就開始受到 Git 的「跟蹤」了
[root@git Dosier_Project]# git add dossier.sh 					#用git add命令把檔案提交暫存區
[root@git Dosier_Project]# git status         					#再次檢視狀態
# On branch master
#
# Initial commit
#
# Changes to be committed:											#意思是要提交的更改,等待提交
#   (use "git rm --cached <file>..." to unstage)
#
#       new file:   dossier.sh										#暫存區已經有一個檔案了
#
[root@git Dosier_Project]#

4、git commit 把暫存區的所有檔案提交到git倉庫
git commit 是把暫存區的所有檔案提交到git倉庫,並不是指提交某個檔案。

[root@git Dosier_Project]# git commit -m "lisi add dossier.sh file"		#提交暫存區內的檔案到git倉庫,-m參數列示寫的註釋
[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				#再次檢視狀態,提示暫存區沒有要commit的,工作目錄檔案也沒有編輯過
# On branch master
nothing to commit, working directory clean
[root@git Dosier_Project]#

5、繼續模擬版本2、版本3

#模擬版本2,模擬版本2為修改dossier_1.sh檔案,新加一個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 *										#星號匹配所有(等價於--all),把所有檔案提交暫存區
[root@git Dosier_Project]# git commit -m "modified dossier_1.sh,add dossier_2.sh"	#git commit提交暫存區檔案到倉庫
[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										#檢視狀態,三大區域已經一致
# On branch master
nothing to commit, working directory clean

#繼續模擬版本3,繼續模擬版本3為新加一個dossier_3.sh檔案
[root@git Dosier_Project]# touch dossier_3.sh								#新加一個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提交到暫存區
[root@git Dosier_Project]# git commit -m "Add dossier_3.sh"					#把暫存區內容提交到git倉庫
[master 72cd563] Add dossier_3.sh
 1 file changed, 1 insertion(+)
 create mode 100644 dossier_3.sh
[root@git Dosier_Project]# git status										#檢視狀態,三大區域已經一致
# On branch master
nothing to commit, working directory clean
[root@git Dosier_Project]# 

以上,我們就建立了3個版本,版本1為建立dossier_1.sh檔案,版本2為修改dossier_1.sh檔案,新加一個dossier_2.sh檔案,模擬版本3為新加一個dossier_3.sh檔案										#檢視狀態,三大區域已經一致# On branch masternothing to commit, working directory clean[root@git Dosier_Project]# 以上,我們就建立了3個版本,版本1為建立dossier_1.sh檔案,版本2為修改dossier_1.sh檔案,新加一個dossier_2.sh檔案,模擬版本3為新加一個dossier_3.sh檔案

6、git log 命令、git reflog 命令檢視git倉庫中有哪些版本
git log 和git reflog 命令都可以檢視git倉庫中有哪些版本,但兩者的區別在於git log只能看得到當前的版本,而git reflog可以看得到所有的版本,也就是說當你回退版本之後,git reflog可以檢視得到回退之前的版本,所有一般使用git reflog即可。

[root@git Dosier_Project]# git log									#git log命令檢視git倉庫中有哪些版本commit 72cd563e2e0241670d7ebe8c541f28a12875e1e8
Author: lisi <[email protected]>Date:   Mon Jan 31 18:05:42 2022 +0800

    Add dossier_3.sh

commit beff2eaf816f345ba39779494752228a06ac1499
Author: lisi <[email protected]>Date:   Mon Jan 31 18:01:03 2022 +0800

    modified dossier_1.sh,add dossier_2.sh

commit ae2c1b8752efd01ef265e2227dd0b4ceb81310f4
Author: lisi <[email protected]>Date:   Mon Jan 31 17:53:32 2022 +0800

    Add dossier_1.sh[root@git Dosier_Project]# git reflog								#git reflog命令檢視git倉庫中有哪些版本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 版本號,實現版本自由回退

[root@git Dosier_Project]# git reflog								#git reflog命令檢視git倉庫中有哪些版本,前面的字元就是版本號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										#檢視檔案,已經沒有了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的最後一行也確實實在版本2時候新增的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					#已經回退到版本1[root@git Dosier_Project]# cat dossier_1.sh 						#已經回退到版本1I am dossier_1	
[root@git Dosier_Project]#[root@git Dosier_Project]# git reflog								#git reflog命令可以看到你所有的版本已經回退版本的記錄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					#為了後面實驗,現在還是回退到版本3吧HEAD is now at 72cd563 Add dossier_3.sh[root@git Dosier_Project]# ll 										#已經回退到版本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,復原檔案修改(檔案未提交到暫存區)
開發工程師修改了某個檔案,檔案未提交到暫存區,需要復原檔案修改,可以通過刪除檔案內容達到恢復檔案最開始狀態,但如果是修改了很多,甚至連自己都不知道要刪除哪些內容了,這時可以使用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				#復原檔案修改,注意命令--後面是空格接檔名[root@git Dosier_Project]# cat dossier_3.sh            				#已經復原成功I am dossier_3[root@git Dosier_Project]#

9、git reset HEAD file,復原暫存區的檔案

[root@git Dosier_Project]# echo "boss is good ">>dossier_3.sh 		#編輯一點內容[root@git Dosier_Project]# git add dossier_3.sh						#提交暫存區,這時突然反悔了,需要從暫存區復原該檔案[root@git Dosier_Project]# git status# On branch master# Changes to be committed:#   (use "git reset HEAD <file>..." to unstage)						#這裡已經提示了,復原暫存區檔案使用git reset HEAD##       modified:   dossier_3.sh#[root@git Dosier_Project]# git reset HEAD dossier_3.sh				#復原暫存區內的指定檔案Unstaged changes after reset:
M       dossier_3.sh[root@git Dosier_Project]#

10、刪除一個檔案並git rm提交到暫存區

[root@git Dosier_Project]# rm  -rf dossier_1.sh						#當檔案不需要了直接rm -rf刪除一個檔案[root@git Dosier_Project]# git status								#檢視狀態# On branch master# Changes not staged for commit:#   (use "git add/rm <file>..." to update what will be committed)	#這裡其實已經提示你使用add或rm引數了#   (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					#提交暫存區[root@git Dosier_Project]# 	git commit -m "delete dossier_1.sh"		#把暫存區內容commit提交git倉庫

推薦學習:Linux視訊教學

以上就是linux安裝git的命令是什麼的詳細內容,更多請關注TW511.COM其它相關文章!