前言

环境:centos7.9 git version 1.8.3.1

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 指向最新放入仓库的版本。

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 file1 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.sh2 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.sh1 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文件

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 <456789123@qq.com>
Date:   Mon Jan 31 18:05:42 2022 +0800Add dossier_3.shcommit beff2eaf816f345ba39779494752228a06ac1499
Author: lisi <456789123@qq.com>
Date:   Mon Jan 31 18:01:03 2022 +0800modified dossier_1.sh,add dossier_2.shcommit ae2c1b8752efd01ef265e2227dd0b4ceb81310f4
Author: lisi <456789123@qq.com>
Date:   Mon Jan 31 17:53:32 2022 +0800Add 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.sh
HEAD 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                #回退到版本1
HEAD is now at ae2c1b8 Add dossier_1.sh
[root@git Dosier_Project]# ll
total 4
-rw-r--r-- 1 root root 15 Jan 31 18:38 dossier_1.sh                 #已经回退到版本1
[root@git Dosier_Project]# cat dossier_1.sh                        #已经回退到版本1
I 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.sh
I 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仓库

git分支管理

后面我们会讲到GitHub远程仓库,开发团队成员都需要把代码提交到远程仓库,那为什么需要分支?
设想一下,如果只有一个master主分支,每个团队成员都去远程仓库master分支克隆一份代码下载到自己电脑进行代码编写,如果成员A尚未完成代码编写,只开发了部分功能,但怕自己电脑出现问题导致开发代码丢失,所以A需要提交代码到远程仓库,难不成A直接把未完成的代码直接提交到远程的master主分支上?然后来了个新人F,F去下载未完成的master分支代码?
其实不是的,企业中,远程仓库一般会创建多个分支,至少有一个dev分支,A可以先提交代码到dev分支,新人F是从master分支克隆代码,其他人也是从master克隆分支,然后大家都提交到dev分支,最后由仓库管理员leader决定是否合并dev分支代码到master分支,master分支的代码才是最后向用户提供的软件代码,所以必须保证master分支的代码是最正确的。

[root@git Dosier_Project]# git branch                       #列出分支,只有一个master分支,星号表示当前也在master分支
* master
[root@git Dosier_Project]# git branch dev                  #创建一个dev分支
[root@git Dosier_Project]# git checkout dev                    #切换到dev分支
Switched to branch 'dev'
[root@git Dosier_Project]# git branch                      #查看分支,现在实在dev分支上
* devmaster
[root@git Dosier_Project]# touch dossier_4.sh              #创建一个dev分支
[root@git Dosier_Project]# echo "dev branch" >>dossier_4.sh
[root@git Dosier_Project]# git status
# On branch dev                                             #现在添加的文件实在dev分支上
# Untracked files:
#   (use "git add <file>..." to include in what will be committed)
#
#       dossier_4.sh
nothing added to commit but untracked files present (use "git add" to track)
[root@git Dosier_Project]# git add dossier_4.sh            #提交暂存区
[root@git Dosier_Project]# git commit -m "add dossier_4.sh on dev branch"        #提交仓库,注意提交到的是dev分支
[dev 00444bd] add dossier_4.sh on dev branch1 file changed, 1 insertion(+)create mode 100644 dossier_4.sh
[root@git Dosier_Project]# git checkout master             #切换到master分支
Switched to branch 'master'
[root@git Dosier_Project]# ll                              #没看到dossier_4.sh文件,因为master还没合并
total 12
-rw-r--r-- 1 root root 35 Jan 31 20:08 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 19:58 dossier_3.sh
[root@git Dosier_Project]# git merge dev                   #合并dev分支到master分支
Updating 72cd563..00444bd
Fast-forwarddossier_4.sh | 1 +1 file changed, 1 insertion(+)create mode 100644 dossier_4.sh
[root@git Dosier_Project]# ll                              #已经可以看到dossier_4.sh文件了
total 16
-rw-r--r-- 1 root root 35 Jan 31 20:08 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 19:58 dossier_3.sh
-rw-r--r-- 1 root root 11 Jan 31 21:25 dossier_4.sh
[root@git Dosier_Project]# git branch -d dev               #删除分支

总结

1、git的安装
[root@git ~]# yum install git                                      #git的安装,直接使用yum安装
[root@git ~]# git --version                                            #查看git的版本
git version 1.8.3.1
2、创建项目目录并初始化
[root@git ~]# mkdir Dosier_Project                                 #创建一个项目代码目录
[root@git ~]# cd Dosier_Project/                                   #进入目录
[root@git Dosier_Project]# git init                                    #初始化目录,让目录受到git版本控制
[root@git Dosier_Project]# ll -a                                   #.git目录就是git仓库
drwxr-xr-x  3 root root  78 Jan 31 18:04 .
dr-xr-x---. 5 root root 215 Jan 31 17:52 ..
drwxr-xr-x  8 root root 166 Jan 31 18:05 .git
[root@git Dosier_Project]# vim dossier.sh                      #创建一个代码文件并编辑保存代码
[root@git Dosier_Project]# git status                          #查看git状态
[root@git Dosier_Project]# git add dossier.sh                      #git add命令把文件放入暂存区
[root@git Dosier_Project]# git add *                               #git add命令把文件放入暂存区,星号匹配所有
[root@git Dosier_Project]# git add --all                           #git add命令把文件放入暂存区,--all表示所有,等价于*
[root@git Dosier_Project]# git commit -m "Add dossier.sh"            #git commit表示提交暂存区全部文件到git仓库,-m参数接注释
[root@git Dosier_Project]# git log                             #git log 查看git仓库里的当前版本
[root@git Dosier_Project]# git reflog                          #git reflog 查看git仓库里的所有版本,包含回退的版本记录
[root@git Dosier_Project]# git reset --hard 72cd563                    #自由回退版本,先用git reflog 查看git仓库的版本号
[root@git Dosier_Project]# git checkout -- dossier_3.sh                #撤销文件修改,注意命令--后面是空格接文件名
[root@git Dosier_Project]# git rm dossier_1.sh                     #rm删除一个文件后,把删除的文件提交到暂存区,不是git add
[root@git Dosier_Project]# git branch                              #查看分支
[root@git Dosier_Project]# git checkout dev                            #切换分支
[root@git Dosier_Project]# git merge dev                           #当前在master分支下操作,合并dev分支到master分支
[root@git Dosier_Project]# git branch -d dev                       #删除分支

