文章目录
分布式版本控制系统
特点:基于服务器、客户端的运行模式
●服务 器保存文件的所有更新版本
●客户端是服务器的完整备份,并不是只保留文件的最新版本
优点:
- 联网运行,支持多人协作开发。
- 客户端断网后支持离线本地提交版本更新。
- 服务器故障或损坏后,可使用任何一一个客户端的备份进行恢复。
初识Git
配置Git 桌面鼠标右击 打开 Git Bash here 终端
输入
git config --global user.name"用户名"
git config --global user.email"邮箱地址"
通过git config --global user.name和git config --global user.email配置的用户名和邮箱地址,会被写
入到C:/Users/用户名文件夹/.gitconfig文件中。这个文件是Git 的全局配置文件,配置-次即可永久生效。
可以使用记事本打开此文件,从而查看自己曾经对Git做了哪些全局性的配置。
可以使用git help config 命令,无需联网即可在浏览器中打开帮助手册
更简明的帮住手册 git config -h
Git之所以快速和高效,主要依赖于它的如下两个特性:
- 直接记录快照,而非差异比较.
- 近乎所有操作都是本地执行
Git快照是在原有文件版本的基础,上重新生成一份新的文件, 类似于备份。
为了效率,如果文件没有修改,Git
不再重新存储该文件,而是只保留一个链接指向之前存储的文件。
缺点:占用磁盘空间较大。
优点:版本切换时非常快,因为每个版本都是完整的文件快照,切换版本时直接恢复目标版本的快照即可。
特点:空间换时间。
在Git中的绝大多数操作都只需要访问本地文件和资源,一般不
需要来自网络上其它计算机的信息。
特性:
- 断网后依旧可以在本地对项目进行版本管理。
- 联网后,把本地修改的记录同步到云端服务器即可。
获取Git仓库
-
将尚未进行版本控制的本地目录转换为Git仓库。
-
从其它服务器克隆一个已存在的Git仓库。
现有目录初始化Git仓库
- 在项目目录中,通过鼠标右键打开"Git Bash Here"。
- 执行 git init 命令将当前的目录转化为Git仓库。
git init命令会创建一一个名为 .git 的隐藏目录,这个 .git 目录就是当前项目的Git仓库,里面包含了初始的必要
文件,这些文件是Git仓库的必要组成部分 (打开文件的查看将 隐藏项目选择可查看)。
使用Git管理的项目
拥有:
三个区域:
- 工作区:处理工作的区域。
- 暂存区:已完成的工作的临时存放区,等待被提交。
- Git 仓库:最终存放区域。
工作区域中的文件状态
四种状态分为两大类:
未被Git管理:
- 未跟踪(Untracked):不被Git管理的文件(新建的文件…)。
已被Git管理:
- 未修改(Unmodified) : 工作区中文件的内容和Git仓库中文件的内容保持一致。
- 已修改(Modified ):工作区中文件的内容和Git仓库中文件的内容不一致。
- 已暂存(Staged):工作区中被修改的文件已被放到暂存区,准备将修改后的文件保存到Git 仓库中。
注意:
●工作区的文件被修改了 ,但还没有放到暂存区,就是已修改状态。
●如果文件已修改并放入暂存区,就属于已暂存状态。
●如果Git 仓库中保存着特定版本的文件,就属于已提交状态。
基本的Git工作流程:
- 在工作区中修改文件。
- 将你想要下次提交的更改进行暂存。
- 提交更新,找到暂存区的文件,将快照永久性存储到Git仓库。
检查文件的状态
使用 git status 命令查看文件处于什么状态。
git status -s 来精简的显示文件状态 未跟踪的文件(Untracked files) 前面有红色的 ??标记。
已暂存(Staged) 绿色的文件名。
clear 清空当前的窗口 更好的观察命令
跟踪新文件
git add 命令开始跟踪一个文件,git add index.html 加文件名。
此时再运行git status命令,会看到new file : index.html文件在Changes to be committed 这行的下面,说明已被
跟踪,并处于已暂存(Staged) 状态。
提交更新
现在暂存区中有一个index.html文件等待被提交到Git仓库中进行保存。可以执行 git commit 命令进行提交,
其中 -m 选项后面是本次的提交消息,用来对提交的内容做进一步的描述:
git commit -m "新建了index .html文件”
提交成功之后,再次检查文件的状态,得到提示如下:
On branch master
nothing to commit, working tree clean
证明工作区中所有的文件都处于“未修改”的状态,没有任何文件需要被提交。
对已提交的文件修改
index.html 文件已经被Git跟踪,并且工作区和Git仓库中的index.html文件内容保持一致。当
修改了工作区中index.html的内容之后,再次运行git status和git status -S命令,会看到如下的内容:
$ git status
On branch master
Changes not staged for commit:
(use "git add …“to update what wi 11 be commi tted)
(usegit restore …” to discard changes in working di rectory)
modified:index. html
no changes added to commit (use “git add” and/or “git commit -a”)
$ git status -S