版本控制

版本控制(Revision control)是一种在开发的过程中用于管理我们对文件、目录或工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前的版本的软件工程技术。

优点

  • 实现跨区域多人协同开发
  • 追踪和记载一个或者多个文件的历史记录
  • 组织和保护你的源代码和文档
  • 统计工作量
  • 并行开发、提高开发效率
  • 跟踪记录整个软件的开发过程
  • 减轻开发人员的负担,节省时间,同时降低人为错误

集中版本控制 (SVN)

所有的版本数据都保存在服务器上,协同开发者从服务器上同步更新或上传自己的修改所有的版本数据都存在服务器上,用户的本地只有自己以前所同步的版本,如果不连网的话,用户就看不到历史版本,也无法切换版本验证问题,或在不同分支工作。而且,所有数据都保存在单一的服务器上,有很大的风险这个服务器会损坏,这样就会丢失所有的数据,当然可以定期备份。代表产品:SVN、CVS、VSS

image-20230320212922769

分布式版本控制 (Git)

所有版本信息仓库全部同步到本地的每个用户,这样就可以在本地查看所有版本历史,可以离线在本地提交,只需在连网时push到相应的服务器或其他用户那里。由于每个用户那里保存的都是所有的版本数据,只要有一个用户的设备没有问题就可以恢复所有的数据,但这增加了本地存储空间的占用

image-20230320212956164

Git与SVN的主要区别

SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而工作的时候,用的都是自己的电脑,所以首先要从中央服务器得到最新的版本,然后工作,完成工作后,需要把自己做完的活推送到中央服务器。集中式版本控制系统是必须联网才能工作,对网络带宽要求较高。

Git是分布式版本控制系统,没有中央服务器,每个人的电脑就是一个完整的版本库,工作的时候不需要联网了,因为版本都在自己电脑上。协同的方法是这样的:比如说自己在电脑上改了文件A,其他人也在电脑上改了文件A,这时,你们两之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。Git可以直接看到更新了哪些代码和文件!

Git配置

下载

Git淘宝镜像

启动

桌面或文件夹下右击看到Git bash Git GUI

Git Bash:Unix与Linux风格的命令行,使用最多,推荐最多

Git CMD:Windows风格的命令行

Git GUI:图形界面的Git,不建议初学者使用,尽量先熟悉常用命令

删除

清理环境变量,然后通过geek, 360或者系统清理等等

1
2
3
4
5
6
7
8
#查看配置 
git config -l

#查看系统config
git config --system --list
  
#查看当前用户(global)配置
git config --global --list

设置用户

1
2
git config --global user.name "你的名称"  
git config --global user.email "你的邮箱"

Git基本知识

Git本地有三个工作区域:工作目录(Working Directory)暂存区(Stage/Index)资源库(Repository或Git Directory)

远程有一个工作区域:git远程仓库(Remote Directory)

文件在这四个区域之间的转换关系如下:

重点

image-20230320221927576

工作流程

git的工作流程一般是这样的:

  1. 在工作目录中添加、修改文件;
  2. 将需要进行版本管理的文件放入暂存区域;
  3. 将暂存区域的文件提交到git仓库。

因此,git管理的文件有三种状态:已修改(modified),已暂存(staged),已提交(committed)

image-20230320222854240

Git项目搭建

常用命令

image-20230320223126713

本地仓库搭建:

1
2
# 在当前目录新建一个Git代码库
$ git init

远程仓库搭建:

1
2
# 克隆一个项目和它的整个代码历史(版本信息)
$ git clone [url]

image-20230322104517297

image-20230322104537259

PS:克隆成功

Git 文件操作

文件的四则状态

  • Untracked: 未跟踪, 此文件在文件夹中, 但并没有加入到git库, 不参与版本控制. 通过git add 状态变为Staged.
  • Unmodify: 文件已经入库, 未修改, 即版本库中的文件快照内容与文件夹中完全一致. 这种类型的文件有两种去处, 如果它被修改, 而变为Modified. 如果使用git rm移出版本库, 则成为Untracked文件
  • Modified: 文件已修改, 仅仅是修改, 并没有进行其他的操作. 这个文件也有两个去处, 通过git add可进入暂存staged状态, 使用git checkout则丢弃修改过, 返回到unmodify状态, 这个git checkout即从库中取出文件, 覆盖当前修改 !
  • Staged: 暂存状态. 执行git commit则将修改同步到库中, 这时库中的文件和本地文件又变为一致, 文件为Unmodify状态. 执行git reset HEAD filename取消暂存, 文件状态为Modified

