首页 > 其他分享 >git

git

时间:2022-09-28 21:25:39浏览次数:90  
标签:git 仓库 Git 提交 远程 分支


 

logo

Author:Shine

Version:9.0.2

一、引言二、介绍三、Git安装3.1 下载Git3.2 安装3.3 基本配置3.4 测试四、专业名词五、仓库5.1 新建仓库5.2 工作区5.3 暂存区六、基本操作6.1 查看仓库状态6.2 暂存文件6.3 提交文件七、远程仓库7.1 远程仓库工作模式7.2 远程仓库选型7.3 基本操作7.3.1 注册git服务器账号7.3.2 新建远程仓库7.3.3 本地关联远程仓库7.3.4 推送文件到远程仓库7.3.5 克隆远程仓库7.3.6 代码共享八、分支8.1 分支简介8.2 分支操作8.2.1 查看分支8.2.2 创建分支8.2.3 切换分支8.3 新建分支细节8.3.1 新分支初始内容8.3.2 多分支走向8.3.3 分支提交日志8.4 分支合并8.4.1 合并分支介绍8.4.2 合并冲突8.4.2.1 冲突演示8.4.2.2 冲突解决九、Idea关联Git9.1 关联Git9.2 创建仓库9.3 提交-commit9.4 创建分支9.5 上传到远程仓库(push)9.6 复制到本地仓库(clone)9.7 更新本地项目9.8 冲突解决十、多人协同开发10.1 项目管理员( 项目经理 )10.2 开发人员十一、经典问题十二 、命令汇总

一、引言


  • 在单人开发过程中,需要进行版本管理,以利于开发进度的控制。

  • 在多人开发过程中,不仅需要版本管理,还需要进行多人协同控制。

二、介绍


  • Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。

  • Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

  • 官网:https://git-scm.com/

  • svn 集中式版本控制工具

三、Git安装


3.1 下载Git

下载Git https://git-scm.com/downloads

下载git
install1

3.2 安装

重要安装步骤如下:

  1. 在输入框内输入想要安装到的本机路径,也就是实际文件夹位置,或点击“Browse...”选择已经存在的文件夹

01

 

  1. 上图红框内的选项是默认勾选的,建议不要动。additional icons 是决定是否在桌面创建快捷方式的。use a TrueType font 是决定在所有控制台窗口中使用TrueType字体和是否每天检查Git是否有Windows更新的。这些根据自己需要选择. 我的选择如下

02

 

  1. 这个页面是在选择Git文件默认的编辑器,很少用到,所以默认Vim即可.

03

 

  1. 这个界面是调整您的PATH环境。我选择推荐的选项第二种配置

      第一种配置是“仅从Git Bash使用Git”。这是最安全的选择,因为您的PATH根本不会被修改。您只能使用 Git Bash 的 Git 命令行工具。但是这将不能通过第三方软件使用。

      第二种配置是“从命令行以及第三方软件进行Git”。该选项被认为是安全的,因为它仅向PATH添加了一些最小的Git包装器,以避免使用可选的Unix工具造成环境混乱。您将能够从Git Bash,命令提示符和Windows PowerShell以及在PATH中寻找Git的任何第三方软件中使用Git。这也是推荐的选项。

      第三种配置是“从命令提示符使用Git和可选的Unix工具”。警告:这将覆盖Windows工具,如 “ find 和 sort ”。只有在了解其含义后才使用此选项。

04

 

  1. 这个界面是选择HTTPS后端传输。 我使用默认选项第一项

      第一个选项是“使用 OpenSSL 库”。服务器证书将使用ca-bundle.crt文件进行验证。这也是我们常用的选项。

      第二个选项是“使用本地 Windows 安全通道库”。服务器证书将使用Windows证书存储验证。此选项还允许您使用公司的内部根CA证书,例如通过Active Directory Domain Services 。

