Git GitLab 使用及规范
Git 基本操作
Git安装配置及基本使用
- 从官网下载安装包,手动完成安装。
- 打开
Git Bash
命令行工具,执行命令ssh-keygen -t rsa -C Email-Addresss
生成一个密钥对。 - 登录到GitLab,点击右上角你的用户头像,点击
Edit Profile settings
,点击SSH Keys
,点击Add SSH Key
,填写Title
栏,复制用户目录下.ssh/id_rsa.pub
文件的内容到Key
,点击Add Key
。 - 点击已有的
project
,点击SSH
后复制SSH
边上栏里的地址。 - 打开
Git Bash
命令行工具,切换到一个合适的目录,使用命令git clone '刚才复制的URL'
克隆创建的仓库。 - 进入目录
cd 仓库名
,执行命令git config --global user.email your-email
,设置你的邮箱git config --global user.name your-name
,设置你的姓名。 - 执行命令:
echo "# Description" > README.md
,添加一个文件git status
,查看当前状态,发现有未跟踪文件git add .
,当前目录所有文件添加到暂存区git diff
,比较当前工作区和暂存区有何不同git status
,查看当前状态,发现有文件未提交git commit -m "
注释"
,把暂存区内容提交到本地仓库git push -u origin master
,把本地仓库的提交推送到远程仓库git log
,查看提交日志 - 模拟远程更新
登录到GitLab
,点击Files
标签,点击README.md
文件,点击Edit
按钮修改文件内容,添加新行:"* 远程修改文件记录",可以点击Preview
预览,也可以填写注释后直接保存。 - 执行命令:
git pull
,拉取远程仓库的更新提交,并做自动合并,可能会出现冲突git fetch
,获得远程仓库的更新提交,不做自动合并,需要手动合并git merge origin/master
,把远程更新提交手动合并到本地master分支 - 配置命令别名
git config --global alias.co checkout
,配置检出命令别名git config --global alias.br branch
,配置分支命令别名git config --global alias.ci commit
,配置提交命令别名git config --global alias.st status
,配置当前状态命令别名git config --global alias.df diff
,配置比较命令别名git config --global alias.pl pull
,配置拉取命令别名git config --global alias.pu push
,配置推送命令别名git config --global alias.mr merge
配置合并命令别名git config --list
,查看配置列表git config --global credential.helper store
,配置记住密码,以HTTPS使用时 - 其它命令
git clean -f
,清空未跟踪文件git checkout .
,清空工作区改动git checkout some-branch-name file-name.js
,检出指定分支的指定文件git checkout {{some-commit-hash}} file-name.js
,检出指定提交的指定文件 - 其它
Git管理大项目一段时间后会比较慢,可以使用git gc
命令清理一下Git不管理空目录,如果本地有空目录,则始终不会提交到仓库中Git会根据文件的相似性自动识别重命令名操作,底层其实也是先delete后add可在.git同级目录添加.gitignore文件,文件中可写入忽略文件信息,查看状态和提交时均会自动忽略1.7版好像支持了像svn那样只检出部分目录的功能,详细请移步官网文档
Git本地分支管理
- 分支的创建、合并、删除、比较
git branch
,显示所有分支git branch b1
,从当前分支创建一个叫b1的分支git checkout b1
,切换到b1分支git checkout -b b1
,相当于以上两条命令的组合git checkout master
,切换到master主分支git merge b1
,把b1分支的代码合并到master上git branch -d b1
,删除b1分支,不能在被删除分支上执行git diff branch-1 branch-2
,比较两个分支的不同git diff --name-only branch-1 branch-2
,只显示两分支不同的文件的名称git diff some-branch some-filename.js
,比较当前分支与另一分支指定文件
Git远程分支管理
- 远程分支的创建、合并、删除
git push origin dev
,将本地分支dev推送到origin远程仓库git pull origin dev
,拉取远程仓库origin的dev分支并自动合并git push orgin :dev
,删除远程仓库origin上的远程分支git push origin --delete dev
,7版之后可以使用这个命令。git remote prune origin
,清理本地的跟踪分支,可加--dry-run参数假执行一下git pull --rebase
,以变基的形式拉取更新
Tips : tag的远程管理类似远程分支管理
Git Tag标签管理
- 标签的创建、删除
git tag t1
,从当前分支创建一个名为t1的标签git tag -m '
注释' t1
,创建一个带有注释的标签git tag -d t1
,删除名为t1的标签
Git Log日志
git log
,查看历史日志git log --graph
,以基于文本的图形显示合并轨迹git log --pretty=oneline
,一行显示日志简要信息git log --pretty=format:"%h - %an, %ar : %s"
,以指定格式查看日志,format参数请移步官方手册git log --pretty="%h - %s" --author=gitster --since="2008-10-01" --before="2008-11-01" --no-merges
,以指定格式显示指定日期区间和指定提交者的日志,不含合并提交git log -p -2 --stat
,-p显示文件差异,-2显示最近两次提交,--stat显示修改行数统计信息git log -p filename
,查看文件的详细变更,包括文件的实际修改内容git log -L 1,1:some-file.txt
,查看文件中指定位置的变更git log --no-merges master..
,查看尚未合并到master分支的变更
其它高级命令
git show --no-merges master..
,功能同上git show some-branch:some-file.js
,查看其它分支的文件,无需切换分支
GitLib权限管理
GitLib有五种身份权限,分别是:
Owner 项目所有者,拥有所有的操作权限
Master 项目的管理者,除更改、删除项目元信息外其它操作均可
Developer 项目的开发人员,做一些开发工作,对受保护内容无权限
Reporter 项目的报告者,只有项目的读权限,可以创建代码片断
Guest 项目的游客,只能提交问题和评论内容
具体参见GitLab权限,为项目添加成员时可指定成员的身份权限。
命名规则
- 每次提交必须写明注释,如果是修复Bug,请加上Bug号创建特性分支,名称要以
f-
开头,加上特性 - 创建发布分支,名称要以
r-
开头,加上预发布版本号 - 创建Bug修复分支,名称要以
b-
开头,加上Bug号创建标签,名称要以t-
开头,加上发布版本号 - 合并分支时必须使用
--no-ff
参数(禁止以快进方式合并),以保留合并历史轨迹
分支模型
整体流程图:
主要分支(保护分支)
- master 主分支,稳定代码,为生产环境做准备的
- develop 开发分支,为开发服务分支关系类似下图:
辅助分支
特性分支
从develop分支创建,用于特性开发,完成后要合并回develop分支。
操作过程:
git checkout -b newfeature develop
,从develop分支创建newfeature特性分支
git checkout develop
,开发完成后,需要合并回develop分支,先切换到develop分支
git merge --no-ff newfeature
,合并回develop分支,必须加--no-ff参数
git branch -d newfeature
,删除特性分支
git push origin develop
,把合并后的develop分支推送到远程仓库分支关系类似下图:
发布分支
从develop分支创建,用于预发布版本,允许小bug修复,完成后要合并回develop和master。
操作过程:git checkout -b release-1.2 develop
,创建一个发布分支git checkout master
,切换到master分支,准备合并git merge --no-ff release-1.2
,把release-1.2分支合并到master分支git tag 1.2
,从master分支打一个标签git checkout develop
,切换到develop分支,准备合并git merge --no-ff release-1.2
,把release-1.2分支合并到develop分支git branch -d release-1.2
,删除这个发布分支
修复分支
从master分支创建,用于生产环境上的Bug修复,完成后要合并回develop和master。
操作过程:
git checkout -b hotfix-1.2.1 master
,从master分支创建一个Bug修复分支
git checkout master
,切换到master分支,准备合并
git merge --no-ff hotfix-1.2.1
,合并到master分支git tag 1.2.1,为master分支创建一个标签
git checkout develop
,切换到develop分支,准备合并
git merge --no-ff hotfix-1.2.1
,合并到develop分支
git branch -d hotfix-1.2.1
,删除hotfix-1.2.1分支
相关文章:

