目录
一、Git 介绍
Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。与常用的版本控制工具 CVS、Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持。接下来看看 Git 与 SVN 之间的区别及其工作流程。
二、Git 与 SVN 的区别
- GIT 是分布式的,SVN 不是:这是 GIT 和其它非分布式的版本控制系统最核心的区别。
- GIT 把内容按元数据方式存储,而 SVN 是按文件(所有的资源控制系统都是把文件的元信息隐藏在一个类似**.svn,.cvs**等的文件夹里)
- GIT 分支和 SVN 的分支不同:SVN 分支就是版本库中的另外的一个目录。
- GIT 没有一个全局的版本号,而 SVN 有:目前为止这是跟SVN相比GIT缺少的最大的一个特征。
- GIT 的内容完整性要优于 SVN:GIT的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。
三、Git 工作流程
四、Git 基本概念
-
工作区:
就是你在电脑里能看到的目录。 -
暂存区:
英文叫stage, 或index。一般存放在"git目录"下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。 -
版本库:
工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。为什么叫版本库呢?实际上不难理解,好比一个研发人员写完代码后,最终会将代码push到远程仓库上,那么对于研发人员来说,他push的这一次就好比他写的代码的第一个版本,并且将他的这个版本上传到了他自己的仓库中,也就是我们说的版本库(即.git目录)。
五、Git 基本操作
5.1 SSH Clone 远程仓库代码
[root@web ~]# git clone git@192.168.139.154:/home/git/sz2002.git
[root@web ~]# cd sz2002 # 进入克隆下来的工作目录
[root@web sz2002]# git pull origin master # 拉取代码(de每次写代码的时候都会拉取代码)--保证数据的完整性,防止文件冲突
[root@web sz2002]# mkdir html # 可在工作目录中创建相关不得目录
[root@web sz2002]# git add . # 添加到暂存区
[root@web sz2002]# git status # 查看缓存区都添加了哪些内容
[root@web html]# git checkout . # 如果发现代码写错了,使用该命令踢出暂存区的内容再次修改相关文件内容后,再add即可
[root@web sz2002]# git commit -m 'HTML代码提交' # 添加到本地仓库.git,如果想要对文件再次进行修改,可以不用再次执行git checkout . 命令,直接vim修改文件、正常提交即可。因为到这一步仅仅是将数据存到了我.git的本地私人仓库,并没有push到远程仓库。
[root@web sz2002]# git remote -v # 看远程仓库信息,一般你从哪里clone的,就会显示哪个仓库信息
[root@web sz2002]# git push origin master # 将写的代码推到Git平台上,给项目经理看,或方便其他开发人员pull代码
5.2 HTTP Clone 远程仓库代码
[root@web ~]# git clone http://192.168.139.154/home/git/sz2002.git
[root@web ~]# cd sz2002 # 进入克隆下来的工作目录
[root@web sz2002]# git pull origin master # 拉取代码(de每次写代码的时候都会拉取代码)--保证数据的完整性,防止文件冲突
[root@web sz2002]# mkdir html # 可在工作目录中创建相关不得目录
[root@web sz2002]# git add . # 添加到暂存区
[root@web sz2002]# git status # 查看缓存区都添加了哪些内容
[root@web html]# git checkout . # 如果发现代码写错了,使用该命令踢出暂存区的内容再次修改相关文件内容后,再add即可
[root@web sz2002]# git commit -m 'HTML代码提交' # 添加到本地仓库.git,如果想要对文件再次进行修改,可以不用再次执行git checkout . 命令,直接vim修改文件、正常提交即可。因为到这一步仅仅是将数据存到了我.git的本地私人仓库,并没有push到远程仓库。
[root@web sz2002]# git remote -v # 看远程仓库信息,一般你从哪里clone的,就会显示哪个仓库信息
[root@web sz2002]# git push origin master # 将写的代码推到Git平台上,给项目经理看,或方便其他开发人员pull代码
注:HTTP 操作和 SSH 一致,只是 clone 的方式不同,再就是 HTTP 方式的 clone 需要输入用户名及密码。
5.3 Git 常用命令
git init # 初始化
git add main.cpp # 将某一个文件添加到暂存区
git add . # 将文件夹下的所有的文件添加到暂存区
git commit -m ‘note‘ # 将暂存区中的文件保存成为某一个版本
git log # 查看所有的版本日志
git status # 查看现在暂存区的状况
git diff # 查看现在文件与上一个提交-commit版本的区别
git reset --hard HEAD^ # 回到上一个版本
git reset --hard XXXXX # XXX为版本编号,回到某一个版本
git pull origin master # 从主分支pull到本地
git push -u origin master # 从本地push到主分支
git pull # pull默认主分支
git push # push默认主分支 ...
Git 的用法还有很多,这里就不再一一例举,只不过是让大家初步了解一下什么是 Git、Git 的工作原理、基本操作命令以及 Git 和其他版本控制系统的区别。