05

 

  1. 这个界面是配置行尾符号转换。我选择第一种选项

      第一个选项是“签出Windows风格,提交Unix风格的行尾”。签出文本文件时,Git会将LF转换为CRLF。提交文本文件时,CRLF将转换为LF。对于跨平台项目,这是Windows上的推荐设置(“ core.autocrlf”设置为“ true”)

      第二个选项是“按原样签出,提交Unix样式的行尾”。签出文本文件时,Git不会执行任何转换。 提交文本文件时,CRLF将转换为LF。对于跨平台项目,这是Unix上的建议设置(“ core.autocrlf”设置为“ input”)

      第三种选项是“按原样签出,按原样提交”。当签出或提交文本文件时,Git不会执行任何转换。不建议跨平台项目选择此选项(“ core.autocrlf”设置为“ false”)

06

 

  1. 这个界面是配置终端模拟器以与Git Bash一起使用。我选择默认的第一种选项

    第一个选项是“使用MinTTY(MSYS2的默认终端)”。Git Bash将使用MinTTY作为终端模拟器,该模拟器具有可调整大小的窗口,非矩形选择和Unicode字体。Windows控制台程序(例如交互式Python)必须通过“ winpty”启动才能在MinTTY中运行。

      第二个选项是“使用Windows的默认控制台窗口”。Git将使用Windows的默认控制台窗口(“cmd.exe”),该窗口可以与Win32控制台程序(如交互式Python或node.js)一起使用,但默认的回滚非常有限,需要配置为使用unicode 字体以正确显示非ASCII字符,并且在Windows 10之前,其窗口不能自由调整大小,并且只允许矩形文本选择。

07

 

  1. 这个界面是配置配置额外的选项。我勾选默认的第一、第二选项

      第一个选项是“启用文件系统缓存”。文件系统数据将被批量读取并缓存在内存中用于某些操作(“core.fscache”设置为“true”)。 这提供了显著的性能提升。

      第二个选项是“启用Git凭证管理器”。Windows的Git凭证管理器为Windows提供安全的Git凭证存储,最显着的是对Visual Studio Team Services和GitHub的多因素身份验证支持。 (需要.NET Framework v4.5.1或更高版本)。

      第三个选项是“启用符号链接”。启用符号链接(需要SeCreateSymbolicLink权限)。请注意,现有存储库不受此设置的影响。

08

 

3.3 基本配置

  • 安装后,打开cmd ,自报家门

  • 如下信息会在提交代码时要使用,记录在你的每次提交中。以后才知道哪次提交是谁做的。

git config --global user.name "Your Name"  #用户名
git config --global user.email "email@example.com"  #邮箱
# 查看信息
git config -l

3.4 测试

测试:cmd中执行 ,查看git版本

git version  

四、专业名词


  • 版本库:工作区中有一个隐藏目录 .git,这个目录不属于工作区,而是git的 版本库,是git管理的所有内容

  • 暂存区:版本库中包含一个临时区域,保存下一步要提交的文件。

  • 分支:版本库中包含若干分支,提交的文件存储在分支中

架构图
暂存区

五、仓库


对应的就是一个目录,这个目录中的所有文件被git管理起来。

以后会将一个项目的根目录,作为仓库。

仓库中的每个文件的改动 都由git跟踪。

5.1 新建仓库

选择一个目录,执行指令:git init

新建仓库仓库目录
新建仓库 新建仓库2

5.2 工作区

执行git init的目录即为工作区,如上例,D:\repo目录即为工作区【不包含.git目录】

所有文件,都首先在工作区新建,然后可以存入仓库(版本库),进行版本控制。

5.3 暂存区

暂存区也在 .git 目录内,工作区的文件进入仓库时,要先进入暂存区。

六、基本操作


6.1 查看仓库状态

执行 git status 可以看到工作区中文件的状态

未记录过的文件,是未跟踪状态
查看状态1

6.2 暂存文件

执行 git add . 将工作区中的文件全部存入暂存区

将工作区中的文件存入暂存区
暂存文件

6.3 提交文件

执行git commit --- 进入 命令模式 -- 输入命令(i | o | a) -- 编写日志 -- ESC(退出编辑模式) -- 输入命令(:wq)(保存并退出)(:q! 强制退出)

 

执行 git commit -m "这里写提交的描述信息" 作用是将暂存区的文件存入分支,形成一个版本

提交文件,形成一个版本
提交文件

七、远程仓库


第5章中的仓库,其实是本地仓库。

当多人协同开发时,每人都在自己的本地仓库维护版本。

但很重要的一点是,多人之间需要共享代码、合并代码,此时就需要一个远程仓库

