高级架构二 Git基础到高级

一 Git仓库的基本概念和流程

什么是版本库?版本库又名仓库,英文名repository,你可以简单的理解一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改,删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻还可以将文件”还原”。

1.1 Git仓库的基本概念

  1. 远程仓库(Remote):
    也叫作资源库,是远程机器上的代码库,用于做不同版本库文件交换更新。如Gitlab,GitHub,gitee。
  2. 本地库(Repository):
    是用户在本地创建的目录,拥有远程库的一个快照,由工作区和版本库构成。
  • 工作区(Workspace):
    本地库的根目录中除.git目录以外的内容,存储内容的实际文件。
  • 暂存区(stage/Index):
    也叫做缓存区,暂存信息存放在.git目录"下的index文件(.git/index)中,用于临时保存内容的修改;
  • 版本库(.git目录)
    是本地库的根目录中的一个隐藏目录.git,用于记录版本信息,Git进行版本控制所需要的文件,则都放在.git文件夹中;
  1. 分支(Branch):
    本地库中默认创建一个主(master)分支,分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作。

本地库和远程库的关系
在这里插入图片描述
开发人员通过Git命令来管理代码,最常用的6个命令如下图所示:
在这里插入图片描述

1.2 Git仓库的工作流程

从一般开发者的角度来看,使用Git的工作流程是:

  1. 克隆远程库:从远程库上克隆完整的Git仓库(包括代码和版本信息)到本地;
  2. 在本地库上修改代码:在本地库上根据不同的开发目的,创建分支,修改代码;
  3. 提交到分支:在本地分支上提交代码;
  4. 把修改合并到本地主分支:在本地库上提交更新,也就是说,把修改合并到本地主分支;
  5. 把远程库合并到本地主分支:把远程库上的最新代码fetch下来,跟本地主分支合并,如果存在冲突,那么解决冲突。
  6. 把本地主分支提交到远程库:生成补丁(patch),把补丁发送给远程库。

在这里插入图片描述

二 Git命令

2.1 创建版本库

创建一个版本库也非常简单,如下我是D盘下 目录下新建一个testGit版本库。
右键通过命令行的方式打开窗口
在这里插入图片描述
在这里插入图片描述
pwd 命令是用于显示当前的目录。

通过命令 git init 把这个目录变成git可以管理的仓库,如下
在这里插入图片描述
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。
在这里插入图片描述
这时候你当前testgit目录下会多了一个.git的目录,这个目录是Git来跟踪管理版本的,没事千万不要手动乱改这个目录里面的文件,否则,会把git仓库给破坏了。.git里面内容如下:
在这里插入图片描述

2.2 添加文件和修改提交文件

首先要明确下,所有的版本控制系统,只能跟踪文本文件的改动,比如txt文件,网页,所有程序的代码等,Git也不列外,版本控制系统可以告诉你每次的改动,但是图片,视频这些二进制文件,虽能也能由版本控制系统管理,但没法跟踪文件的变化,只能把二进制文件每次改动串起来,也就是知道图片从1kb变成2kb,但是到底改了啥,版本控制也不知道。

  1. 创建文件readme.txt, 此刻文件在工作区(WorkSpace)
    在这里插入图片描述
    通过git status可以查看文件追踪的情况
    在这里插入图片描述
  2. 使用命令 git add readme.txt添加到暂存区里面去。
    在这里插入图片描述
    我们发现添加到暂存区的时候会有警告出现。不过没关系,是换行符的警告。
    我们可以看到readme.txt目前处于暂存区。

在这里插入图片描述
如果要提交多个文件
我们可以在add后面指定文件的列表

git add test2.txt test3.txt

在这里插入图片描述
如果想要添加工作区所有文件到暂存区(注意后边有个点)

git add .

在这里插入图片描述
我们可以通过提示的话来撤销回工作区

git rm --cached readme.txt

在这里插入图片描述
3. 提交文件到主分支

git commit -m 'first commit'

现在我们已经提交了一个readme.txt文件了,我们下面可以通过命令git status来查看是否还有文件未提交,注意:注释是必须要写的。
在这里插入图片描述
在这里插入图片描述
4. 修改文件,在文件中加入一行。查看git的状态
在这里插入图片描述
我们发现文件进入到工作区
在这里插入图片描述
最新版本改成了

git restore test3.txt

此刻我们发现界面上有两个提示:
(1)提交修改后的文件
在这里插入图片描述
(2)通过checkout上一个版本的文件来覆盖修改后的文件

git checkout -- readme.txt

在这里插入图片描述
注意 :–后面要有空格

2.3 版本回退

2.3.1 日志查看

现在我已经对readme.txt文件做了三次修改了,那么我现在想查看下历史记录,如何查呢?我们现在可以使用命令 git log 演示如下所演示

git log

在这里插入图片描述
git log命令显示从最近到最远的显示日志,我们可以看到最近三次提交
如果嫌上面显示的信息太多的话,我们可以使用命令 git log –pretty=oneline 演示如下:
在这里插入图片描述

