首页 > 其他分享 >Git使用

Git使用

时间:2022-09-04 22:35:16浏览次数:99  
标签:git -- --- Git master 使用 远程 分支

git命令的使用

#配置git用户信息
$ git config --global user.name "用户名"
$ git config --global user.email [email protected]
$ git init   #将当前目录作为工作区,生成.git目录;.git目录为git仓库的目录
$ git add file1 file2 #同时将多个文件添加到暂存区,已空格分隔
$ git add ./ #将当前目录下所有变动的文件添加到暂存区
$ git status #使用频率很高的一个命令,用于查看当前暂存区的使用情况
$ git commit -m '提交信息' # 将暂存区中的内容提交到本地仓库
$ git clone url #根据url地址的仓库,克隆到本地
$ git log #查看所有的历史提交信息
$ git log -p -2 #完整的显示两条提交的完整信息,包含提交内容对比
$ git remote #查看远程仓库名称
$ git remote -v #查看远程仓库的url路径

 

git log的常用选项

选项说明
-p 按补丁格式显示每个提交引入的差异。
--stat 显示每次提交的文件修改统计信息。
--shortstat 只显示 --stat 中最后的行数修改添加移除统计。
--name-only 仅在提交信息后显示已修改的文件清单。
--name-status 显示新增、修改、删除的文件清单。
--abbrev-commit 仅显示 SHA-1 校验和所有 40 个字符中的前几个字符。
--relative-date 使用较短的相对时间而不是完整格式显示日期(比如“2 weeks ago”)。
--graph 在日志旁以 ASCII 图形显示分支与合并历史。
--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline、short、full、fuller 和 format(用来定义自己的格式)。
--oneline --pretty=oneline --abbrev-commit 合用的简写。

git fetch & pull详解

1、简单概括

先用一张图来理一下git fetchgit pull的概念:

 

可以简单的概括为:

git fetch是将远程主机的最新内容拉到本地,用户在检查了以后决定是否合并到工作本机分支中。

git pull 则是将远程主机的最新内容拉下来后直接合并,即:git pull = git fetch + git merge,这样可能会产生冲突,需要手动解决。

下面我们来详细了解一下git fetchgit pull 的用法。

 

2、分支的概念

在介绍两种方法之前,我们需要先了解一下分支的概念: 分支是用来标记特定代码的提交,每一个分支通过SHA1sum值来标识,所以对分支的操作是轻量级的,你改变的仅仅是SHA1sum值。

如下图所示,当前有2个分支,A,C,E属于master分支,而A,B,D,F属于dev分支。

A----C----E(master)
\
B---D---F(dev)
  • 1

  • 2

  • 3

它们的head指针分别指向E和F,对上述做如下操作:

git checkout master  //选择or切换到master分支
git merge dev       //将dev分支合并到当前分支(master)中
  • 1

  • 2

合并完成后:

A---C---E---G(master)
\         /
B---D---F(dev)
  • 1

  • 2

  • 3

现在ABCDEFG属于master,G是一次合并后的结果,是将E和F的代码合并后的结果,可能会出现冲突。而ABDF依然属于dev分支。可以继续在dev的分支上进行开发:

A---C---E---G---H(master)
\         /
B---D---F---I(dev)
  • 1

  • 2

  • 3

  • 4

分支(branch)的基本操作:

git branch //查看本地所有分支 

git branch -r //查看远程所有分支

git branch -a //查看本地和远程的所有分支

git branch <branchname> //新建分支

git branch -d <branchname> //删除本地分支

git branch -d -r <branchname> //删除远程分支,删除后还需推送到服务器
git push origin:<branchname> //删除后推送至服务器

git branch -m <oldbranch> <newbranch> //重命名本地分支
/**
*重命名远程分支:
*1、删除远程待修改分支
*2、push本地新分支到远程服务器
*/

//git中一些选项解释:

-d
--delete:删除

-D
--delete --force的快捷键

-f
--force:强制

-m
--move:移动或重命名

-M
--move --force的快捷键

-r
--remote:远程

-a
--all:所有

 

3、git fetch 用法

git fetch 命令:

$ git fetch <远程主机名> //这个命令将某个远程主机的更新全部取回本地
  • 1

如果只想取回特定分支的更新,可以指定分支名:

$ git fetch <远程主机名> <分支名> //注意之间有空格
  • 1

最常见的命令如取回origin 主机的master 分支:

$ git fetch origin master
  • 1

取回更新后,会返回一个FETCH_HEAD ,指的是某个branch在服务器上的最新状态,我们可以在本地通过它查看刚取回的更新信息:

$ git log -p FETCH_HEAD
  • 1

如图:

可以看到返回的信息包括更新的文件名,更新的作者和时间,以及更新的代码(19行红色[删除]和绿色[新增]部分)。

我们可以通过这些信息来判断是否产生冲突,以确定是否将更新merge到当前分支。

 

4、git pull 用法

前面提到,git pull 的过程可以理解为:

git fetch origin master //从远程主机的master分支拉取最新内容 
git merge FETCH_HEAD //将拉取下来的最新内容合并到当前所在的分支中
  • 1

  • 2

即将远程主机的某个分支的更新取回,并与本地指定的分支合并,完整格式可表示为:

$ git pull <远程主机名> <远程分支名>:<本地分支名>
  • 1

如果远程分支是与当前分支合并,则冒号后面的部分可以省略:

$ git pull origin next

5、gitignore文件

.gitignore文件通常位于git仓库同级别的目录中。.gitignore文件用于根据指定的模式忽略文件或目录。 比如,java文件编译后缠身的class文件是不需要提交的。 IDEA配置文件.iml及目录.idea是不需要提交的。

# 忽略任何已class结尾的文件
*.class

# 忽略.idead目录及其子目录中的文件
.idea/

6、推送本地仓库更新到远程仓库

将本地仓库中的更新推送到远程仓库中的master分支

# git 指令 远程仓库别名 仓库的分支
git push orgin master
 

标签:git,--,---,Git,master,使用,远程,分支
From: https://www.cnblogs.com/huang2979127746/p/16656355.html

相关文章

  • dependencyManagement正确使用方法
    dependencyManagement正确使用方法dependencyManagement正确使用方法一、介绍Maven中的dependencyManagement元素提供了一种管理依赖版本号的方式。在dependencyMan......
  • git tag
    aliases:[git标签]tags:[git,blog]link:官方文档date:2022-09-04简介gittag用于git标签的相关操作。具体详情可查看文首link的官方文档。常用命令参数查看......
  • 使用CSS3快速实现毛玻璃效果
    使用CSS3实现毛玻璃效果并没有想象中那么难,我们只需要了解一个属性:backdrop-filter:blur(5px);在使用该属性之前我们先要区分backdrop-filter与filter的区别。filter......
  • @FeignClient 的使用
     ​ 添加依赖  <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency>......
  • npm太慢, 淘宝npm镜像使用方法
    淘宝npm地址:http://npm.taobao.org/如何使用有很多方法来配置npm的registry地址,下面根据不同情境列出几种比较常用的方法。以淘宝npm镜像举例:1.临时使用npm--reg......
  • 如何使用 ABAP 代码解析 XML 文件
    正如本教程的开篇介绍文章SAPOData开发教程-从入门到提高(包含SEGW,RAP和CDP)所提到的,SAPOData服务开发,从实现技术上来说,可以分为三大类。因此本教程也分为三大......
  • SAP UI5 应用中的 sap.ui.require 使用场景
    下图是笔者SAPUI5开发教程中使用到的一段代码:varmPath=sap.ui.require.toUrl('sap/ui5/walkthrough')+"/";console.log('Jerry:',mPath);本文介绍sap.ui.r......
  • lightdb使用一条sql实现高性能事务一致性归历史
    相比insertselect,delete,如下:--lightdb专有oracle匿名块写法BEGINTRANSACTIONISOLATIONLEVELREPEATABLEREAD;insertintoxxselectxxfromyywhereid<xxx;......
  • git ignore忽略规则
    aliases:[gitignore]tags:[git,blog]link:date:2022-09-04目录aliases:[gitignore]tags:[git,blog]Git忽略文件提交的方法Git忽略规则Git忽略规则优先级Gi......
  • Git和gitee的使用(二、入门篇)
    一、准备工作Git的下载以及gitee的注册。Git下载链接:https://git-scm.com/downloads注:按照默认选项进行安装就ok。gitee官网:https://gitee.com/注:按照提示进行注册。......