文章目录
- Git分布式版本控制工具
- 版本控制器的方式
- 常用命令
- 远程仓库
- Tip
 
Git分布式版本控制工具
 Git是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。
 Git是分布式的,Git不需要有中心服务器,我们每台电脑拥有的东西都是一样的。我们使用Git并且有个中心服务器,仅仅是为了方便交换大家的修改,但是这个服务器的地位和我们每个人的PC是一样的。我们可以把这个服务器当作一个开发者的PC就可以,就是为了大家代码容易交流不关机用的。没有这个服务器大家一样可以工作,只不过“交换“修改不方便而已。
 
版本控制器的方式
集中式版本控制工具
 集中式版本控制工具,版本库是集中存放在中央服务器的,team里每个人work时从中央服务器下载代码,是必须联网才能工作,局域网或互联网。个人修改后提交到中央版本库。如:SVN、CVS
 
分布式版本控制工具
 分布式版本控制系统没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样工作的时候,无需要联网了,因为版本库就在你自己的电脑上。多人协作只需要各自的修改推送给对方,就能互相看到对方的修改了。如:Git
常用命令
Git工作流程:
 
-  clone:从远程仓库中克隆代码到本地仓库 
-  checkout:从本地仓库中检出一个仓库分支然后进行修改 
-  add:在提交前先将代码提交到暂存区 
-  commit:提交到本地仓库,本地仓库中保存修改的各个历史版本 
-  fetch:从远程库抓取到本地仓库,不进行任何的合并动作 
-  pull:从远程库拉到本地库,自动进行合并(merge),然后放到工作区,相当于 fetch+merge
-  push:将代码推送到远程仓库 
-  git config:配置信息# 设置用户信息 git config --global user.name "userName" git config --global user.email "Email"# 查看配置信息 git config --global user.name git config --global user.email
-  alias:配置命令别名,在~/.bashrc中添加配置,修改完成后需要执行source ~/.bashrc# 部分windows系统不允许用户创建.开头的文件,可以在gitBash中执行 touch ~/.bashrc# 在~/.bashrc中添加内容,输出git提交日志 alias git-log='git log --pretty=oneline --all --graph --abbrev-commit'
-  git init:初始化当前目录为一个git仓库,执行成功后会多个.git文件夹
-  git status:查看修改状态(暂存区、工作区)
  
-  git add:添加工作区一个或多个文件的修改到暂存区git add 单个文件名 | 通配符# 将所有修改加入到暂存区 git add .
-  git commit:提交暂存区内容到本地仓库的当前分支,git commit -m '注释内容'
-  git log:查看提交日志,配置别名git-loggit log [option]--all 显式所有分支--pretty=oneline 将提交信息显示为一行--abbrev-commit 使得输出的commitId更简短--graph 以图的形式显示
-  git reset:版本回退# 查看已经删除的记录,可以看到已经删除的提交记录 git reflog# 版本切换,commitId可以通过git log查看 git reset --hard commitId
-  git branch:查看本地分支,使用分支意味着可以把工作从开发主线上分离开来进行Bug修复和开发新功能,以免影响主线-  master(生产)分支:线上分支,主分支,中小规模项目作为线上运行的应用对应的分支 
-  develop(开发)分支:是从master创建的分支,一般作为开发部分的主要开发分支,如果没有其它并行开发不同期上线要求,都可以在此版本进行开发,阶段开发完成后,需要合并到master分支,准备上线 
-  feature/xxx分支:从develop创建的分支,一般是同期并行开发,但不同期上线时创建的分支,分支上研究任务完成后合并到develop分支 
-  hotfix/xxx分支:从master派生的分支,一般作为线上bug修复使用,修复完成后需要合并到master、test、develop分支 
-  test(测试)分支 
-  pre(预上线)分支 
  
 # 查看本地分支 git branch# 创建本地分支 git branch 分支名# 切换分支 git checkout 分支名# 切换到一个不存在的分支,创建并切换 git checkout -b 分支名# 合并分支,一个分支上的提交可以合并到另一个分支 git merge 分支名# 删除分支,不能删除当前分支,只能删除其它分支 # 删除时需要做各种检查 git branch -d 分支名 # 强制删除,不做任何检查 git branch -D 分支名
-  
-  冲突解决:当两个分支上对文件的修改可能会存在冲突,如同时修改了同一文件的同一行,需要手动解决冲突,步骤如下: - 处理文件中冲突的地方
- 将解决完冲突的文件加入暂存区(add)
- 提交到仓库(commit)
 
远程仓库
-  git remote add:添加远程仓库,此操作是先初始化本地库,然后与已创建的远程库进行对接git remote add <远端名称> <仓库路径>远端名称:默认是origin,取决于远程服务器设置仓库路径:从远端服务器获取此URL git remote add origin git@gitee.com:lshibo/local-git-store.git
-  git remote:查看远程仓库
-  git push:推送到远程仓库库git push [-f] [--set-upstream] [远端名称 [本地分支名][:远端分支名]]-f 强制覆盖--set-upstream 推送到远端的同时并且建立起和远端分支的关联关系# 如果远端分支名=本地分支名,则可以只写本地分支 git push origin master# 如果当前分支已经和远端分支关联,则可以省略分支名和远端名 # 将master分支推送到已关联的远端分支 git push
-  git branch -vv:查看本地分支与远程分支的关联关系
-  git clone:clone远端仓库到本地git clone <仓库路径> [本地目录]本地目录可以省略,会自动生成一个目录
-  git fetch [remote name] [branch name]:将仓库里的更新都抓取到本地,不会进行合并。如果不指定远端名称和分支名,则抓取所有分支
-  git pull [remote name] [branch name]:拉取指令就是将远端仓库的修改拉到本地并自动进行合并,等同于fetch+merge。如果不指定远端名称和分支名,则抓取所有并更新当前分支。
-  解决合并冲突:先拉去远程仓库,经过合并后才能推送到远端分支 
  
Tip
-  GitBash乱码问题 - 打开GitBash执行git config --global core.quotepath false命令
- 在${git_home}/etc/bash.bashrc文件最后添加export LANG="zh_CN.UTF-8" export LC_ALL="zh_CN.UTF-8"
 
- 打开GitBash执行
-  添加文件到忽略列表:在工作目录创建 .gitignore文件(文件名称固定),列出要忽略的文件模式# no .a files *.a # but do track lib.a, even though you're ignoring .a files above !lib.a # only ignore the TODO file in the current directory, not subdir/TODO /TODO # ignore all files in the build/ directory build/ # ignore doc/notes.txt, but not doc/server/arch.txt doc/*.txt # ignore all .pdf files in the doc/ directory doc/**/*.pdf
参考:黑马