2.3.2 版本回退和撤销

  1. 版本回退
    现在我想使用版本回退操作,我想把当前的版本回退到上一个版本,要使用什么命令呢?可以使用如下2种命令,第一种是:git reset --hard HEAD^ ,那么如果要回退到上上个版本只需把HEAD^ 改成 HEAD^^ 以此类推。那如果要回退到前100个版本的话,使用上面的方法肯定不方便,我们可以使用下面的简便命令操作:git reset --hard HEAD~100 即可。未回退之前的readme.txt内容如下:
    在这里插入图片描述
    我们查看文件的内容:
    在这里插入图片描述
    查看提交日志:
    在这里插入图片描述
    同时我们也可以通过sha1的前四位来做回退
git reset –heard sha1
  1. 回退撤销
    我们看到 增加update 2内容我们没有看到了,但是现在我想回退到最新的版本,如:有update 2的内容要如何恢复呢?我们可以通过版本号回退,使用命令方法如下:
    git reset --hard 版本号 ,但是现在的问题假如我已经关掉过一次命令行或者update 2内容的版本号我并不知道呢?要如何知道增加update 2内容的版本号呢?可以通过如下命令即可获取到版本号:git reflog 演示如下:
    在这里插入图片描述
    通过上面的显示我们可以知道,增加内容update 2的版本号是 8d95a43.我们现在可以命令
git reset --hard 8d95a43

在这里插入图片描述
查看撤销后的结果。
在这里插入图片描述

2.4 删除文件

添加并且提交了多个文件
在这里插入图片描述
一般情况下,可以直接在文件目录中把文件删了,或者使用如上rm命令:rm b.txt ,如果我想彻底从版本库中删掉了此文件的话,可以再执行commit命令 提交掉。

git rm test.txt

在这里插入图片描述
我们发现删除的文件直接进入暂存区(此刻需要注意,如果使用rm删除不在暂存区,需要git add才会进入暂存区。如果进入暂存区可以退回工作区,使用下面命令 git reset HEAD test.txt),提交之后文件被删除。
在这里插入图片描述

2.5 Git配置信息Config

2.5.1 Config概述

在git中,我们使用git config 命令用来配置git的配置文件,git配置级别主要有以下3类:
1、仓库级别 local 【优先级最高】
2、用户级别 global【优先级次之】
3、系统级别 system【优先级最低】

git 仓库级别对应的配置文件是当前仓库下的.git/config
git 用户级别对应的配置文件是用户宿主目录下的~/.gitconfig
git系统级别对应的配置文件是git安装目录下的 /etc/gitconfig

当然我们可以在cmd命令提示符中输入以下查看配置信息

git config --local -l

在这里插入图片描述
git config --global -l
在这里插入图片描述

git config --system -l

在这里插入图片描述

2.5.2 Config修改

演示修改用户名和邮箱:

git config --global user.name "renliang"
git config --global user.email "renliang@126.com"

在这里插入图片描述
注意不要手动修改 每个级别的配置文件,要用命令。

对于git来说,配置文件的权重是仓库>全局>系统。Git会使用这一系列的配置文件来存储你定义的偏好,它首先会查找/etc/gitconfig文件(系统级),该文件含有对系统上所有用户及他们所拥有的仓库都生效的配置值。接下来Git会查找每个用户的~/.gitconfig文件(全局级)。最后Git会查找由用户定义的各个库中Git目录下的配置文件.git/config(仓库级),该文件中的值只对当前所属仓库有效。

三 .gitignore文件

在项目中,我们可能一起提交多个文件

  • git add -A 提交所有变化
  • git add -u 提交被修改(modified)和被删除(deleted)文件,不包括新文件(new)
  • git add . 提交新文件(new)和被修改(modified)文件,不包括被删除(deleted)文件

在使用git的过程中,一般我们总会有些文件无需纳入git的管理,也不希望它们总出现在未跟踪文件列表,这些文件通常是日志文件、临时文件、编译产生的中间文件、工具自动生成的文件等等。
此时我们可以创建一个名为 .gitignore 的文件,列出要忽略的文件模式,Git会根据这些模式规则来判断是否将文件添加到版本控制中。
注意:在windows下可以创建文件名为.gitignore.,保存之后系统会自动重命名为 .gitignore

3.1 格式规范

(1)所有空行或者以注释符号 # 开头的行都会被 Git 忽略
(2)可以使用标准的 glob 模式匹配
(3)匹配模式最后跟斜杠(/)说明要忽略的是目录
(4)要忽略指定模式以外的文件或目录,可以在模式前加上感叹号(!)进行取反

3.2 glob模式

所谓的 glob 模式是指 shell 所使用的简化了的正则表达式,匹配规则如下:
"*":星号匹配零个或多个任意字符
[]:匹配任何一个列在方括号中的字符,如[ab]匹配a或者匹配b
"?":问号匹配一个任意字符
[n-m]:匹配所有在这两个字符范围内的字符,如[0-9]表示匹配所有0到9的数字

匹配示例
logs/: 忽略当前路径下的logs目录,包含logs下的所有子目录和文件
/logs.txt: 忽略根目录下的logs.txt文件
*.class: 忽略所有后缀为.class的文件
!/classes/a.class:不忽略classes目录下的a.class文件
tmp/*.txt: 只忽略tmp目录下的.txt文件
**/foo: 可以忽略/foo, a/foo, a/b/foo等