查看文件状态

1
2
3
4
5
6
7
8
#查看指定文件状态
git status [filename]

#查看所有文件状态
git status

git add . #添加所有文件到暂存区
git commit -m "消息内容" #提交暂存区中的内容到本地仓库 -m 提交信息

image-20230322105940114

image-20230322110420847

image-20230322110747597

忽略的文件

有些时候我们不想把某些文件纳入版本控制中,比如数据库文件,临时文件,设计文件等

在主目录下建立”.gitignore”文件,此文件有如下规则:

  1. 忽略文件中的空行或以井号(#)开始的行将会被忽略。
  2. 可以使用Linux通配符。例如:星号(*)代表任意多个字符,问号(?)代表一个字符,方括号([abc])代表可选字符范围,大括号({string1,string2,…})代表可选的字符串等。
  3. 如果名称的最前面有一个感叹号(!),表示例外规则,将不被忽略。
  4. 如果名称的最前面是一个路径分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件不忽略。
  5. 如果名称的最后面是一个路径分隔符(/),表示要忽略的是此目录下该名称的子目录,而非文件(默认文件或目录都忽略)。
1
2
3
4
5
6
#为注释
*.txt #忽略所有 .txt结尾的文件,这样的话上传就不会被选中!
!lib.txt #但lib.txt除外
/temp #仅忽略项目根目录下的TODO文件,不包括其它目录temp
build/ #忽略build/目录下的所有文件
doc/*.txt #会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

image-20230322111633086

配置SSH公钥连接远程仓库

PS:实现免密码登录

Git同时配置Github和Gitee

新建仓库

在gitee上创建仓库,并将克隆连接复制,克隆到本地

image-20230322160420158

image-20230322160357273

PS:可能会要输入密码

在IDEA中集成Git

创建一个项目例如:springboot,会发现项目自带.gitgnore

PS:如何创建springboot项目

image-20230322165018325

此时可以看见这里没有git图标

image-20230322165216776

此时把远程克隆的项目复制到我们创建的文件夹下

image-20230322165552090

此时在去idea里看变化

image-20230322170023324

修改文件,使用IDEA操作git。

image-20230322170450774

image-20230322170631404

image-20230322171142537

提交成功后会出现

image-20230322171211053

此时就可以在日志里看到

image-20230322171338819

然后上传远端,git push

image-20230322171633259

PS:如果你之前拷贝的是gitee里拉去的项目,此时push到的是gitee

此时可以看到看到gitee仓库已经有我们的内容了

image-20230322172027269

Git分支

这就是分支,在出现多人进行,或者版本更替等等,会需要一个仓库里有多个分支

image-20230322173429562

image-20230322174013731

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# 列出所有本地分支
$ git branch

# 列出所有远程分支
$ git branch -r

# 列出所有本地分支和远程分支
$ git branch -a

# 新建一个分支,但依然停留在当前分支
$ git branch [branch-name]

# 新建一个分支,并切换到该分支
$ git checkout -b [branch]

# 新建一个分支,指向指定commit
$ git branch [branch] [commit]

# 新建一个分支,与指定的远程分支建立追踪关系
$ git branch --track [branch] [remote-branch]

# 切换到指定分支,并更新工作区
$ git checkout [branch-name]

# 切换到上一个分支
$ git checkout -

# 建立追踪关系,在现有分支与指定的远程分支之间
$ git branch --set-upstream [branch] [remote-branch]

# 合并指定分支到当前分支
$ git merge [branch]

# 选择一个commit,合并进当前分支
$ git cherry-pick [commit]

# 删除分支
$ git branch -d [branch-name]

# 删除远程分支
$ git push origin --delete [branch-name]
$ git branch -dr [remote/branch]

如果同一个文件在合并分支时都被修改了则会引起冲突:解决的办法是我们可以修改冲突文件后重新提交!选择要保留他的代码还是你的代码!

**master主分支应该非常稳定,用来发布新版本,一般情况下不允许在上面工作,工作一般情况下在新建的dev分支上工作,工作完后,比如上要发布,或者说dev分支代码稳定后可以合并到主分支master上来。**

PS:在gitee上有很多git相关知识,每个仓库的最下方都有

image-20230322185335200

PS:个人认为主要就记住最主要的六个,其他需要的时候自然会找到

本文章参考:来自于微信公众号狂神说狂神聊Git

学习视频:bilbil