????什么是Git
????Git的安装
??????Centos平台安装Git
??????Ubuntu平台安装Git
????Git的基本操作
??????创建远程仓库
??????配置Git
????认识工作区、暂存区与版本库
??????添加文件到暂存区
??????将暂存区文件提交至本地仓库
????总结
前言:
??世界上最强大的分布式管理控制器——Git它来了!今天起,逐步更新Git的文章,那么话不多说,开启我们今天的话题!
??在了解什么是Git之前,我来问一下,你是否遇到过这种或类似的情况:
??阿熊在物理实验课上自信满满的写完了实验报告,交给老师,老师却让阿熊重写,于是阿熊再次重写。第二次拿给老师看,老师还说不行,于是阿熊又回去一顿改,这样反反复复,也不知道改了多少次…
??最后,阿熊拿给老师看,老师还说不行?!阿熊当时就急眼了,对老师说:“老师啊,马上提交时间就截止了,我没法再改了啊”,老师:“嗯,那还是把你写的第一版发来吧。”,阿熊:“???”
??阿熊没有将每个文件都进行保存,而是在源文件进行修改的,所以阿熊就拿不出第一版的实验报告。
??下一次实验报告很快就来了,阿熊学聪明了,每次改完实验报告就保存一份在文件夹,这样当老师要那一版的时候,就可以把对应版本的实验报告发过去,果不其然,阿熊改了整整11次,老师最后只要第二版的。这老师不会在针对阿熊吧…
??不仅生活中如此,我们写代码更是如此,当版本多、代码量大的时候,你能记得你改的细节吗?为了能够方便管理这些不同版本的文件,便有了版本控制器——Git。
??而所谓的版本控制器,就是能够让你了解到一个文件的历史,以及它的发展过程的系统。通俗来说,就是可以记录工程的每一次改动和版本迭代的一个管理系统,同时也方便多人协同作业。
??如果你是跟我一样是Centos(我的是7.6)系统,可以先查看系统是否安装了git,输入指令:
git#输入后回车即可
如果你的Linux机器上已经安装了git就会显示:
如果没有安装则会有这样几句话:
$git
-bash: git: command not found
??没有安装Git只需要输入如下指令回车:
sudo yum -y install git#root账号下不用sudo,普通用户需要sudo权限
??可以看到我们的电脑上已经安装了git,安装完成之后,可以查看自己安装的git的版本,使用如下命令进行查看:
git --version
??我的版本是1.8.3.1,其实版本只要不相差太远就基本没什么问题。
??如果你是Ubuntu忠实爱好者的话,安装git也很简单,以Ubuntu20.04为例:
??查看系统是否有git:
git#输入后回车
??如果出现下面的结果,Linux会有好地告诉你Git没有安装,还会告诉你如何安装:
&git
Command 'git' not found, but can be installed with:
sudo apt install git
??安装git:
sudo apt-get install git -y
??查看git的版本:
git --version
??在创建远程仓库之前,要注意的是:仓库是进?版本控制的?个 ?件?录。我们要想对?件进?版本控制,就 必须先创建?个仓库 出来。
??所以我们先 创建一个管理代码的git仓库:
??我们进入到gitcode目录里,然后创建我们的本地仓库,使用如下命令:
git init#创建本地仓库
??我们发现,在gitcode目录下,隐藏文件多了 .git 文件,它的作用是 跟踪管理仓库 ,不要手动修改这个目录里的文件,一不小心可能整个仓库就会被改垮了。
??当然我们可以查看 .git 里面究竟有什么:
??我们并不是创建完了本地仓库就可以进行版本控制了,在进行实操之前,还需要 设置 你的 用户名 和 邮箱地址,我们可以使用如下命令来设置:
git config user.name "用户名"#用户名
git config user.email "邮箱"#填写邮箱
??我们也可以使用 git config 命令查看配置信息:
git config -l#查看配置信息
??如果我们要 删除用户名和邮箱 只需要输入如下指令:
git config --unset user.name#删除当前仓库用户名
git config --unset user.email#删除当前仓库邮箱
??这里设置和删除的用户名好邮箱仅仅是当前仓库的,对本地别的仓库无效,若是想要 用户名和邮箱在所有仓库有效,在原来指令的基础上加上 --global 选项。
git config --global user.name "用户名"#全局范围内用户名有效
git config --global user.email "邮箱"#全局范围内邮箱有效
??而全局范围的用户名和邮箱 使用普通的删除也是删除不了 的,也需要在删除时 加上 –global 选项:
git config --unset --global user.name#删除全局范围的用户名
git config --unset --global user.email#删除全局范围的邮箱
下图它们三个的关系图:
??我们前面创建的 gitcode 目录就是仓库,而我们使用 git init 命令就是 将目录变为可以管理的仓库,进入到 gitcode目录后的地方就是工作区,在这写你的代码文件等。
??暂存区为 index 或者 stage 在没有文件被添加时是不显示暂存区的,也就是暂存区为空:
??那么首先我们来学习一下,将文件添加至暂存区,我们需要如下命令:
git add#将当前目录下的所有文件全部添加至暂存区内
git add 文件#这里文件可以为多个文件,文件之间用空格隔开即可
git add 指定目录#也可以添加指定目录下的文件
??我们创建一个文件,然后将文件添加,观察版本库是否会出现暂存区:
??这个时候暂存区就会显示出来了,因为file1文件被添加至了暂存区。
??我们将工作区的文件添加至暂存区之后,我们就可以进行下一步了,将暂存区中的文件提交至本地仓库,使用如下命令:
git commit -m "提交信息描述"#将该目录下的文件全部提交到本地仓库
git commit 文件列表 -m "提交信息描述"#提交单个或多个文件到本地仓库
注意:git commit 后 -m 选项后的 提交信息描述 是一定要描述本次提交的信息的,用户自己完成这部分步骤,写下来是给人看的,所以一定得好好写描述信息。
??git commit命令执行后,会告诉我们一个文件被改动(我们的file1文件),插入了0行内容(因为没有写东西)。
??到目前为止,我们已经能将代码从本地提交到本地仓库了,我们可以使用 git log 命令来 查看我们曾经提交过的历史记录:
??这样的信息似乎有些繁琐,看的眼花缭乱的,那么我们在查看信息的命令后加上 –pretty=oneline 选项使得日志变得 漂亮且单行。
git log --pretty=oneline#将日志信息变得规范
??需要说明的是,我们看到的这些:
??这些一大串的数字是 每次提交的 commit id 也就是 版本号,Git的版本号不是递增的数字,而是由 SHA 计算出来的一个非常庞大的数,使用十六进制表示。
??创作不易,如果这篇文章对你有帮助的话,还望三连支持博主~~ 点个赞也行~