3.3 案例使用

  1. 在需要创建 .gitignore 文件的文件夹, 右键选择Git Bash 进入命令行,进入项目所在目录。
  2. 输入 touch .gitignore 在文件夹就生成了一个“.gitignore”文件
  3. 然后用编辑器打开这个文件进行编辑就行了。
  4. 然后就写规则来操作要忽略的文件了。

在这里插入图片描述
.gitignore内容
在这里插入图片描述
创建两个文件
在这里插入图片描述
查看状态我们发现testclass.class不在工作区
在这里插入图片描述
提交也不会进入暂存区
在这里插入图片描述
在这里插入图片描述

3.4定义全局的.gitignore

除了可以在项目中定义.gitignore文件外,还可以设置全局的.gitignore文件来管理所有Git项目的行为。
这种方式在不同的项目开发者之间是不共享的,是属于项目之上Git应用级别的行为。
可以在任意目录下创建相应的.gitignore文件,然后再使用以下命令配置Git

git config --global core.excludesfile ~/.gitignore

3.5 .gitignore规则不生效

.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。所以一定要养成在项目开始就创建.gitignore文件的习惯。

3.6 java开发通用模板

#java
*.class#package file
*.war
*.ear
*.zip
*.tar.gz
*.rar
#maven ignore
target/
build/#eclipse ignore
.settings/
.project
.classpatch#Intellij idea
.idea/
/idea/
*.ipr
*.iml
*.iws# temp file
*.log
*.cache
*.diff
*.patch
*.tmp# system ignore
.DS_Store
Thumbs.db

接下来我想看下readme.txt文件到底改了什么内容,如何查看呢?可以使用如下命令:

3.7 diff命令

git diff readme.txt
在这里插入图片描述
diff里面a表示前面那个变量,b表示第二个变量
HEAD commit版本
Index staged版本

  1. 工作目录 vs 暂存区
$ git diff <filename>

意义:查看文件在工作目录与暂存区的差别。如果还没 add 进暂存区,则查看文件自身修改前后的差别。也可查看和另一分支的区别。

$ git diff <branch> <filename>
  1. 暂存区 vs Git仓库
git diff --cached <filename>

意义:表示查看已经 add 进暂存区但是尚未 commit 的内容同最新一次 commit 时的内容的差异。 也可以指定仓库版本:

git diff --cached <commit> <filename>
  1. 工作目录 vs Git仓库
git diff <commit> <filename>

意义:查看工作目录同Git仓库指定 commit 的内容的差异。
<commit>=HEAD 时:查看工作目录同最近一次 commit 的内容的差异。

  1. Git仓库 vs Git仓库
git diff <commit> <commit>

意义:Git仓库任意两次 commit 之间的差别。

以上命令可以不指定 <filename>,则对全部文件操作。
以上命令涉及和 Git仓库 对比的,均可指定 commit 的版本。
HEAD 最近一次 commit
HEAD^ 上次提交
HEAD~100 上100次提交

四 Git分支管理

Git 的默认分支就是 master。你所作的commit会在master分支上自动移动。 在多次提交操作之后,master分支指向最后那个commit object(提交对象链)。
Git 的 “master” 分支不特殊,跟其它分支没有区别。 之所以几乎每一个仓库都有 master 分支,是因为 git init 命令默认创建它。
在这里插入图片描述
但很多时候听别人说master分支,往往有一种 这个分支是稳定、无bug的分支。而develop往往预示这新功能,不稳定的分支。这和分支策略有关,但本质上这两个分支没区别。

4.1 分支创建

通过git branch来查看和创建分支。
创建标签记在HEAD指针所指向的提交点创建tag(就是当前所在分支)

git branch dev

在这里插入图片描述
分支切换到dev

git checkout dev

在这里插入图片描述
创建分支与合并分支同时完成

git checkout -b dev2

在这里插入图片描述
这是我们在dev2分支创建一个文件A.txt并且提交。我们发现在dev2分支可以看到这个文件,当我们切换到master分支的时候无法看到这个文件。
在这里插入图片描述
在这里插入图片描述

4.2 分支删除

  1. 不能删除自己所在的分支
    在这里插入图片描述
    我们可以切换到master删除一个合并后的或者没有发生变化的分支
    在这里插入图片描述
  2. 如果一个分支发生了变化不能删除
    在这里插入图片描述
    我们发现dev2发生了变化,同时没有合并不能删除。如果要强制删除可以
git branch -D dev2

4.3 分支合并

我们继续基于上面的例子,切换到master上做dev2 的合并
在这里插入图片描述
我们发现master分支上也添加了A.txt这个文件

如果修改的是同一个文件也可以做同样的合并,让我们切换到dev2分支修改A.txt中的内容。在A.txt中添加了一行World
在这里插入图片描述
我们切换到master分支的时候发现提示了A.txt的变动。通过合并发现master分支上也合并了dev2修改的内容,合并之后dev2就删除就被允许了。
在这里插入图片描述

4.4 分支本质

