Git 一些知识点
Git 一些知识点配置ssh:部分命令从远程库clone分支部分命令:分支管理分支合并冲突分支策略情况处理多人协作一些小细节:标签管理:搭建git服务器
linux和windows安装:
①下载git。
②配置user.email、user.name
git congif --global user.email "email"
git config --global user.name "name"
②创建repository:cd到一个目录,然后git init,将其变成可管理的仓库。
③配置ssh
配置ssh:
说明:由于本地git和github等远程仓库是通过ssh(Secure Shell,安全外壳协议)传输,所以需要进行一些配置。
①:创建SSH Key。
在git bash里面输入:ssh-keygen -t rsa -C 'email'
//创建成功会在/c/user/administrator/下有.ssh文件夹。linux在~/.ssh里
②:在远程仓库(如github)上设置ssh key
在github里:account——》setting——》SSH——》add SSH key:
输入任意标题和.ssh文件夹里的id_rsa.pub即可
③:连接远程库。
在git bash:> git remote add origin(默认远程库名,可修改) url
然后:> git push -u oringin branch
(默认为master) //-u用于首次push,使不仅提交分支到远程仓库,
//还可以与其建立连接,方便以后push或clone
以后每次提交到远程库:> git push origin branch
更改url(http to ssh):在.git/config文件中,修改url = new url。
注意Error:当ubuntu出现permission denied时,作如下:
ssh-agent bash
ssh-add /home/ubuntu/.ssh/id_rsa
当出现unrelated:git pull origin master --allow-unrelated-histories
部分命令
撤回:git checkout [editionId | -- fileName]
:checkout的功能就是覆盖。所以checkout分支时,分支会覆盖当前分支。当checkout一个旧版本时,会覆盖当前版本,但是不会像reset直接恢复到之前版本,而是新建一个detached head头部分离的分支。
恢复:想要将恢复成之前的状态,用git reset
命令。ps:reset不会删掉工作区内容。
提交子命令:
--pretty=oneline
:以一行来表示一个历史提交。--graph
:以图示列出历史提交。abbrev-commit
:缩写提交id。
()别名*:可以自定义命令的别名:git config --global alias.custom 'real command'
。如:git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
以后直接用lg,就轻松可以得到日志信息了。
- config文件位置:如果是--local,则是当前仓库/.git/config。如果是--global,则是user/adminstrator/.gitconfig (windows)
删除别名:在/.git/config里面,删掉alias就可以了。
从远程库clone分支
如window上打开git cmd:> git clone git@github.com:mrsun002/gitskills.git
会安装到当前工作区。(包含.git文件的父目录)
url:两种传输协议:https | ssh ; 推荐ssh,速度快,而且不用输入口令。
查看远程库信息:git remote
or 详细信息:git remote -v
克隆之后获得新版本:git pull
部分命令:
取消临时区的内存(已add):git restore --staged fileName
分支管理
说明:git用分支来管理版本库,有一个主分支和多个其他分支。可以随意切换到其他分支(变成主分支),或者合并其他分支(非当前分支)。
注意:switch是从当前分支上,创建分支。
命令:
git checkout -b branchName //建立分支,并切换到该分支,等于下面两个命令。
git switch -c branchName //同上。
git branch branchName //如果没有,创建分支
git checkout branchName //转移到指定分支,下条同意但更清晰。
git switch branchName
git merge branchName //将branchName与当前分支合并。
git branch -d branchName //删除branchName分支。
git branch //查看当前已有分支
禁用fast forward
:git merge默认是快进模式,可以禁用,但合并分支时代码变成:git merge --no-ff -m 'merge with no-ff' branch2
。
因为禁用ff后,会提交一个修改,所以需要-m 'message'
好处:ff模式下,无法看到分支合并的历史信息。而普通模式可以看到。在团队工作项目合并时,应该用普通模式合并。
分支合并冲突
说明:当分支各有commit,而导致矛盾无法合并时,必须要修复conplict矛盾才行。
用git log --gragh
可以看到分支合并图
分支策略
master分支:追求稳定,仅用于发布新版本,而不能在上面干活。
dev分支:不稳定分支,团队成员在这个分支上干活,每个人都有自己的分支,不时地往dev上合并就行。如michael和bob分支。
情况处理
BUG急需修复,但当前工作未做完不能commit:(临时区已经有待提交已add的文件,但还有别的文件要一起提交,而又需提交BUG修复的文件)
说明:修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除分支;
储藏:git stash
功能:把当前工作现场储藏起来,等以后恢复现场后继续工作。(保存stage区,git status无文件)
恢复:
git stash pop
:恢复并且删掉stash文件。git stash apply
:仅恢复但并不删掉stash文件。如果要删除,需要:git stash drop
注意:通常一个master主分支有bug,dev分支也会有。所以也要处理dev分支上的内容。而git专门提供了一个命令:cherry-pick
(做出最佳选择)。步骤:跳转到待修复分支dev。然后执行:git cherry-pick commitID
(commitID:之前修复bug分支的commit,而不是master合并commit。)
多人协作
①clone:当从远程仓库clone时,只能得到master分支,需要输入如下命令获得其他分支:
git checkout -b dev origin/dev
②冲突:当你和同事的最新提交有冲突时,用git pull
把最新的提交抓取下来,然后在本地合并,再提交。
③rebase:当要维护master的直线性,--graph中没有分支。当提交dev分支时,先git pull最新master,然后如果发现冲突,而又不想直接用merge,则可以使用(dev)> git rebase master
来。然后再切换master并进行merge即可。
- 功能:其将dev和master的上个交叉点之后的所有commit取消,并保存commit信息,然后获得master的更改后版本(相当于指向了现在的master),然后再恢复之前保存的commit信息,所以就不会出现分叉。
当git pull失败时,指定本地dev
分支和远程origin/dev
的链接:
$ git branch --set-upstream-to=origin/dev dev Branch 'dev' set up to track remote branch 'dev' from 'origin'.
详细:http://gitbook.liuhui998.com/4_2.html
因此,多人协作的工作模式通常是这样:
首先,可以试图用
git push origin
推送自己的修改;如果推送失败,则因为远程分支比你的本地更新,需要先用
git pull
试图合并;如果合并有冲突,则解决冲突,并在本地提交;
没有冲突或者解决掉冲突后,再用
git push origin
推送就能成功!
如果git pull
提示no tracking information
,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to origin/
。
这就是多人协作的工作模式,一旦熟悉了,就非常简单。
一些小细节:
开发新feature:最好新建一个分支。如果要丢弃一个未合并的分支,用git branch -D name
而不是-d
分支推送:并不是一定要把本地分支往远程推送,那么,哪些分支需要推送,哪些不需要呢?
master
分支是主分支,因此要时刻与远程同步;dev
分支是开发分支,团队所有成员都需要在上面工作,所以也需要与远程同步;bug分支只用于在本地修复bug,就没必要推到远程了,除非老板要看看你每周到底修复了几个bug;
feature分支是否推到远程,取决于你是否和你的小伙伴合作在上面开发。
多个远程库:一个本地库可关联多个远程库,此时对每个远程库取不同的名字即可。git remote add nameX url
忽视特殊文件:在工作区建立.gitignore文件。
别名:可以自定义命令的别名:git config --global alias.custom 'real command'
。如:git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
以后直接用lg,就轻松可以得到日志信息了。
标签管理:
说明:用git tag
来打标签。
给分支打标签:切换到该分支,然后git tag tName
即可。注意,当前分支的版本号,是打在现在的分支状态,即如果又提交了,则版本号对应前一个commit。
查看指定标签及其对应提交:git show tag
其他操作:
-
删除:
git tag -d tName
远程标签:当push时,标签并不会随着push到远程,只在本地储存。若需要给远程库添加标签,则直接用:git push origin tName
即可,会给当前commit点添加标签。
推送全部本地标签:
git push origin --tags
删除远程标签:git push origin :refs/tags/tName
搭建git服务器
https://www.liaoxuefeng.com/wiki/896043488029600/899998870925664