这篇文章主要介绍“linux安装git的命令是哪个”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“linux安装git的命令是哪个”文章能帮助大家解决问题。

在linux中,安装git的命令是“yum install git”;yum是“Yellow dog Updater Modified”的简称,yum用于自动化地升级、安装、移除rpm包,收集rpm包的相关信息,检查依赖性并自动提示用户解决,因此可以利用yum来安装git。

本教程操作环境:linux7.3系统、Dell G3电脑。

linux安装git的命令是什么

安装Git

[root@git~]#yuminstallgit						#git的安装,直接使用yum安装

查看版本

[root@git~]#git--version							#查看git的版本gitversion1.8.3.1

扩展知识:

git个人身份设置

git是分布式版本控制系统,所以每个开发者都应该在自己的笔记本上安装Git,然后在git上设置自己的个人身份信息。

[root@git~]#gitconfig--globaluser.name"lisi"						#设置用户姓名[root@git~]#gitconfig--globaluser.emain"456789123@qq.com"			#设置邮箱[root@git~]#gitconfig--globalcolor.uitrue							#enableui颜色[root@git~]#gitconfig--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~]#mkdirDosier_Project									#创建一个项目代码目录
[root@git~]#cdDosier_Project/									#进入目录
[root@gitDosier_Project]#gitinit									#初始化目录,让目录受到git版本控制
InitializedemptyGitrepositoryin/root/Dosier_Project/.git/		#初始化了一个空的git仓库
[root@gitDosier_Project]#ll-al									#查看该目录
total0
drwxr-xr-x3rootroot18Jan3116:15.
dr-xr-x---.5rootroot215Jan3116:14..
drwxr-xr-x7rootroot119Jan3116:15.git						
#发现gitinit初始化命令就是生成了.git目录,这个.git目录就是git仓库,以后在Dosier_Project目录下做的所有操作就可以受到git版本控制了
[root@gitDosier_Project]#

2、模拟开发工程师开发代码文件

[root@gitDosier_Project]#cd/root/Dosier_Project/				#进去到项目目录
[root@gitDosier_Project]#vimdossier.sh						#创建一个代码文件
[root@gitDosier_Project]#

3、git add把代码文件提交到暂存区

[root@gitDosier_Project]#gitstatus								#查看状态
#Onbranchmaster
#
#Initialcommit
#
#Untrackedfiles:
#(use"gitadd<file>..."toincludeinwhatwillbecommitted)
#
#dossier.sh
nothingaddedtocommitbutuntrackedfilespresent(use"gitadd"totrack)
#解释:Untrackedfiles说明存在未跟踪的文件(下边红色的那个)
#所谓的“未跟踪”文件,是指那些新添加的并且未被加入到暂存区域或提交的文件。它们处于一个逍遥法外的状态,当你一旦将它们加入暂存区域或提交到Git仓库,它们就开始受到Git的“跟踪”了
[root@gitDosier_Project]#gitadddossier.sh					#用gitadd命令把文件提交暂存区
[root@gitDosier_Project]#gitstatus					#再次查看状态
#Onbranchmaster
#
#Initialcommit
#
#Changestobecommitted:	#意思是要提交的更改,等待提交
#(use"gitrm--cached<file>..."tounstage)
#
#newfile:dossier.sh#暂存区已经有一个文件了
#
[root@gitDosier_Project]#

4、git commit 把暂存区的所有文件提交到git仓库
git commit 是把暂存区的所有文件提交到git仓库,并不是指提交某个文件。

[root@gitDosier_Project]#gitcommit-m"lisiadddossier.shfile"		#提交暂存区内的文件到git仓库,-m参数表示写的注释
[master(root-commit)c2b3806]lisiadddossier.shfile
1filechanged,2insertions(+)
createmode100644dossier.sh
[root@gitDosier_Project]#gitstatus				#再次查看状态,提示暂存区没有要commit的,工作目录文件也没有编辑过
#Onbranchmaster
nothingtocommit,workingdirectoryclean
[root@gitDosier_Project]#

5、继续模拟版本2、版本3