master指向的是提交,HEAD是指向当前的分支,当前在哪个分支就指向哪个分支
在这里插入图片描述
第二张图上我们可以看到创建了dev的分支,当我们切换到dev分支的时候HEAD就会指向dev
在这里插入图片描述
当我们进入.git文件夹查看HEAD的内容的时候可以看到,所处分支不同内部的文件指向就不同
master分支
在这里插入图片描述
dev2分支
在这里插入图片描述
git的分支与svn不同,svn是整体拷贝一份分支,git用的是指针。

如果dev发生修改提交,dev的版本就会向后移动
在这里插入图片描述
在master分支上如果合并就会出现下面的图
在这里插入图片描述

4.5 分支的冲突

在这里插入图片描述
我们在dev2分支里面修改A.txt文件添加一行 update by dev2后提交
在这里插入图片描述
我们在master分支里面修改A.txt文件同时添加一行 update by master后提交
在这里插入图片描述
合并时候我们发现出现冲突
在这里插入图片描述

<<<<<<<<<<<HEAD是当前指向的分支所修改
>>>>>>>>>>dev2是dev2分支修改

我们需要手工合并。修改后报了冲突的内容
在这里插入图片描述
我们可以通过图形来查看冲突的提交日志

git log --graph

在这里插入图片描述

五 Git stash

  1. 当正在dev分支上开发某个项目,这时项目中出现一个bug,需要紧急修复,但是正在开发的内容只是完成一半,还不想提交,这时可以用git stash命令将修改的内容保存至堆栈区,然后顺利切换到hotfix分支进行bug修复,修复完成后,再次切回到dev分支,从堆栈中恢复刚刚保存的内容。

  2. 由于疏忽,本应该在dev分支开发的内容,却在master上进行了开发,需要重新切回到dev分支上进行开发,可以用git stash将内容保存至堆栈中,切回到dev分支后,再次恢复内容即可。

总的来说,git stash命令的作用就是将目前还不想提交的但是已经修改的内容进行保存至堆栈中,后续可以在某个分支上恢复出堆栈中的内容。这也就是说,stash中的内容不仅仅可以恢复到原先开发的分支,也可以恢复到其他任意指定的分支上。git stash作用的范围包括工作区和暂存区中的内容,也就是说没有提交的内容都会保存至堆栈中。

案例操作
我们在master分支修改A.txt添加一行
在这里插入图片描述
这时我们要切换dev2分支
在这里插入图片描述
我们发现会提示错误,git建议我们先提交或者stash修改的内容再切换
我们执行

git stash

会先把修改的内容做保存然后我们就可以切换到其他的分支
在这里插入图片描述
列出stash保存的所有修改
我们切换回master分支执行,我们能看到上次保存的操作

git stash list

在这里插入图片描述
我们同样也可以再次修改文件去做stash,这样就会产生2条保存的记录
在这里插入图片描述
我们可以将stash过的修改恢复出来。通过pop取出最近的恢复并且删除stash中的修

git stash pop

在这里插入图片描述
在这里插入图片描述
如果两次pop,由于第一次没有做提交则会报错,所以我们应该把第一次pop的提交,再pop第二次的。
在这里插入图片描述

六 分支管理策略

git 的分支整体预览图如下:
在这里插入图片描述
从上图可以看到主要包含下面几个分支:
master:git默认主分支(这里不作操作)。
stable:稳定分支,替代master,主要用来版本发布。
develop:日常开发分支,该分支正常保存了开发的最新代码。
feature:具体的功能开发分支,只与 develop 分支交互。
release:release 分支可以认为是 stable分支的未测试版。比如说某一期的功能全部开发完成,那么就将 develop 分支合并到 release分支,测试没有问题并且到了发布日期就合并到 stable分支,进行发布。
bugfix:线上 bug 修复分支。

6.1 主分支

因为master分支我们不作操作,所以针对stable和develop这两个主分支来讲解。
stable分支:用来发布,管理着多个稳定的版本。
develop分支:就是我们日常开发的分支。
使用这两个分支就具有了最简单的开发模式:develop 分支用来开发功能,开发完成并且测试没有问题后,则将 develop 分支的代码合并到 stable分支并发布。

在这里插入图片描述

6.2 辅助分支

通过这些分支,我们可以做到:团队成员之间并行开发,增加新功能更加容易,可以同时进行开发和版本发布、线上bug修复等。

6.2.1 Feature分支

feature 分支用来开发具体的功能,一般基于develop分支,最后完成功能后再合并到develop分支。
比如,目前我们针对develop分支来做功能开发,在开发的过程中会有紧急需求需要开发,且在本次版本发布时间之前要能测试完成。我们可以基于之前稳定版本另开一个feature分支来做紧急需求的开发,发布并进行测试,完成之后再合并到develop分支上。
在这里插入图片描述

6.2.2 release分支

release分支作为预发布分支,release 分支从 develop 分支 fork 出来,最终会合并到 develop 分支和 stable 分支,合并到 stable分支上就是可以发布的代码了。
为什么我从develop分支fork出来,还要合并到develop分支中呢?因为我们在release分支上难免会有bug产生,修复bug也是在release分支上,所以必须要合并到develop分支
在这里插入图片描述

6.2.3 bugfix分支

bugfix 分支用来修复线上bug。当线上代码出现 bug 时,我们基于 stable 分支开一个bugfix分支,修复 bug之后再将 bugfix分支合并到stable分支并进行发布,同时develop 分支作为最新最全的代码分支,bugfix分支也需要合并到 develop 分支上去。

