一、什么是git?
Git是分布式版本控制系统
概念:
- 工作区:就是你在电脑里能看到的目录;
- 暂存区:一般存放在(.git/index)中,所以我们把暂存区有时也叫作索引(index);
- 版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库发布管理;
二、集中式vs分布式
- 集中式版本控制系统,版本库是集中存放在*服务器的,而干活的时候,用的都是自己的电脑,所以要先从*服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给*服务器。*服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。
- 集中式版本控制系统最大的毛病就是必须联网才能工作;
- 分布式版本控制系统根本没有“*服务器”,每个人的电脑上都是一个完整的版本库:
这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。而集中式版本控制系统的*服务器要是出了问题,所有人都没法干活了。
在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机。因此,分布式版本控制系统通常也有一台充当“*服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。
- Git极其强大的分支管理,把SVN等远远抛在了后面;
三、git使用(https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000)
使用工作流程
- 克隆 Git资源作为工作目录:gitclone http://xxxxxxxx.git;
- 切换到dev分支:gitcheckoutdev;
- 更新获取资源源码:gitpull origin xxx;
- 在克隆的资源上添加或修改文件: gitadd <filename>/gitadd*;
- 在提交前查看修改:gitlog;
- 提交修改:gitcommit -m "代码提交信息";
- 提交到远程库:gitpush origin xxx;
分支管理
- 查看分支:gitbranch;
- 切换分支: gitcheckout (branchname);
- 创建分支:gitbranch (branchname),创建分支项目中技术经理会负责创建;
- 一般项目上有多少环境就创建几个分支,一般项目都是3个环境(DEV,UAT,PROD);
四、git基本命令
五、git代码冲突解决
冲突的原因
两个已经提交的分支的相同文件相同位置的的不同操作进行了合并
影响
git pull时的自动merge被中断,有可能引起大范围的文件变更,对版本库形成较大风险;
在git pull时git会将remote库的资源下载并自动merge到本地版本库,并自动commit远程库;
解决(2种)
- 代码回滚:gitrevert与gitreset,通知技术经理,根据影响范围确定执行REVERT还是RESET;
- 解决冲突:
- 执行gitadd xxx(xxx为冲突文件全路径)
- 执行gitrebase --continue
- 执行gitpull --rebase
- 执行gitpush
六、gitLab和gitHub
- git是一种版本控制系统,是一个命令,是一种工具;
- gitlab 是一个基于git实现的在线代码仓库软件,你可以用gitlab自己搭建一个类似于github一样的系统,一般用于在企业、学校等内部网络搭建git私服, 如公司的RDC;
- github是一个基于git实现的在线代码仓库,包含一个网站界面,向互联网开放;