#模拟版本2,模拟版本2为修改dossier_1.sh文件,新加一个dossier_2.sh文件
[root@git~]#cd~/Dosier_Project/
[root@gitDosier_Project]#echo"Iamgooddossier_1">>dossier_1.sh		#修改了dossier_1.sh文件
[root@gitDosier_Project]#touchdossier_2.sh								#新加dossier_2.sh文件
[root@gitDosier_Project]#echo"Iamdossier_2">>dossier_2.sh
[root@gitDosier_Project]#gitadd*#星号匹配所有(等价于--all),把所有文件提交暂存区
[root@gitDosier_Project]#gitcommit-m"modifieddossier_1.sh,adddossier_2.sh"	#gitcommit提交暂存区文件到仓库
[masterbeff2ea]modifieddossier_1.sh,adddossier_2.sh
2fileschanged,2insertions(+)
createmode100644dossier_2.sh
[root@gitDosier_Project]#gitstatus#查看状态,三大区域已经一致
#Onbranchmaster
nothingtocommit,workingdirectoryclean

#继续模拟版本3,继续模拟版本3为新加一个dossier_3.sh文件
[root@gitDosier_Project]#touchdossier_3.sh								#新加一个dossier_3.sh文件
[root@gitDosier_Project]#echo"Iamdossier_3">>dossier_3.sh
[root@gitDosier_Project]#gitadddossier_3.sh							#把dossier_3.sh提交到暂存区
[root@gitDosier_Project]#gitcommit-m"Adddossier_3.sh"					#把暂存区内容提交到git仓库
[master72cd563]Adddossier_3.sh
1filechanged,1insertion(+)
createmode100644dossier_3.sh
[root@gitDosier_Project]#gitstatus#查看状态,三大区域已经一致
#Onbranchmaster
nothingtocommit,workingdirectoryclean
[root@gitDosier_Project]#

以上,我们就创建了3个版本,版本1为创建dossier_1.sh文件,版本2为修改dossier_1.sh文件,新加一个dossier_2.sh文件,模拟版本3为新加一个dossier_3.sh文件#查看状态,三大区域已经一致#Onbranchmasternothingtocommit,workingdirectoryclean[root@gitDosier_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@gitDosier_Project]#gitlog									#gitlog命令查看git仓库中有哪些版本commit72cd563e2e0241670d7ebe8c541f28a12875e1e8
Author:lisi<456789123@qq.com>Date:MonJan3118:05:422022+0800

Adddossier_3.sh

commitbeff2eaf816f345ba39779494752228a06ac1499
Author:lisi<456789123@qq.com>Date:MonJan3118:01:032022+0800

modifieddossier_1.sh,adddossier_2.sh

commitae2c1b8752efd01ef265e2227dd0b4ceb81310f4
Author:lisi<456789123@qq.com>Date:MonJan3117:53:322022+0800

Adddossier_1.sh[root@gitDosier_Project]#gitreflog								#gitreflog命令查看git仓库中有哪些版本72cd563HEAD@{0}:commit:Adddossier_3.sh
beff2eaHEAD@{1}:commit:modifieddossier_1.sh,adddossier_2.sh
ae2c1b8HEAD@{2}:commit(initial):Adddossier_1.sh[root@gitDosier_Project]#

7、git reset --hard 版本号,实现版本自由回退