七 推送本地仓库到远程

删除之前的仓库中的所有内容,从新建库,同时创建一个A.txt文件。

7.1 修改本地仓库用户名

为了本地演示多个用户操作,我们把仓库local的级别的用户设置一下

$ git config --local user.name '鲁智深'
$ git config --local user.mail 'luzhishen@126.com'

在这里插入图片描述

7.2 Push命令

以github为例,github已创建空仓https://github.com/txjava-teach/txjava-code.git,本地库要上传并与之关联:

git remote add origin https://github.com/txjava-teach/txjava-code.git

添加后,远程库的名字就是origin,这是Git默认的名字,也可以改成别的,但是origin这个名字⼀看就知道是远程库。下一步,就可以把本地库的所有内容推送到远程库上:
在这里插入图片描述
在这里插入图片描述
然后推送本地库的文件。

git push -u origin master

在这里插入图片描述
第⼀次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master 分支关联起来
只要本地作了提交,就可以通过命令:

git push origin master

把本地master分支的最新修改推送至GitHub
查看远程仓库

git remote show

在这里插入图片描述
origin相当于远程仓库的链接别名
查看远程仓库明细

git remote show origin

在这里插入图片描述
上面命令展示了origin的详细信息,
远程拉取的url
push推送的url
头指针指向的master分支,同时远程分支是被追踪的状态
本地master分支被配置成git pull会拉取并且合并远程master
本地master分支配置成git push推送远程master

7.3 远程分支查看

origin master关联的是远程的master分支,用于追踪远程分支的状态
查看远程分支

git branch -a

在这里插入图片描述
我们加上参数v可以查看本地分支和远程分支的最后提交

git branch -av

在这里插入图片描述
在这里插入图片描述
我们修改A.txt文件
在这里插入图片描述
我们通过git status可以看到我们master分支和远程分支origin/master都是最新的。
此时我们提交我们的修改后在查看git status,我们可以发现我们的本地master分支领先了1次提交。
在这里插入图片描述
从分支的详细信息中我们可以看到远程分支的提交版本和master的提交版本不同,本地领先了。
在这里插入图片描述
此刻我们把本次修改推送到远程,远程和本地便保持了版本的同步
在这里插入图片描述
在这里插入图片描述

八Git多人协作

8.1 项目克隆

我们可以把远程项目克隆到本地形成一个本地的仓库

git clone https://github.com/txjava-teach/txjava-code.git

在这里插入图片描述
我们可以发现克隆下来的仓库和远程仓库的名字一致
在这里插入图片描述
进入仓库可以看到.git的配置文件和远程代码
在这里插入图片描述
.git中的配置可以看到目前的分支为master,远程别名是origin,关联合并的是远程分支的master
在这里插入图片描述
注意:我们也可以克隆远程项目自己定义仓库名字

git clone https://github.com/txjava-teach/txjava-code.git testGit2

在这里插入图片描述

8.2 多人协作

8.2.1 创建仓库

创建林冲仓库
克隆远程仓库命名testGit1.
指定本地仓库级别的用户名和邮箱

git config --local user.name '林冲'
git config --local user.email 'linchong@txjava.com'

在这里插入图片描述
在这里插入图片描述

8.2.2 协作处理

在testGit中通过鲁智深添加文件并且推送到远程
在这里插入图片描述
在这里插入图片描述
在testGit1仓库中林冲查看远程状态发现已经过期。

在这里插入图片描述
此时林冲应该从远程仓库来更新拉取
在这里插入图片描述
fast-forward表示不需要手工处理冲突直接合并。
在这里插入图片描述

8.2.3 冲突处理

当两个人修改同一个文件的同一行的时候就会发生冲突
我们使用鲁智深修改B.txt内容: 拓薪教育1
在这里插入图片描述
提交并且推送到远程
在这里插入图片描述
此刻林冲也修改B.txt内容:拓薪教育2
在这里插入图片描述
我们提交并且推送远程的时候发现出现冲突,推送失败
此刻git要求我们先拉取更新
在这里插入图片描述
我提示中我们发现拉取成功,但是自动合并失败。git建议我们修改冲突后提交
在这里插入图片描述
我们可以修改冲突,此时和svn是一样的。我们保留林冲的“拓薪教育2”
在这里插入图片描述
推送到远程
在这里插入图片描述
搞定
在这里插入图片描述

8.3 分支推送协作

创建develop分支
在这里插入图片描述
我们发现git push无法把develop推送到远程。
在这里插入图片描述
执行下面的命令,这就是把本地的分支推送到远程分支。

git push --set-upstream origin develop

在这里插入图片描述
我们可以看到远程分支已经推送。
在这里插入图片描述
同时本地也关联了远程develop分支
在这里插入图片描述
除此之外我们可以使用下面命令完成远程分支推送

git push -u origin 分支名

在这里插入图片描述
我们创建分支,并且把分支推送到远程
在这里插入图片描述
分支查看
在这里插入图片描述

8.4 分支拉取协作

