【实习经历Two:参与开源项目,学习并应用Git】

news2025/3/18 12:10:51

前端参与开源项目中使用过的git

1.参与开源项目(必备技能——git)

参与开源项目首先需要进入自己想参加的项目页面 点击右边的Fork即可复制到自己的仓库

像个人开发时常用的add、commit和push等命令就不过多介绍了,在这里主要是想记录一下自己作为从未参与过开源项目的初学者遇到的一些常用知识点,很感谢本人这次实习的mt老师很有耐心地帮助我解决使用Git过程中遇到的一些问题。

a.如何在commit里加上SOB署名

首先贡献开源项目需要署名,所以需要先配置用户名和邮箱:

git config --global user.name "xxx"
git config --global user.email "<EMAIL>"

如果配置错误,可以使用 --amend --author 修复:

git commit --amend --author="Correct Name <correct.email@example.com>"

使用GBP密钥对提交进行签名:

gpg --full-generate-key #生成主密钥

回车后出现以下内容:

gpg (GnuPG) 2.2.4; Copyright (C) 2017 Free Software Foundation, Inc.
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
 
Please select what kind of key you want:
   (1) RSA and RSA (default)
   (2) DSA and Elgamal
   (3) DSA (sign only)
   (4) RSA (sign only)
Your selection?1 #默认选1,表示加密和签名都使用RSA算法
RSA keys may be between 1024 and 4096 bits long.
What keysize do you want? (3072) #默认选3072,表示密钥长度为3072位,回车即可
Please specify how long the key should be valid.
         0 = key does not expire
      <n>  = key expires in n days
      <n>w = key expires in n weeks
      <n>m = key expires in n months
      <n>y = key expires in n years
Key is valid for? (0) #默认选0,表示密钥永不过期
Is this correct? (y/N) y
GnuPG needs to construct a user ID to identify your key.
 
Real name:#姓名的英文写法
Email address: #邮箱地址
Comment: #comment可以空着
#生成的用户id
You selected this USER-ID:
    "psadmin <psadmin@psadmin.com>"
 
Change (N)ame, (C)omment, (E)mail or (O)kay/(Q)uit? #默认选O,表示确认

接着,系统会弹出一个小框让你设置一个私钥的密码,密码需要输入两次。

最好再生成一张"撤销证书",以备以后密钥作废时,可以请求外部的公钥服务器撤销你的公钥。

如: gpg --gen-revoke 5550D5D614E9CC36F1B731B930B117F460FCAF5F

如果有较高的安全需求(例如在多个设备上使用 GPG 签名功能),建议为签名操作生成一个专门的子密钥。如果只是偶尔使用签名功能,且密钥只用于单一设备,主密钥已经足够

命令显示内容包含的密钥类型用途
gpg -k公钥环中的密钥主公钥 (pub) 和子公钥 (sub)查看本地存储的所有公钥,用于加密或验证签名
gpg -K私钥环中的密钥主私钥 (sec) 和子私钥 (ssb)查看本地存储的所有私钥,用于签名或解密

运行命令 gpg -k 列出刚刚创建的 GPG 密钥的 ID
比如这里的id是5550D5D614E9CC36F1B731B930B117F460FCAF5F

运行下面的命令配置 Git 以使用指定的密钥签名提交,将 <KEY ID> 替换PG 密钥 ID

git config --global user.signingkey <KEY ID>

添加 GPG_TTY 添加到本地系统用户的 Bash 环境变量

[ -f ~/.bashrc ] && echo 'export GPG_TTY=$(tty)' >> ~/.bashrc

手动签名单个 Git 提交,签名时会弹出提示框,询问 GPG 密钥的密码

git commit -S -m "first commit"

一般我们需要写清楚具体commit的内容 推荐使用git commit -s -S,会打开一个文件让我们自行编辑commit提交的内容(标题,内容和Sob)

保存关闭后再git log查看一下就能看到新增的一条提交记录

最后Push到远程分支就ok.
当然如果先提交了,可以使用git commit --amend修改最近一次的提交信息,再push
保留更改并撤回提交:

git reset --soft HEAD~1 #不保留改动用--hard(不推荐)

创建具有签名、验证的子密钥或想了解更多内容可参考https://blog.csdn.net/vic_qxz/article/details/127225478?fromshare=blogdetail&sharetype=blogdetail&sharerId=127225478&sharerefer=PC&sharesource=m0_75134766&sharefrom=from_link

b.其他常用的commit命令
git rebase

1个pr只需要对应1个commit,当我们需要合并多个commit时就要用到rebase里的squash

合并多个commit可参考文章:https://blog.csdn.net/weixin_42392767/article/details/139543446?fromshare=blogdetail&sharetype=blogdetail&sharerId=139543446&sharerefer=PC&sharesource=m0_75134766&sharefrom=from_link