[root@gitDosier_Project]#gitreflog								#gitreflog命令查看git仓库中有哪些版本,前面的字符就是版本号72cd563HEAD@{0}:commit:Adddossier_3.sh
beff2eaHEAD@{1}:commit:modifieddossier_1.sh,adddossier_2.sh
ae2c1b8HEAD@{2}:commit(initial):Adddossier_1.sh[root@gitDosier_Project]#gitreset--hardbeff2ea				#回退到版本2,即修改dossier_1.sh文件,新加dossier_2.shHEADisnowatbeff2eamodifieddossier_1.sh,adddossier_2.sh[root@gitDosier_Project]#ll#查看文件,已经没有了dossier_3.sh文件total8-rw-r--r--1rootroot35Jan3117:56dossier_1.sh
-rw-r--r--1rootroot15Jan3117:56dossier_2.sh[root@gitDosier_Project]#catdossier_1.sh						#dossier_1.sh的最后一行也确实实在版本2时候添加的Iamdossier_1
Iamgooddossier_1[root@gitDosier_Project]#gitreset--hardae2c1b8			#回退到版本1HEADisnowatae2c1b8Adddossier_1.sh[root@gitDosier_Project]#lltotal4-rw-r--r--1rootroot15Jan3118:38dossier_1.sh					#已经回退到版本1[root@gitDosier_Project]#catdossier_1.sh						#已经回退到版本1Iamdossier_1	
[root@gitDosier_Project]#[root@gitDosier_Project]#gitreflog								#gitreflog命令可以看到你所有的版本已经回退版本的记录ae2c1b8HEAD@{0}:reset:movingtoae2c1b8
beff2eaHEAD@{1}:reset:movingtobeff2ea
72cd563HEAD@{2}:commit:Adddossier_3.sh
beff2eaHEAD@{3}:commit:modifieddossier_1.sh,adddossier_2.sh
ae2c1b8HEAD@{4}:commit(initial):Adddossier_1.sh[root@gitDosier_Project]#gitreset--hard72cd563					#为了后面实验,现在还是回退到版本3吧HEADisnowat72cd563Adddossier_3.sh[root@gitDosier_Project]#ll#已经回退到版本3了total12-rw-r--r--1rootroot35Jan3118:44dossier_1.sh
-rw-r--r--1rootroot15Jan3118:44dossier_2.sh
-rw-r--r--1rootroot15Jan3118:44dossier_3.sh[root@gitDosier_Project]#

8、git checkout – filename,撤销文件修改(文件未提交到暂存区)
开发工程师修改了某个文件,文件未提交到暂存区,需要撤销文件修改,可以通过删除文件内容达到恢复文件最开始状态,但如果是修改了很多,甚至连自己都不知道要删除哪些内容了,这时可以使用git checkout命令:

[root@gitDosier_Project]#echo"testesshfkshdsjdhjshka">>dossier_3.sh[root@gitDosier_Project]#catdossier_3.shIamdossier_3
testesshfkshdsjdhjshka[root@gitDosier_Project]#gitcheckout--dossier_3.sh				#撤销文件修改,注意命令--后面是空格接文件名[root@gitDosier_Project]#catdossier_3.sh				#已经撤销成功Iamdossier_3[root@gitDosier_Project]#

9、git reset HEAD file,撤销暂存区的文件

[root@gitDosier_Project]#echo"bossisgood">>dossier_3.sh		#编辑一点内容[root@gitDosier_Project]#gitadddossier_3.sh						#提交暂存区,这时突然反悔了,需要从暂存区撤销该文件[root@gitDosier_Project]#gitstatus#Onbranchmaster#Changestobecommitted:#(use"gitresetHEAD<file>..."tounstage)						#这里已经提示了,撤销暂存区文件使用gitresetHEAD##modified:dossier_3.sh#[root@gitDosier_Project]#gitresetHEADdossier_3.sh				#撤销暂存区内的指定文件Unstagedchangesafterreset:
Mdossier_3.sh[root@gitDosier_Project]#

10、删除一个文件并git rm提交到暂存区

[root@gitDosier_Project]#rm-rfdossier_1.sh						#当文件不需要了直接rm-rf删除一个文件[root@gitDosier_Project]#gitstatus								#查看状态#Onbranchmaster#Changesnotstagedforcommit:#(use"gitadd/rm<file>..."toupdatewhatwillbecommitted)	#这里其实已经提示你使用add或rm参数了#(use"gitcheckout--<file>..."todiscardchangesinworkingdirectory)##deleted:dossier_1.sh#nochangesaddedtocommit(use"gitadd"and/or"gitcommit-a")[root@gitDosier_Project]#	gitrm	dossier_1.sh					#提交暂存区[root@gitDosier_Project]#	gitcommit-m"deletedossier_1.sh"		#把暂存区内容commit提交git仓库

关于“linux安装git的命令是哪个”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

推荐阅读:Git常见命令

点赞(67) 打赏

评论列表 共有 0 条评论

暂无评论

微信小程序

微信扫一扫体验

立即
投稿

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部