由于鲁智深已经推送,我们使用林冲的账户来拉取,我们可以看到新建立了分支
在这里插入图片描述
但是我们发现有远程分支,但是没有本地的develop分支。
在这里插入图片描述
这时我们可以创建本地的develop分支,此刻我们也可以修改本地分支的名字

git checkout -b develop origin/develop

我们已经创建分支并且切换到develop上,而且该分支和远程分支develop关联
在这里插入图片描述
查看
在这里插入图片描述
我们还可以使用另一种方式本地分支的追踪,但是必须要先git pull

git checkout --track origin/feature

在这里插入图片描述

8.5 远程分支的删除

我们在鲁智深仓库删除Feature分支,删除之后远程的Feature分支关联还在
在这里插入图片描述
我们也可以删除对应的远程分支

git push origin --delete feature

在这里插入图片描述
在这里插入图片描述
当我们通过另一个用户来查看本地对应的远程分支的时候可以看到远程分支的变化。
在这里插入图片描述
查看origin远程对应的分支

git remote prune origin

在这里插入图片描述

九 tag标签远程管理

9.1 标签 tag管理

新建标签,标签有两种:轻量级标签(lightweight) 与带有附注标签(annotated)

创建一个轻量级标签
创建标签记在HEAD指针所指向的提交点创建tag(就是当前所在分支)

git tag v1.0.1

在这里插入图片描述
创建一个带有附注的标签

git tag -a v1.0.2 -m 'release version'

在这里插入图片描述
标签不依赖于分支。

删除标签

git tag -d tag_ name

在这里插入图片描述

9.2 标签推送

我们前面已经介绍过标签的创建
我们创建3个标签
在这里插入图片描述
把多个标签推送到远程

git push origin 标签1 标签2……

在这里插入图片描述
GitHub上可以看到标签已经推送,标签代码可以下载。
在这里插入图片描述
可以把所有标签推送到远程

git push origin --tag

在这里插入图片描述

9.3 标签拉取

git pull

我们通过林冲用户来拉取
在这里插入图片描述

9.4 删除远程标签

git push origin :refs/tags/标签名

在这里插入图片描述
远程标签被删除
在这里插入图片描述
同时也可以

git push origin --delete tag 标签1 标签2…

远程标签删除后本地标签不会消失,我们可以手动删除本地标签
在这里插入图片描述

9.5 标签检出

git checkout -b <branchName> <tagName>

我们创建tx_master_v1.0标签并且推送到远程
然后我们通过此标签来检出分支

git checkout -b myfeature tx_master_v1.0

在这里插入图片描述
但是此分支这是本地分支,我们可以推送到远程
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

十 GitLab

GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务。可通过Web界面进行访问公开的或者私人项目。它拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。团队成员可以利用内置的简单聊天程序(Wall)进行交流。它还提供一个代码片段收集功能可以轻松实现代码复用。

10.1 centos7.x安装gitlab

Gitlab的rpm包集成了它需要的软件,简化了安装步骤,所以直接安装rpm包即可,rpm包的获取从官方网站或者国内镜像源(如:清华https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/)获取,gitlab又分为社区版和企业版(收费),这里部署的是社区版本10.8.4

[root@gitlab ~]# mkdir -p /service/tools[root@gitlab ~]# cd /service/tools/[root@gitlab tools]# yum localinstall -y gitlab-ce-10.8.4-ce.0.el7.x86_64.rpm            #安装下载好的rpm包
或者
[root@gitlab ~]# rpm -ivh https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-10.8.4-ce.0.el7.x86_64.rpm        #执行rpm -ivh 在线安装

在这里插入图片描述
安装成功,但是需要配置,安装完成后出现下面的提示,按照提示修改配置文件中的url地址为本地服务器的地址
在这里插入图片描述

[root@gitlab tools]# vim /etc/gitlab/gitlab.rbexternal_url 'http://192.168.0.108'

在这里插入图片描述

[root@gitlab tools]# gitlab-ctl reconfigure        #重新加载配置[root@gitlab tools]# gitlab-ctl stop        #停止gitlab,进行后面的汉化[root@gitlab tools]# cat /opt/gitlab/embedded/service/gitlab-rails/VERSION10.8.4        #查看版本[root@gitlab tools]# rpm -qa gitlab-cegitlab-ce-10.8.4-ce.0.el7.x86_64        #查看版本[root@gitlab tools]# ls /opt/gitlab/    

在这里插入图片描述

[root@gitlab tools]# ll /var/opt/gitlab                #相关目录

在这里插入图片描述

10.2 汉化

默认的全英文界面对于英文水平低的来讲当然用着很不舒服,于是便需要来一波操作进行汉化,英文好的请自觉忽略

