用Git很多年了,其实就会几条命令,本篇主要讲一下Git基本概念,不涉及分支管理。
1、Git
Git是Linus两周时间用C语言写出来的一个分布式版本控制系统。
2、分布式VS集中式
Git是分布式版本管理系统,但实际上Git和SVN一样都会有一个远程服务器,不过Git有本地仓库概念,并且本地仓库有完整的版本信息记录,而SVN并没有,其它的都差不多,其实Git在小团队中相比SVN有什么优势我也没搞懂,大家都用Git我们也用,不然感觉落伍了。:)
3、Git客户端安装配置
# Linux
yum install git
# Mac
homebrew install git
git config --global user.name "Your Name"
git config --global user.email "email@example.com"
4、本地版本库
# 创建工作区
cd /Users/qingcai18036/testgit
# 初始化为Git可管理的本地仓库
git init
# 初始化后会在工作区下创建一个隐藏目录.git
# 这个目录存储所有版本相关信息
5、远程仓库
Git远程仓库可以使用GitLab搭建或者在GitHub网站自己账号下创建一个仓库,GitLab手工搭建还是有点麻烦的,它依赖于mysql、redis,可以用docker方式一键式安装。
(1)将本地库关联远程仓库?
#关联远程库
git remote add origin
git@github.com:qingcai18036/testgit.git
# 将本地库推送到远程
git push -u origin master
(2)从远程库克隆到本地
一般开发流程都是先在远程GitLab创建项目仓库,然后大家使用克隆方式从远程下载代码骨架,可以使用http或ssh协议,用ssh协议需要将你本机的公钥配置在GitLab里。
# 使用SSH协议
git clone git@github.com:qingcai18036/testgit.git
# 使用https协议
git clone https://github.com/qingcai18036/testgit.git
6、Git核心四个区(重点理解)
四个存储区 工作区(WorkSpace): 项目工程目录,源代码在该区修改。 暂存区(Index):在工作区和本地版本库之间的一个临时存储区。 本地版本库(Head): ?Head就是一个指向本地当前分支的指针。 远程仓库(Remote):一般是指远程GitLab服务器,这样便于管理。 提交推送命令 git add file :将WorkSpace代码添加到Index。 git commit -m 'xxx':将代码从Index提交到Head。 git push:将本地Head区代码推到远程库。 回退命令 git checkout file:将Index区的代码覆盖掉WorkSpace区代码。 git reset file:用Head区覆盖掉Index区代码,Index不会覆盖WorkSpace. git reset --hard :用远程库覆盖本地库代码,git reset --hard HEAD^ 回退到上一个版本,你本地WorkSpace和Index和Head区都会被重置。 其它命令 git status:查看本地仓库状态。 git diff:对比各个区文件不同和不同分支文件的不同。 git log:显示所有提交过的版本信息,不含已被删除commit和reset操作。 git reflog:显示所有的提交和回退信息。
|