7.1 远程仓库工作模式

远程仓库工作模式
远程仓库

clone: 从零到有, 从远程仓库 克隆仓库到本地

pull :拉取,从旧到新, 从远程仓库 拉取 最新代码到本地

push :推送, 把本地仓库代码推送到远程

 

7.2 远程仓库选型

7.3 基本操作

每个开发人员,在面对远程仓库时,会面临的一些基本操作。

7.3.1 注册git服务器账号

码云 注册账号,并登录。

进入公司后,很可能会使用公司自己搭建的git服务器,则账号向领导索要即可

点击注册,完成注册过程 
码云注册  
登录后显示主页
码云登录

 

7.3.2 新建远程仓库
创建远程私有仓库-01
创建远程仓库1
创建远程私有仓库-02
创建远程仓库2
创建远程私有仓库-03
创建远程仓库3
7.3.3 本地关联远程仓库

本文档中选用仓库的 https协议的地址,将此地址关联到本地git中

如此后,本地即可用“origin” 代指远程仓库
关联远程仓库
7.3.4 推送文件到远程仓库

将本地仓库中已经commit的内容push到远程仓库,以共享自己的代码。

push
push到远程
输入凭证,如此码云才能接受此次上传的内容
push到远程_输入凭证

 

7.3.5 克隆远程仓库

如果仓库已经由别人创建完毕,我们需要其中的内容,则可以通过 git clone 将其复制到本地。

新建目录“repo2”,然后在其中执行 git clone
clone远程仓库
远程仓库,复制到本地,并自动初始化为一个本地仓库
clone远程仓库2
7.3.6 代码共享

多人协同开发时,写好代码的git push 上传到远程仓库;需要代码的 git pull 拉取代码即可。

有人再次将本地仓库内容,上传到了远程仓库
pull远程仓库1
重点:此时另一方如果想获得更新,则需要做一次拉取 git pull
pull远程仓库2

 

八、分支


8.1 分支简介

  • 分支,是一个个版本最终存储的位置。

  • 分支,就是一条时间线,每次git commit形成一个个版本,一个个版本依次存储在分支的一个个提交点上。

分支由多个提交点组成,分支上会有一个指针,默认总是指向最新的提交点
分支图例1

8.2 分支操作

8.2.1 查看分支
  • 查看当前仓库的分支 git branch

  • 仓库中默认只有 master 分支

  • 执行git commit时,默认是在master分支上保存版本。

默认只有master分支
查看分支-master
8.2.2 创建分支
  • 在商业项目开发过程中,我们不会轻易的在master分支上做操作。

  • 我们会新建一个开发用的分支,在此分支上做版本的记录。

    当代码确实没有问题时,才会将开发分支上成熟的代码版本添加到master分支上。

  • 保证开发过程中,可以及时记录版本,又保证master分支上每个提交点都是稳健版本。

创建分支
新建分支
8.2.3 切换分支
  • 默认情况下,当前使用的分支是 master分支

  • 可以切换到 dev分支,则后续的git commit 便会在dev分支上新建版本(提交点)

切换分支
切换分支
再次查看分支情况
查看分支

8.3 新建分支细节

新建分支时,新分支,默认有哪些内容?分支中包含了哪些次提交?

8.3.1 新分支初始内容

每个分支都有一个指针,新建一个分支,首先是新建一个指针

而且新分支的指针会和当前分支指向同一个提交点

新分支包含的提交点就是从第一个提交点到分支指针指向的提交点。

每个分支都有一个指针,新建一个分支,首先是新建一个指针
新建分支细节1
8.3.2 多分支走向

在master分支和新分支,分别进行 git addgit commit

分支情况如下图:

master分支未动,在dev分支增加一次commit
新建分支细节2
master分支增加一个commit,dev分支再增加一个commit
新建分支细节3
8.3.3 分支提交日志

查看分支的提交日志,进而看到分支中提交点的详细情况。

提交情况如下
提交日志
查看当前分支的提交日志
提交日志2

恢复到历史某一个时刻

git reset --hard 提交id

 

8.4 分支合并

两个分支内容的合并

git merge 分支a 合并分支a

8.4.1 合并分支介绍