Git GitLab 使用及规范
Git 基本操作 Git安装配置及基本使用 从官网下载安装包,手动完成安装。打开Git Bash命令行工具,执行命令ssh-keygen -t rsa -C Email-Addresss生成一个密钥对。登录到GitLab,点击右上角你的用户头像,点击Edit Profile settings&…...

【SpringCloud——Sentinel】
一、什么是雪崩? 微服务调用链路中的某个服务发生故障,引起整个链路中的所有微服务都不可用,这就是雪崩。 二、解决雪崩问题的常见措施 1、超时处理 设定超时时间,请求超过一定时间没有响应就返回错误信息,不会无休…...

面试专题:计算机网络常见面试点总结
socket、tcp、udp、http 的认识及区别 socket、tcp、udp、http 的认识及区别 一、先来一个讲TCP、UDP和HTTP关系的 1、TCP/IP是个协议组,可分为三个层次:网络层、传输层和应用层。 在网络层有IP协议、ICMP协议、ARP协议、RARP协议和BOOTP协议。 在传…...

PageHelper失效问题
问题出现记录: 修改代码后,出现分页失效问题,原本的代码再设置了 PageHelper.startPage(pageNum, pageSize);后只有一个mysql查询,我在原本的业务查询前,新增了其他的Mysql查询,导致原需要分页的查询失效 …...

