Git学习
1.Git工作流程图
命令如下: 1.clone(克隆):从远程仓库中克隆代码到本地仓库; 2. checkout(检出):从本地仓库中检出一个仓库分支然后进行修订; 3. add(添加):在提交前先将代码提交到暂存区; 4. commit(提交):提交到本地仓库。本地仓库中保存修改的各个历史版本; 5. fetch (抓取):从远程库,抓取到本地仓库,不进行任何的合并动作,一般操作比较少; 6. pull (拉取):从远程库拉到本地库,自动进行合并(merge),然后放到到工作区,相当于fetch+merge; 7. push(推送):修改完成后,需要和团队成员共享代码时,将代码推送到远程仓库;
2.Git常用命令
2.1 基本配置
git config --global user.name "name" git config --global user.email "email"
2.2 查看配置信息
git config --global user.namegit config --global user.email
2.3 基本操作指令
git add (工作区-->暂存区) git commit (暂存区-->本地仓库) git status (查看修改的状态) git add (添加工作区一个或多个文件的修改到暂存区) git add . (将所有修改加入暂存区) git commit -m '注释内容' (提交暂存区内容到本地仓库的当前分支) git log [option] options: --all 显示所有分支 --pretty=oneline 将提交信息显示为一行 --abbrev-commit 使得输出的commitId更简短 --graph 以图的形式显示 git reset --hard commitID (版本回退 commitID可以使用git log查看) git relog (看到已经删除的提交记录)
2.4 分支命令
git branch (查看本地分支) git branch '分支名' (创建本地分支) git checkout 分支名 (切换分支) git checkout -b (还可以直接切换到一个不存在的分支(创建并切换)) git merge 分支名称 (一个分支上的提交可以合并到另一个分支) git branch -d 分支名称 (不能删除当前分支,只能删除其他分支) git branch -D 分支名称 (不做任何检查,强制删除) 解决冲突 1.处理文件中冲突的地方 2.将解决完冲突的文件加入暂存区(add) 3.提交到仓库(commit)
2.5 分支名规范使用原则和流程
在开发中,一般有如下分支使用原则与流程: master(生产)分支线上分支,主分支,中小规模项目作为线上运行的应用对应的分支; develop(开发)分支是从master创建的分支,一般作为开发部门的主要开发分支,如果没有其他并行开发不同期上线要求,都可以在此版本进行开发,阶段开发完成后,需要是合并到master分支,准备上线。 feature/xxxx分支从develop创建的分支,一般是同期并行开发,但不同期上线时创建的分支,分支上的研发任务完成后合并到develop分支。 hotfix/xxxx分支,从master派生的分支,一般作为线上bug修复使用,修复完成后需要合并到master、test、develop分支。 还有一些其他分支,在此不再详述,例如 test分支(用于代码测试)、 pre分支(预上线分支)等等。
2.6 生成SSH公钥
ssh-keygen -t rsa