如果分支A当前的修改,是完全基于分支B的修改而来,则B分支合并A分支,就是移动指针即可。

合并前分支状态
新建分支细节2
快速合并效果(master 合并 dev)
快速分支合并
8.4.2 合并冲突

两个分支进行合并,但它们含有对同一个文件的修改,则在合并时出现冲突,git无法决断该保留改文件哪个分支的修改。

8.4.2.1 冲突演示

场景模拟如下:

master分支修改hig.txt文件
冲突1
dev分支修改hig.txt
冲突2

在master分支 合并 dev分支

合并dev分支
冲突3

此时,打开hig.txt 文件:

冲突后,git会将两个分支的内容都展示在文件中
冲突4
8.4.2.2 冲突解决

出现冲突后,如要由两个开发人员当面协商,该如何取舍,为冲突文件定义最终内容。

解决方案:

  1. 保留某一方的,删除另一方的

  2. 保留双方的

  3. 但无论如何,要记得删除 <<<< ==== >>>> 这些

  4. 本质是两人协商为冲突的内容,定制出合理的内容。

根据协商,再次编辑文件
冲突5
提交 再次编辑后的文件
冲突6

九、Idea关联Git


9.1 关联Git

File > Settings 关联过程是自动的

此处关联是Idea可以自动完成的
idea-关联git

9.2 创建仓库

  • 新建项目后,将项目目录创建为git仓库

  • 注意: 要在建仓库前,设置忽略文件 ".gitignore"

    作用:被忽略的文件会被版本记录忽略,版本中不包含它们。

    范围:不需要和其他开发共享的文件,具体见下图。

 

创建仓库前,先添加忽略文件
idea-创建仓库0
将项目目录初始化为一个仓库
idea-创建仓库1
idea-创建仓库2

9.3 提交-commit

创建好仓库后,做第一次提交。

选择提交菜单
idea-commit
选择提交文件,定义提交信息
idea-commit2
之后会有些友好提示,可以忽略,点击“commit”即可
idea-commit3

9.4 创建分支

新建开发分支

点击右下角链接,即可
idea-新建分支
新建分支
idea-新建分支2
查看当前分支
idea-新建分支3

9.5 上传到远程仓库(push)

  • 请首先参照第7章,创建一个远程仓库。

  • 要求是裸库,且建议库名和项目名同名。

选择push菜单
idea-push
定义远程仓库地址
idea-push3
执行,push操作
idea-push4
push成功后 ,弹窗提示
idea-push5

9.6 复制到本地仓库(clone)

如果有建好的远程仓库,比如公司内已经在用的仓库,或者github,码云上的一些公开仓库,

可以将远程仓库的项目复制到本地使用。

点击克隆菜单
idea-clone
输入如远程仓库地址
idea-clone2
打开项目
idea-clone3
打开项目,选项
idea-clone4

9.7 更新本地项目

如果远程仓库有更新,则你的本地项目也需要一起更新。

选择pull菜单
idea-pull1
执行 pull操作
idea-pull2
更新日志显示
idea-pull3

9.8 冲突解决

合并分支时,如果出现冲突,则需要解决冲突。

冲突出现,弹窗中可以选择如下
idea-冲突
也可以直接修改冲突文件,然后commit即可
idea-冲突2

 

十、多人协同开发


多人开发协同,git操作

10.1 项目管理员( 项目经理 )

1> 由管理员负责创建一个远程库,初始的库中什么也没有,为裸库。库的名称建议和项目同名

2> 管理员会在idea中创建一个初始项目,其中包含.gitignore文件。 并在项目根目录下 建立本地库。并建立 dev分支。

3> 管理员将本地库上传到远程库

4> 将其他开发人员拉入远程库的 开发成员列表中 ,使得其他开发人员可以访问该远程库。

流程如下:

点击添加成员
添加开发成员
选择直接添加
添加开发成员2
提交
添加开发成员3
查看已添加的开发成员
添加开发成员4

 

5> master分支设置为 protected分支,只有管理员有权限将代码合并到其中。dev分支设置为 常规分支所有开发人员 都可以其中合并代码

进入分支设置
保护分支1
设置保护分支,让master分支不能被随更改
保护分支2