rebase过程中可能会出现冲突 解决完后需要重新add再执行git rebase --continue
终止rebase:git rebase --abort

如果想要修改某个历史commit,也可以使用rebase的interactive模式:

git rebase -i HEAD~n  # n是要回溯的提交数
git cherry-pick

cherry-pick是将某个分支上的某个commit应用到当前分支上

这个主要是我之前犯了一个错误:忘记拉取主仓最新的代码,在旧的分支上进行了开发,导致最后使用git log --graph --oneline时发现节点树已经混乱,所以一定一定,要基于最新的代码开发!!!

解决方式:拉取主仓最新的代码后从主分支再checkout -b 一个新分支出去,然后把在错误分支上开发的代码通过cherry-pick到新分支上再强制把新分支上的代码覆盖推送给错误的分支上。

自动关闭issue

在commit提交记录里添加Resolves #pr号
在pr内容里添加Resolves #issue号

c.其他
pr之间的关联性

有时候一个需求大概率会分批提交多个pr,但是如果前一个pr还没审核通过的情况下怎么办呢?

我的解决方法是不同的pr在不同的分支上进行开发,如完成了a分支上的代码开发后(解决了部分需求),在a的pr还未通过的情况下,从a分支上checkout -b出去一个新的分支b,再在b分支上进行开发,这样b分支就自动和a分支关联上了,logs后也会看到标记。但是force push后标记会丢失,笨方法是每次改了a就checkout -b再做b,聪明点的方法是在b分支上执行rebase操作,将a分支的最新更改应用到b分支上。

(ps:以上仅记录了我在前端实习期间遇到的一些基本的Git操作经验,对于更深入的知识点,建议查阅其他专业文章进行学习)

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

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

相关文章

AD绘图基本操作

一、基本操作 注意&#xff1a;快捷键都要在英文模式下才能生效 1、移动 按住鼠标右键移动 2、切换桌面栅格距离 G 3、英寸和毫米 尺寸切换 Q 4、元件在3D模式下的移动 3D视角鼠标左键只起到选择元器件并移动之的功能&#xff0c; 单纯鼠标右键只能平移桌面 shift鼠…

dfs(十二)21. 合并两个有序链表 递归解决

21. 合并两个有序链表 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例 1&#xff1a; 输入&#xff1a;l1 [1,2,4], l2 [1,3,4] 输出&#xff1a;[1,1,2,3,4,4]示例 2&#xff1a; 输入&#xff1a;l1 [], l2 [] …

51单片机指令系统入门

目录 基本概念讲解 一、机器指令​ 二、汇编指令​ &#xff08;一&#xff09;汇编指令的一般格式 &#xff08;二&#xff09;按字节数分类的指令 三、高级指令 总结​ 基本概念讲解 指令是计算机&#xff08;或单片机&#xff09;中 CPU 能够识别并执行的基本操作命令…

安全无事故连续天数计算,python 时间工具的高效利用

安全天数计算&#xff0c;数据系统时间直取&#xff0c;安全标准高效便捷好用。 笔记模板由python脚本于2025-03-17 23:50:52创建&#xff0c;本篇笔记适合对python时间工具有研究欲的coder翻阅。 【学习的细节是欢悦的历程】 博客的核心价值&#xff1a;在于输出思考与经验&am…

如何玩DeepSeek!15分钟快速创建GIS动态数据可视化仪表盘

DeepSeek最近火遍全球&#xff0c;大家用的都用的不亦乐乎。国外呢&#xff1f;当然也是&#xff0c;最近一上YouTube、X等都是deepseek的推送。 今天介绍一下&#xff0c;我在YouTube上看到的GIS行业与DeepSeek结合的一个案例&#xff1a; 快速轻松构建交互式地图仪表盘&…

课上测试:MIRACL共享库使用测试

MIRACL(MultiprecisionIntegerandRationalArithmeticC/cLibrary)是著名的密码算法库&#xff0c;设法去官网下载安装MIRACL&#xff0c;提交安装过程截图或过程文本&#xff08;3分&#xff09;. 去github官网下载.zip文件 使用如下命令进行解压 unzip -j -aa -L MIRACL-mast…

网络编程知识预备阶段

1. OSI七层模型 OSI&#xff08;Open System Interconnect&#xff09;七层模型是一种将计算机网络通信协议划分为七个不同层次的标准化框架。每一层都负责不同的功能&#xff0c;从物理连接到应用程序的处理。这种模型有助于不同的系统之间进行通信时&#xff0c;更好地理解和…

STM32微控制器_03_GPIO原理与应用

核心内容 STM32 GPIO基本原理&#xff08;熟悉&#xff09;GPIO输出功能HAL库编程实现的应用&#xff08;重点&#xff09;GPIO输入功能HAL库编程实现的应用&#xff08;重点&#xff09; 一.STM32 GPIO基本原理 1.GPIO简介 STM32的GPIO相当于STM32的四肢&#xff0c;一个S…