https://www.jianshu.com/p/e57a4a2cf077

Linux下安装Git、git命令介绍相关推荐

  1. LINUX 下安装软件方法命令方法

    LINUX 下安装软件方法命令方法 怎么安装应用软件? 我的软件安装在什么地方? 如何删除不要的应用软件? -- 下面,我们就一起来认识一下这些方面的问题. 一. 解析Linux应用软件安装包: 通常 ...

  2. Linux下安装配置git

    我用的Linux是CentOS,安装过程这里 http://progit.org/book/zh/ 有详细介绍,我只说下我在安装配置过程中遇到的问题. 第一,就是下载的问题,我在下载的时候发现 用yu ...

  3. Linux下安装maven(mvn命令)

    1.准备工作 1)maven的安装运行以来Java环境,需要预先安装,具体Java安装方法可以参考我的另一篇博文: linux下yum安装jdk1.8(rpm包)和tomcat-8.5 2)maven ...

  4. LINUX下安装软件方法命令方法

    1.通常Linux应用软件的安装包有三种: 1) tar包,如software-1.2.3-1.tar.gz.它是使用UNIX系统的打包工具tar打包的. 2) rpm包,如software-1.2. ...

  5. linux 下安装gnu aspell命令,Linux spell命令

    Linux spell命令 Linux spell命令可建立拼写检查程序. spell可从标准输入设备读取字符串,结束后显示拼错的词汇. 语法spell 实例 检查文件testfile是否有拼写错误, ...

  6. nginx在linux下安装,Nginx在linux下安装及简单命令

    安装环境:Centos7 创建目录及切换至目录 # mkdir /usr/local/nginx # cd /usr/local/nginx/ wget http://nginx.org/downlo ...

  7. Linux 下查看文件的命令介绍

    这篇文章中介绍了三个命令,都是对文件进行操作的,用于查看文件内容,这三个命令分别是 cat, tac,paste.        第一个命令:cat 这个命令用于查看文件内容,它是一次性显示文件的所有 ...

  8. linux下安装sz/rz命令

    参考 https://blog.csdn.net/kobejayandy/article/details/13291655 转载于:https://www.cnblogs.com/xiaobiaome ...

  9. linux 添加宋体字符集,Linux下安装中文宋体

    1,#cd /usr/share/fonts/default 2,mkdir -p ./truetype/simsun 3,取得simsun.ttc文件:如果网上下载不到则在windows (c:/w ...

  10. linux 安装git失败,Linux运维知识之linux下安装git常见故障整理

    本文主要向大家介绍了Linux运维知识之linux下安装git常见故障整理,通过具体的内容向大家展现,希望对大家学习Linux运维知识有所帮助. FAQ1: Permission denied (pu ...

最新文章

  1. 你真的了解CSS3硬件加速吗?
  2. 在将规则文件上传到sonarQube时,Findbugs配置文件无效错误
  3. [文档].艾米电子 - 在综合中使用函数,Verilog
  4. 【今日CV 视觉论文速览】29 Nov 2018
  5. 有序数组原地删除重复出现的元素问题(js)
  6. 基于SSM的商旅系统
  7. 10米精度NPP净初级生产力数据/NDVI数据/植被类型数据/土地利用数据/降雨气温分布数据/太阳辐射分布数据
  8. uniapp 微信小程序的弹框文字换行
  9. WebView内通过浏览器打开链接
  10. android 获取手机内存及SD卡内存可用空间
  11. window10设置系统还原点和使用还原点还原系统
  12. APP安全性检查报告整改
  13. 进阶阿里巴巴之路——招聘要求汇总
  14. 网站空间与服务器的区别,网站空间与服务器的区别
  15. 从零学习Fluter(四):Flutter中ListView组件系列详展
  16. 爬取6.6w+豆瓣电影之后,分析他们的故事
  17. 南邮 OJ 1652 翻转棋
  18. (线段树)P5459 [BJOI2016]回转寿司
  19. 原生JavaScript类型判断
  20. 配置 不使用rsa 密码_了解使用RSA的密码学

热门文章

  1. python数据字典ppt_[关系型数据库][MySQL]用python快速导出数据字典
  2. 山海演武传·黄道·第二卷 大风起兮 第二 ~ 三章 傲娇的赤龙皇女
  3. Machin(梅钦/马青)公式计算圆周率π
  4. 利用马青公式输出π的后任意位数字
  5. ReactNative进阶(三十五):应用脚手架 Yo 构建 RN 页面
  6. 工商变更:吴忌寒退出北京比特大陆法定代表人,詹克团接任
  7. 优秀案例 | 长江鲲鹏中地数码:打造智慧城市“数字底座”
  8. ai怎么做波普风圆点_超实用AI描边小技巧:AI画一个圆点组成的圆
  9. 如何用计算机录麦克风的声音,电脑内部与麦克风的声音怎么同时录制?详细教程在此...
  10. python 制作动画片_分享7个好用的动画制作软件,学会它,人人可以成为动画大师...