GitLab中文社区的项目,v7-v8.8是由Larry Li发起的"GitLab中文社区版项目"(https://gitlab.com/larryli/gitlab),从v8.9之后由@xhang开始继续汉化项目(https://gitlab.com/xhang/gitlab)

[root@gitlab tools]# pwd/service/tools[root@gitlab tools]# mkdir /backup[root@gitlab tools]# cp /opt/gitlab/embedded/service/gitlab-rails/* /backup    #防止汉化失败,备份原文件[root@gitlab tools]# git clone https://gitlab.com/xhang/gitlab.git        #下载最新的汉化包

汉化包的版本更新速度不得而知,所以尽量不要安装最新版本的gitlab。如果是要下载老版本的汉化包,需要加上老版本的分支,如果想下载10.0.2,可以运行如下语句

[root@gitlab tools]# git clone https://gitlab.com/xhang/gitlab.git -b v10.0.2-zh[root@gitlab tools]# ls        #git下来的文件为gitlabgitlab gitlab-ce-10.8.4-ce.0.el7.x86_64.rpm[root@gitlab tools]# \cp -rf gitlab/* /opt/gitlab/embedded/service/gitlab-rails/    #拷贝文件

检验汉化

[root@gitlab tools]# gitlab-ctl reconfigure            #加载配置(第一次执行此命令会启动,若只启动执行start)

启动时查看控制台输出,需要等待一段时间,无输出后启动完成,执行free -m命令查看到当前的内存使用情况为

[root@gitlab tools]# free -mtotal used free shared buff/cache availableMem: 2993 2123 156 62 713 597Swap: 2047 0 2047[root@gitlab tools]# netstat -lntupActive Internet connections (only servers)Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program nametcp 0 0 127.0.0.1:9100 0.0.0.0:* LISTEN 4319/node_exportertcp 0 0 127.0.0.1:9229 0.0.0.0:* LISTEN 4628/gitlab-workhortcp 0 0 127.0.0.1:9168 0.0.0.0:* LISTEN 4659/rubytcp 0 0 127.0.0.1:8080 0.0.0.0:* LISTEN 4191/unicorn mastertcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 4223/nginx: mastertcp 0 0 127.0.0.1:8082 0.0.0.0:* LISTEN 4196/sidekiq 5.0.5tcp 0 0 127.0.0.1:9236 0.0.0.0:* LISTEN 4642/gitalytcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1439/sshdtcp 0 0 0.0.0.0:8060 0.0.0.0:* LISTEN 4223/nginx: mastertcp 0 0 0.0.0.0:6783 0.0.0.0:* LISTEN 4696/alertmanagertcp 0 0 127.0.0.1:9121 0.0.0.0:* LISTEN 4425/redis_exportertcp 0 0 127.0.0.1:9090 0.0.0.0:* LISTEN 4681/prometheustcp 0 0 127.0.0.1:9187 0.0.0.0:* LISTEN 4710/postgres_exportcp 0 0 127.0.0.1:9093 0.0.0.0:* LISTEN 4696/alertmanagertcp6 0 0 ::1:9168 :::* LISTEN 4659/rubytcp6 0 0 :::22 :::* LISTEN 1439/sshd

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/63027.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从excel数据导入到sqlsever遇到的问题

1、格式问题时间格式&#xff0c;excel中将日期列改为日期未生效&#xff0c;改完后&#xff0c;必须手动单击这个单元格才能生效&#xff0c;那不可能一个一个去双击。解决方案如下 2、导入之后表字段格式问题&#xff0c;数据类型的用navicat导入之后默认是nvarchar类型的&a…

FREERTOS二值信号量实验

代码&#xff1a; 主程序 #include "./SYSTEM/sys/sys.h" #include "./SYSTEM/usart/usart.h" #include "./SYSTEM/delay/delay.h" #include "./BSP/LED/led.h" #include "./BSP/LCD/lcd.h" #include "./BSP/KEY/key…

对于Oracle来说,土地管理是非核心域吗

思雨喵 2022-1-4 14:13 您在课上说&#xff0c;对于土地管理系统来说oracle&#xff0c;arcgis&#xff0c;java是非核心域&#xff0c;因为它们可有可无。我想请教对于oracle来说&#xff0c;土地管理好像也是可有可无&#xff0c;那么土地管理是非核心域吗 UMLChina潘加宇 …

工业齐套管理虚拟现实仿真模拟软件

工业齐套管理虚拟现实仿真模拟软件是与法国最大的汽车制造商合作开发的一款虚拟现实仿真模拟软件&#xff0c;借助身临其境的虚拟现实环境&#xff0c;无需停止生产线&#xff0c;即可模拟仓库和提货区域。 工业齐套管理虚拟现实仿真模拟软件不仅适用于汽车工业&#xff0c;安全…

状态模式的理解和实践

在软件开发中&#xff0c;我们经常遇到需要根据对象的不同状态执行不同行为的情况。如果直接将这些状态判断和行为逻辑写在同一个类中&#xff0c;会导致该类变得臃肿且难以维护。为了解决这个问题&#xff0c;状态模式&#xff08;State Pattern&#xff09;应运而生。状态模式…

【MySQL — 数据库基础】MySQL的安装与配置 & 数据库简单介绍

数据库基础 本节目标 掌握关系型数据库&#xff0c;数据库的作用掌握在Windows和Linux系统下安装MySQL数据库了解客户端工具的基本使用和SQL分类了解MySQL架构和存储引擎 1. 数据库的安装与配置 1.1 确认MYSQL版本 处理无法在 cmd 中使用 mysql 命令的情况&a…

Python从入门到入狱

Python是从入门到入狱&#xff1f;这个充满调侃意味的说法在程序员圈子里流传甚广。表面看&#xff0c;它似乎是在嘲笑这门语言从简单易学到深陷麻烦的巨大反差&#xff0c;实际上却隐藏着很多值得深思的问题。要解读这个话题&#xff0c;得从Python的特点、使用场景以及潜在风…

Linux获取文件属性

目录 stat函数 获取文件属性 获取文件权限 实现“head -n 文件名”命令的功能 编程实现“ls -l 文件名”功能 stat/fstat/lstat的区别&#xff1f; stat函数 int stat(const char *path, struct stat *buf); 功能&#xff1a;获取文件属性 参数&#xff1a; path&…

线程信号量 Linux环境 C语言实现

既可以解决多个同类共享资源的互斥问题&#xff0c;也可以解决简易的同步问题 头文件&#xff1a;#include <semaphore.h> 类型&#xff1a;sem_t 初始化&#xff1a;int sem_init(sem_t *sem, int pshared, unsigned int value); //程序中第一次对指定信号量调用p、v操…

如何使用k8s安装minio呢

话不多说&#xff0c;直接干货。 创建 minio-deployment.yaml apiVersion: apps/v1 kind: Deployment metadata:name: miniolabels:app: minio spec:replicas: 1selector:matchLabels:app: miniotemplate:metadata:labels:app: miniospec:containers:- name: minioimage: reg…

设计模式:17、单件模式(单例模式)

目录 0、定义 1、单件模式的一个角色 2、单件模式的UML类图 3、示例代码 0、定义 保证一个类仅有一个实例&#xff0c;并提供一个访问它的全局访问点。 1、单件模式的一个角色 单件类&#xff08;Singleton&#xff09;:单件类只可以创建出一个实例。 2、单件模式的UML类…

前端常用缓存技术深度剖析

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

任务管理法宝:甘特图详解

在项目管理中&#xff0c;如何清晰、直观地展示项目的进度和任务分配&#xff1f; 甘特图作为一种经典的项目管理工具&#xff0c;提供了有效的解决方案。无论是团队合作还是个人项目管理&#xff0c;甘特图都能帮助你轻松追踪各项任务的进展。今天&#xff0c;我们将详细介绍…

leetcode 62.不同路径

1.题目要求: 2.解题思路: 利用动态规划去解此题 3.题目代码: class Solution { public:int uniquePaths(int m, int n) {//创建dp数组vector<vector<int>> dp;dp.resize(m);for(int i 0;i < dp.size();i){dp[i].resize(n);}//确定dp数组的含义//初始化for(i…

电子应用设计方案-38:智能语音系统方案设计

智能语音系统方案设计 一、引言 智能语音系统作为一种便捷、自然的人机交互方式&#xff0c;正逐渐在各个领域得到广泛应用。本方案旨在设计一个高效、准确、功能丰富的智能语音系统。 二、系统概述 1. 系统目标 - 实现高准确率的语音识别和自然流畅的语音合成。 - 支持多种语…

UE5 C++ 不规则按钮识别,复选框不规则识别 UPIrregularWidgets

插件名称&#xff1a;UPIrregularWidgets 插件包含以下功能 你可以点击任何图片&#xff0c;而不仅限于矩形图片。 UPButton、UPCheckbox 基于原始的 Button、Checkbox 扩展。 复选框增加了不规则图像识别功能&#xff0c;复选框增加了悬停事件。 欢迎来到我的博客 记录学习过…

第32天:安全开发-JavaEE应用Servlet路由技术JDBCMybatis数据库生命周期

时间轴&#xff1a; 32天主要学习内容&#xff1a; 1、JavaEE-HTTP-Servlet技术 2、JavaEE-数据库-JDBC&Mybatis java技术使用历史&#xff08;2023 &#xff09;&#xff1a; JavaEE-HTTP-Servlet&路由&周期: java学习范围&#xff1a; 3、Java: 功能:数据…

基于ZYNQ-7000系列的FPGA学习笔记7——按键控制蜂鸣器(模块化编写)

基于ZYNQ-7000系列的FPGA学习笔记7——按键控制蜂鸣器&#xff08;模块化编写&#xff09; 1. 实验要求2. 功能分析3. 模块设计4. 波形图4.1 按键消抖模块4.2 按键控制蜂鸣器模块 5.代码编写5.1 rtl代码5.2 测试代码 6. 代码仿真7. 添加约束文件并分析综合 在上期的内容中&…

k8s,声明式API对象理解

命令式API 比如&#xff1a; 先kubectl create&#xff0c;再replace的操作&#xff0c;我们称为命令式配置文件操作 kubectl replace的执行过程&#xff0c;是使用新的YAML文件中的API对象&#xff0c;替换原有的API对象&#xff1b;而kubectl apply&#xff0c;则是执行了一…

【金猿CIO展】复旦大学附属中山医院计算机网络中心副主任张俊钦:推进数据安全风险评估,防范化解数据安全风险,筑牢医疗数据安全防线...

‍ 张俊钦 本文由复旦大学附属中山医院计算机网络中心副主任张俊钦撰写并投递参与“数据猿年度金猿策划活动——2024大数据产业年度优秀CIO榜单及奖项”评选。 大数据产业创新服务媒体 ——聚焦数据 改变商业 数据要素时代&#xff0c;医疗数据已成为医院运营与决策的重要基石…