引入
我们在编写各种⽂档时,为了防⽌⽂档丢失,更改失误,失误后能恢复到原来的版本,不得不复制出⼀个副本,每个版本有各⾃的内容但最终会只有⼀份报告需要被我们使⽤,在此之前的⼯作都需要这些不同版本的报告,于是每次都是复制粘贴副本,产出的⽂件就越来越
多,⽂件多不是问题,问题是:随着版本数量的不断增多,你还记得这些版本各⾃都是修改了什么吗?
概念
Git本质是版本控制器,目的是能够更⽅便管理不同版本的⽂件。Git可以控制电脑上所有格式的⽂件,例如?doc、excel、dwg、dgn、rvt等等。而对于开发人员来说,Git最重要的就是可以帮助管理软件开发项目的源代码文件
注意:所有的版本控制系统,只能跟踪⽂本⽂件的改动,而不是文件本身
sudo yum -y install git #Centos
sudo apt-get install git -y #ubuntu
查看Git安装的版本:git --version
仓库是进⾏版本控制的⼀个⽂件⽬录。我们要想对⽂件进⾏版本控制,就必须先创建⼀个仓库出来,新建仓库命令是:git init
注意:该命令要在⽂件⽬录下执⾏
可以发现:当前⽬录下多了⼀个.git
目录的隐藏文件。
注意:.git
⽬录是Git来跟踪管理仓库的,不要⼿动修改这个⽬录⾥⾯的⽂件,不然改乱了,就把Git仓库给破坏了。
当安装Git后⾸先要做的事情是设置你的⽤⼾名称和e-mail地址,配置用户名称和邮箱地址命令为:
git config[--global] user.name "Your Name"
git config[--global] user.email "[email protected]"
其中:--global
是⼀个可选项。如果使⽤了该选项,表⽰这台机器上所有的Git仓库都会使⽤这个配置。因为一台服务器下可以创建多个git仓库,如果你希望在不同仓库中使⽤不同的name和email,可以不要--global
选项,需要注意的是,执⾏命令时必须要在仓库⾥
查看配置的命令为:git config -l
删除对应的配置的命令为:
git config[--global] --unset user.name
git config[--global] --unset user.email
gitcode
目录就是工作区.git
目录下的index文件当中(.git/index)中,暂存区有时也叫作索引.git
目录虽然在gitcode目录下,但它不属于工作区,而是git的版本库,这个版本库⾥⾯的所有⽂件都可以被Git管理起来,每个⽂件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。⼯作区、暂存区和版本库之间的关系:
git add
命令时:暂存区⽬录树的⽂件索引会被更新,当执⾏提交操作git commit
时:master分⽀会做相应的更新,可以简单理解为暂存区的⽬录树才会被真正写到版本库中在工作区新建⼀个ReadMe⽂件,可以使⽤ git add 命令可以将⽂件添加到暂存区
git add file1 filee dir ...
git add .
使⽤ git commit 命令将暂存区内容添加到本地仓库中
git commmit -m "message"
git commit file1] file2 ... -m "message"
注意:-m
选项跟上描述本次提交的message信息,这部分内容绝对不能省略,并要好好描述,是⽤来记录你的提交细节,是给⼈看的
甚至可以多次add不同的⽂件,⽽只commit⼀次便可以提交所有⽂件,需要提交的⽂件是通通被add到暂存区中,然后⼀次性commit暂存区的所有修改
可以使用git log
查看历史提交记录
该命令显⽰从**最近到最远的提交⽇志**,并且可以看到我们commit时的⽇志消息,如果嫌输出信息太多,看得眼花缭乱的,可以试试加上 --pretty=oneline
参数
git log --pretty=oneline : 查看一行好看的日志信息
每次提交都有一个commit id(版本号),它是通过哈希加密计算出来的⼀个⾮常⼤的数
注意:查找object时要将commit id分成两部分,其前2位是⽂件夹名称,后38位是⽂件名称。找到这个⽂件之后,⼀般不能直接看到⾥⾯是什么,因为该类⽂件是经过sha(安全哈希算法)加密过的⽂件,可以利用:git cat-file -p 版本号
:查看版本库对象的内容
在本地的git仓库中,有⼏个⽂件或者⽬录很特殊
git add
之后,会将工作区的内容放到暂存区commit id(版本号)
此时提交之后,是只有⼀个⽂件改变了。原因是:git add 是将⽂件添加到暂存区,git commit 是将暂存区的内容添加到本地仓库中,但是由于并没有使⽤git add file5
,file5目前不不在暂存区中维护,所以我们commit的时候其实只是把已经在暂存区的file4 提交了