git 一些知识点

Git 一些知识点

Git 一些知识点配置ssh:部分命令从远程库clone分支部分命令:分支管理分支合并冲突分支策略情况处理多人协作一些小细节:标签管理:搭建git服务器

2.jpg

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

当出现unrelatedgit 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 [email protected]: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分支。

0.png

情况处理

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

因此,多人协作的工作模式通常是这样:

  1. 首先,可以试图用git push origin推送自己的修改;

  2. 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;

  3. 如果合并有冲突,则解决冲突,并在本地提交;

  4. 没有冲突或者解决掉冲突后,再用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


你可能感兴趣的:(git 一些知识点)