Linux常用命令——grep命令
在线Linux命令查询工具 grep 强大的文本搜索工具 补充说明 grep(global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本&…...

学校热水供应系统方案
学校热水供应系统是现代化校园建设的重要组成部分。一套高效、可靠、安全、环保的热水供应系统,不仅能够满足学生、教职工的日常生活需求,也能提高学校形象和竞争力。 在设计学校热水供应系统方案时,需要考虑以下几个方面: 一、热…...

chatgpt赋能python:Python怎么写绝对值
Python怎么写绝对值 在Python编程语言中,有很多常用函数。其中包括求绝对值的函数。在这篇文章中,我们将介绍如何在Python中使用绝对值函数,并提供一些示例。 什么是绝对值函数? 绝对值函数是一个数学中常用的函数,…...

研发工程师玩转Kubernetes——Node亲和性requiredDuringSchedulingIgnoredDuringExecution几种边界实验
在《研发工程师玩转Kubernetes——使用Node特性定向调度Pod》中,我们提到requiredDuringSchedulingIgnoredDuringExecution只有在规则被满足的时候才能执行调度。本节我们将测试几种边界情况,看看Kubernetes的行为。 没有满足的条件 假设我们测试的Nod…...

OpenCV中的图像处理3.9(六)轮廓线特征与属性
目录 3.9 OpenCV中的轮廓线3.9.1 轮廓线:入门目标什么是轮廓线?如何绘制轮廓线?轮廓线逼近法 3.9.2 轮廓线的特征1. 矩2. 轮廓线面积3. 轮廓线周长4. 轮廓逼近5. 凸面体6. 检查凸性7. 边界矩形8. 最小包围圈9. 拟合椭圆10. 拟合直线 3.9.3 轮…...

burpsuite+xray实现联动测试(手动分析和自动化测试同时进行)
目的:安全测试过程中手动分析测试与xray自动化扫描测试结合,这样可以从多层保障安全测试的分析,针对平台业务接口量大的安全测试是十分有用的,可以实现双向测试同时开始。 xray简介 xray 是一款功能强大的安全评估工具ÿ…...

2023年专业连锁行业研究报告
第一章 行业概况 专业连锁行业是指以连锁经营模式运营的公司,其主要业务涵盖零售、餐饮、酒店、医疗、教育等领域。这些公司通过规模化、标准化的经营模式和供应链管理,提供专业化、高质量的产品和服务。专业连锁行业在全球范围内蓬勃发展,并…...

Mysql数据库(六):基本的SELECT语句
基本的SELECT语句 前言一、SELECT...二、SELECT ... FROM三、列的别名四、去除重复行五、空值参与运算六、着重号七、查询常数八、显示表结构九、过滤数据 前言 本博主将用CSDN记录软件开发求学之路上亲身所得与所学的心得与知识,有兴趣的小伙伴可以关注博主&#…...

在CentOS7环境中,实现使用openresty配置文件,达到jwt指定用户userid不能访问的效果
#在CentOS7环境中,实现使用openresty配置文件,达到jwt指定用户userid不能访问的效果。 首先,你需要安装 OpenResty 和 JWT 组件: 安装 OpenResty 参考 OpenResty 的官方安装文档,在终端执行如下命令: $…...

SpringBoot 源码分析初始化应用上下文(1)-createApplicationContext
前言:springBoot的版本是 2.2.4.RELEASE 一、入口 /*** Run the Spring application, creating and refreshing a new* {link ApplicationContext}.* param args the application arguments (usually passed from a Java main method)* return a running {link A…...

STM32队列
目录 什么是队列? 队列特点 1. 数据入队出队方式 2. 数据传递方式 3. 多任务访问 4. 出队、入队阻塞 队列相关 API 函数 1. 创建队列 参数: 2. 写队列 参数: 返回值: 3. 读队列 参数: 返回值…...

探索Beyond Compare:让文件比较和管理变得简单高效
在这个信息爆炸时代,我们的日常生活和工作中需要处理大量的数据和文档。在这个过程中,有时候我们会面临找出不同文件之间的差异、合并重复内容等需求。那么,有没有一款软件可以帮助我们轻松地完成这些任务呢?答案当然是肯定的&…...

动态网站Servelt基础
文章目录 一、Servlet基础(一)Servlet概述1、Servlet是什么2、Servlet容器3、Servlet应用程序的体系结构 (二)Servlet的特点1、功能强大2、可移植3、性能高效4、安全性高5、可扩展 (三)Servlet接口1、Servl…...

Docker 网络
Docker 网络实现原理 Docker使用Linux桥接,在宿主机虚拟一个Docker容器网桥(docker0),Docker启动一个容器时会根据Docker网桥的网段分配给容器一个IP地址,称为Container-IP,同时Docker网桥是每个容器的默认网关。因为在同一宿主机…...

Tomcat的优化
Tomcat的优化 一、Tomcat 优化Tomcat 配置文件参数优化 二、系统内核优化三、Tomcat 配置 JVM 参数:参数含义 一、Tomcat 优化 Tomcat默认安装下的缺省配置并不适合生产环境,它可能会频繁出现假死现象需要重启,只有通过不断压测优化才能让它…...

一个问题来对比文心一言和chatgpt
问题: 请注意, 孩子不会说话,他无法用语言来回复妈妈的问题, 请生成以下剧本:一个妈妈和一岁不会说话的婴儿的日常vlog的剧本 文心一言 场景一:早晨 (妈妈和孩子在客厅里醒来) 妈妈&…...

防雪崩利器之Hystrix
Hystrix作为一个容错组件,本文从它的作用、熔断设计、工作流程和应用方面一一道来,帮助大家了解如何使用。 1、什么是灾难性雪崩效应 要讲Hystrix,我们就要讲一种场景,在微服务架构中,如果底层服务出现故障࿰…...

机器学习复习(上)
严正声明:本文的答案是ChatGPT的回答,仅供参考,不代表就是正确答案!!! 1.解释什么是过拟合和欠拟合,如何降低过拟合? 过拟合(overfitting)指的是一个模型在训练数据上表…...

node笔记_express结合formidable实现前后端的文件上传
文章目录 ⭐前言⭐安装http请求的文件解析依赖库💖 安装 formidable💖 node formidable接受formData上传参数 ⭐上传的页面搭建💖 vue2 element upload💖 node 渲染 上传文件 ⭐后端生成api上传文件到指定目录💖完整的…...

CKA 09_Kubernetes工作负载与调度 资源调度 三类QoS request 资源需求 limit 资源限额
文章目录 1. 资源调度1.1 准备工作1.2 为什么需要 request 和 limit1.3 内存限制1.3.1 Brustable1.3.2 Guaranteed1.3.3 BestEffort1.3.4 当容器申请的资源超出 limit 和 request 1.4 CPU限制 1. 资源调度 1.1 准备工作 Kubernetes 采用 request 和 limit 两种限制类型来对资源…...

【pytorch】维度变换
【pytorch】维度变换 View操作unSqueeze操作图片处理的一个案例squeeze 维度删减操作维度扩展-expand维度扩展-repeat矩阵的转置操作-transpose View操作 将一个四维的张量(b x c x h x w)转换成一个二维的张量 对于四张图片 将每一张图像用一行向量进…...

vue3中的nextTick()
目录 nextTick() 方法用法回调函数方式使用await方式使用 实现原理使用nextTick() 方法时的注意事项 nextTick() 方法 nextTick() 方法是一个非常强大的工具,是一个等待下一次 DOM 更新刷新的工具方法。用于将一个函数以异步的方式推迟到下一个 DOM 更新周期执行。…...

高效学习传感器|霍尔式传感器
01、霍尔式传感器的工作原理 1●霍尔效应 霍尔式传感器的物理基础是霍尔效应。如图1所示,在一块长度为l、宽度为b、厚度为d的长方体导电板上,左、右、前、后侧面都安装上电极。在长度方向上通入电流I,在厚度方向施加磁感应强度为B的磁场。 ■…...

2023年前端面试高频考点HTML5+CSS3
目录 浏览器的渲染过程⭐⭐⭐ CSS 、JS 阻塞 DOM 解析和渲染 回流(重排)和重绘⭐⭐ 选择器 ID选择器、类选择器、标签选择器(按优先级高到低排序)⭐⭐ 特殊符号选择器(>,,~,空格࿰…...

企业开源测试项目实战(附全套实战项目教程+视频+源码)
接口测试项目 1. No matching distribution found for itypes1.1.0 Could not find a version that satisfies the requirement itypes1.1.0 (from -r requirements.txt (line 8)) (from versions: ) No matching distribution found for itypes1.1.0 (from -r requirements.…...

信创办公–基于WPS的EXCEL最佳实践系列 (创建表格)
信创办公–基于WPS的EXCEL最佳实践系列 (创建表格) 目录 应用背景操作步骤1、新建空白工作簿并命名为“奖牌榜”2、使用模板新建工作簿3、新增一张工作表,并将工作簿的标签更改为红色4、复制与隐藏工作表5、添加工作簿属性值6、更改工作簿主题…...