目錄
linux安裝git的指令是什麼
git指令實踐
首頁 運維 linux運維 linux安裝git的指令是什麼

linux安裝git的指令是什麼

Jun 30, 2022 pm 05:09 PM
linux

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

linux安裝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 "456789123@qq.com"			#设置邮箱[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 的三大核心架構

工作區域(Working Directory):就是開發者平時存放專案程式碼的目錄;
暫存區域(Stage ):用於暫時存放開發者程式碼的改動,事實上它只是一個文件,保存即將提交的文件清單資訊;
Git 倉庫(Repository):就是安全存放資料的位置,git倉庫有開發者提交的所有版本的資料代碼,其中,HEAD 指向最新放入倉庫的版本。
linux安裝git的指令是什麼
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]#</file></file>
登入後複製

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 Date:   Mon Jan 31 18:05:42 2022 +0800

    Add dossier_3.sh

commit beff2eaf816f345ba39779494752228a06ac1499
Author: lisi Date:   Mon Jan 31 18:01:03 2022 +0800

    modified dossier_1.sh,add dossier_2.sh

commit ae2c1b8752efd01ef265e2227dd0b4ceb81310f4
Author: lisi 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]#</file>
登入後複製

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仓库</file></file>
登入後複製

推薦學習:Linux影片教學

以上是linux安裝git的指令是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1666
14
CakePHP 教程
1425
52
Laravel 教程
1325
25
PHP教程
1273
29
C# 教程
1252
24
Linux體系結構:揭示5個基本組件 Linux體系結構:揭示5個基本組件 Apr 20, 2025 am 12:04 AM

Linux系統的五個基本組件是:1.內核,2.系統庫,3.系統實用程序,4.圖形用戶界面,5.應用程序。內核管理硬件資源,系統庫提供預編譯函數,系統實用程序用於系統管理,GUI提供可視化交互,應用程序利用這些組件實現功能。

vscode上一步下一步快捷鍵 vscode上一步下一步快捷鍵 Apr 15, 2025 pm 10:51 PM

VS Code 一步/下一步快捷鍵的使用方法:一步(向後):Windows/Linux:Ctrl ←;macOS:Cmd ←下一步(向前):Windows/Linux:Ctrl →;macOS:Cmd →

git怎麼查看倉庫地址 git怎麼查看倉庫地址 Apr 17, 2025 pm 01:54 PM

要查看 Git 倉庫地址,請執行以下步驟:1. 打開命令行並導航到倉庫目錄;2. 運行 "git remote -v" 命令;3. 查看輸出中的倉庫名稱及其相應的地址。

notepad怎麼運行java代碼 notepad怎麼運行java代碼 Apr 16, 2025 pm 07:39 PM

雖然 Notepad 無法直接運行 Java 代碼,但可以通過借助其他工具實現:使用命令行編譯器 (javac) 編譯代碼,生成字節碼文件 (filename.class)。使用 Java 解釋器 (java) 解釋字節碼,執行代碼並輸出結果。

sublime寫好代碼後如何運行 sublime寫好代碼後如何運行 Apr 16, 2025 am 08:51 AM

在 Sublime 中運行代碼的方法有六種:通過熱鍵、菜單、構建系統、命令行、設置默認構建系統和自定義構建命令,並可通過右鍵單擊項目/文件運行單個文件/項目,構建系統可用性取決於 Sublime Text 的安裝情況。

Linux的主要目的是什麼? Linux的主要目的是什麼? Apr 16, 2025 am 12:19 AM

Linux的主要用途包括:1.服務器操作系統,2.嵌入式系統,3.桌面操作系統,4.開發和測試環境。 Linux在這些領域表現出色,提供了穩定性、安全性和高效的開發工具。

laravel安裝代碼 laravel安裝代碼 Apr 18, 2025 pm 12:30 PM

要安裝 Laravel,需依序進行以下步驟:安裝 Composer(適用於 macOS/Linux 和 Windows)安裝 Laravel 安裝器創建新項目啟動服務訪問應用程序(網址:http://127.0.0.1:8000)設置數據庫連接(如果需要)

git軟件安裝 git軟件安裝 Apr 17, 2025 am 11:57 AM

安裝 Git 軟件包括以下步驟:下載安裝包運行安裝包驗證安裝配置 Git安裝 Git Bash(僅限 Windows)

See all articles