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 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分支。

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


©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352