零拷贝分析

kafka 零拷贝 请求 - 网口 - socket - 用户态 - 内核缓存区 - 内核态&#xff08;磁盘信息&#xff09; 磁盘 - 内核缓存区 - 用户缓存区 - 网络缓存区 零拷贝&#xff08;Zero-Copy&#xff09; 是一种高效的数据传输技术&#xff0c;旨在减少数据在内存中的拷贝次数&#x…

从Instagram到画廊:社交平台如何改变艺术家的展示方式

从Instagram到画廊&#xff1a;社交平台如何改变艺术家的展示方式 在数字时代&#xff0c;艺术家的展示方式正在经历一场革命。社交平台&#xff0c;尤其是Instagram&#xff0c;已经成为艺术家展示作品、与观众互动和建立品牌的重要渠道。本文将探讨社交平台如何改变艺术家的…

✎ 一次有趣的经历

&#x1f4c6;2025年3月17日 | 周一 | ☀️晴 &#x1f4cd;今天路过学院楼7&#xff0c;见到了满园盛开的花&#x1f33a;&#xff0c;心情瞬间明朗&#xff01; &#x1f4cc;希望接下来的日子也能像这些花一样&#xff0c;充满活力&#x1f525;&#xff01; &#x1…

快!快!快!NDPP时延测试数据公布!

在全方位认识NDPP第3期《NDPP在金融场景的应用》中&#xff0c;我们重点介绍了NDPP的典型应用场景行情解码硬件加速和策略计算加速&#xff0c;并帮助某百亿私募用户基于NDPP实现期货业务加速的案例。 近期&#xff0c;中科驭数凭借低时延产品荣获信创“大比武”行业融合赛道三…

激光雷达“开卷”2.0,头部Tier1入局

高阶智驾的普及&#xff0c;正在催生激光雷达市场的巨大潜在增长空间。 本周&#xff0c;汽车激光雷达主力供应商之一的禾赛科技发布财报&#xff0c;去年第四季度激光雷达总交付量为222,054台&#xff0c;同比增长153.1%&#xff0c;超过2023年全年。2024全年激光雷达总交付量…

力扣No.376.摆动序列

题目&#xff1a; 链接&#xff1a; https://leetcode.cn/problems/wiggle-subsequence/description/ 代码&#xff1a; class Solution {public int wiggleMaxLength(int[] nums) {int nnums.length;//状态表示:int[] fnew int[n];int[] gnew int[n];//初始化:for(int i0;i…

C语言中qsort函数的详解,以及模拟

引言 C语言中qsort函数的详解和模拟实现qsort函数&#xff0c;这里为了使用冒泡排序来模拟qsort函数 一、详解qsort函数 在 C 语言中&#xff0c;qsort 函数是一个标准库函数&#xff0c;用于对数组进行快速排序&#xff08;Quick Sort&#xff09;。它位于 <stdlib.h>…

9、讲一讲你理解的虚拟内存【中高频】

计算机早期&#xff0c;CPU 是直接操作 物理内存&#xff08;Physical Memory&#xff09;的&#xff0c;但这会导致 内存空间无法完全隔离&#xff0c;一个程序修改了另一个程序的地址空间&#xff0c;就会导致程序崩溃&#xff1b;同时物理内存大小有限&#xff0c;一旦超出这…

算法刷题整理合集(四)

本篇博客旨在记录自已的算法刷题练习成长&#xff0c;里面注有详细的代码注释以及和个人的思路想法&#xff0c;希望可以给同道之人些许帮助。本人也是算法小白&#xff0c;水平有限&#xff0c;如果文章中有什么错误或遗漏之处&#xff0c;望各位可以在评论区指正出来&#xf…

高数1.5 极限的运算法则

1. 预备知识 2.四则求极限法则 3.复合运算求极限法则

【鸿蒙开发】Hi3861学习笔记- 定时器中断

00. 目录 文章目录 00. 目录01. 概述02. 定时器相关API2.1 hi_timer_create2.2 hi_timer_start2.3 hi_timer_stop2.4 hi_timer_delete 03. 硬件设计04. 软件设计05. 实验现象06. 附录 01. 概述 定时器&#xff0c;顾名思义就是用来计时的&#xff0c;我们常常会设定计时或闹钟…

Power Apps 技术分享:画布应用使用表单控件

前言 表单控件&#xff0c;是画布应用里一个非常好用的控件&#xff0c;我们今天简单介绍下&#xff0c;如何使用这个控件。 正文 1.首先&#xff0c;我们需要有一个数据源&#xff0c;我们这里用上一篇博客新建的数据源&#xff0c;如下图&#xff1a; 2.新建一个页面&#xf…