文章目录
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
:配置信息shell# 设置用户信息 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
shell# 部分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
:添加工作区一个或多个文件的修改到暂存区shellgit add 单个文件名 | 通配符 # 将所有修改加入到暂存区 git add .
-
git commit
:提交暂存区内容到本地仓库的当前分支,git commit -m '注释内容'
-
git log
:查看提交日志,配置别名git-log
shellgit log [option] --all 显式所有分支 --pretty=oneline 将提交信息显示为一行 --abbrev-commit 使得输出的commitId更简短 --graph 以图的形式显示
-
git reset
:版本回退shell# 查看已经删除的记录,可以看到已经删除的提交记录 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(预上线 )分支
shell# 查看本地分支 git branch # 创建本地分支 git branch 分支名 # 切换分支 git checkout 分支名 # 切换到一个不存在的分支,创建并切换 git checkout -b 分支名 # 合并分支,一个分支上的提交可以合并到另一个分支 git merge 分支名 # 删除分支,不能删除当前分支,只能删除其它分支 # 删除时需要做各种检查 git branch -d 分支名 # 强制删除,不做任何检查 git branch -D 分支名
-
-
冲突解决:当两个分支上对文件的修改可能会存在冲突,如同时修改了同一文件的同一行,需要手动解决冲突,步骤如下:
- 处理文件中冲突的地方
- 将解决完冲突的文件加入暂存区(add)
- 提交到仓库(commit)
远程仓库
-
git remote add
:添加远程仓库,此操作是先初始化本地库,然后与已创建的远程库进行对接shellgit remote add <远端名称> <仓库路径> 远端名称:默认是origin,取决于远程服务器设置 仓库路径:从远端服务器获取此URL git remote add origin git@gitee.com:lshibo/local-git-store.git
-
git remote
:查看远程仓库 -
git push
:推送到远程仓库库shellgit push [-f] [--set-upstream] [远端名称 [本地分支名][:远端分支名]] -f 强制覆盖 --set-upstream 推送到远端的同时并且建立起和远端分支的关联关系 # 如果远端分支名=本地分支名,则可以只写本地分支 git push origin master # 如果当前分支已经和远端分支关联,则可以省略分支名和远端名 # 将master分支推送到已关联的远端分支 git push
-
git branch -vv
:查看本地分支与远程分支的关联关系 -
git clone
:clone远端仓库到本地shellgit 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
文件最后添加shellexport LANG="zh_CN.UTF-8" export LC_ALL="zh_CN.UTF-8"
-
-
添加文件到忽略列表 :在工作目录创建
.gitignore
文件(文件名称固定),列出要忽略的文件模式shell# 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
参考:黑马