10.2 开发人员

  • 初始化:在idea中clone 远程库,获得项目。会建立本地库

  • 后续的开发中,都要在dev分支上进行。开发完一个功能并测试通过后就commit 提交到本地的dev分支中,然后 上传(push)到远程dev分支中。

  • 需要更新项目内容时,通过 pull 从远程仓库拉取内容。

  • 注意:多人协同时,每次在 push 到远程库前,都先做一次pull,一来是把远程最新内容合并到本地,二来是核实本地内容是否和远程内容有冲突。

  • 后续的开发,会接到一个个的功能任务,往复操作 2>、3>、4> 而已。

十一、经典问题


在使用https协议做push时,如果曾经使用过码云,但密码有过改动,此时会报错

使用https协议报错
坑1

解决方案: 控制面板 》 凭据管理器 》 删除对应凭证,再次使用时会提示重新输入密码。

删除之前的码云凭证,然后重新push即可
坑2

 

十二 、命令汇总

命令描述
git remote add 标识名(master) 远程地址 本地关联远程仓库
git push 标识名 master 将本地仓库内容上传到远程仓库
git pull 标识名 master 从远程仓库下载内容到本地仓库
git clone 远程地址 将远程仓库复制到本地,并自动形成一个本地仓库
git add . 添加到暂存区
git commit -m "日志内容" 提交到本地仓库
git init 在当前位置创建新的本地仓库
git branch 查看当前分支
git branch 分支名称 创建分支
git checkout 分支名称 切换分支
git merge 分支名称a 在当前分支上将分支名称a合并过来

标签:git,仓库,Git,提交,远程,分支
From: https://www.cnblogs.com/bxmhdh/p/16739588.html

相关文章

  • git命令会将结果输出到单独窗口必须按q才能退出的问题
    前言   最近换了新的笔记本,执行gitbranch命令的时候总是会进入单独的页面,看着像是进入了vim编辑页,需要手动q才能退出。虽然不是啥大问题,但是每次总是需要多出这一......
  • Gitee And GitHub优秀开源资料记录
    分类链接描述数据库:SqlSugarhttps://gitee.com/dotnetchina/SqlSugar开源ORM框架源码(数据库操作)数据库:SqlSugar 从零开始-项目安装-《SqlSugar5.0文......
  • 常用Git命令
    本地修改同步到版本库:gitcommit-a初始化仓库:gitinit克隆仓库:gitclonehttp://切换到dev分支:gitcheckoutdev推送到本地版本库:gitadd*提交到服务端仓库备注“al......
  • Linux下Gitlab服务器(docker安装)
    一、Docker在线安装https://www.cnblogs.com/dabao150114/p/16739213.html二、portainer容器在线安装https://www.cnblogs.com/dabao150114/p/16739217.html三、GitLab......
  • 重温git操作
    1.git常用命令gitconfig--globaluser.name用户名:设置用户签名gitconfig--globaluser.email邮箱:设置用户签名gitinit:初始化本地库gitstatus:查......
  • CentOS git版本控制系统-本地仓库
    git版本控制系统-本地仓库分布式版本控制系统版本控制不管是在企业中,还是我们个人,我们一定都做过版本控制。比如:1.写脚本,一遍一遍的修改2.大学写论文3.写技术文档什......
  • gitlab 服务端 hook, 拦截糟糕的提交到仓库
    点击上方关注我们背景当我们接收一份新的代码,代码拿到手要做的第一件事就是gitlog,看看这份代码的提交记录,最近提交的情况,做了些什么。但往往看到的gitlog杂乱无章,不知......
  • git 修改commit 备注
    1.没有push1.修改最后一次的提交备注gitcommit--amend输入i进行编辑模式,修改好以后esc退出编辑模式:wq保存并退出。 2.修改之前的备注gitrebase-i......
  • 解决GIT [ fatal: Out of memory? mmap failed: No such device ]
    1#git操作不想每次都输密码,出现报错2[root@api~]#sudo-unginxgitconfig--globalcredential.helperstore3error:couldnotlockconfigfile/home/ngi......
  • git命令
    git代码还原开发同事相互协作,共同开发,合并代码后出现冲突,解决冲突,但是解决了几个版本以后还是冲突,并且出现代码缺失问题。开发同事提出还原版本到合并之前。趁机整理下gi......