Git使用—把当前仓库的一个分支push到另一个仓库的指定分支、基于当前仓库创建另一个仓库的分支并推送到对应仓库(mit6828)
把学习过程中遇到的Git问题汇总如下(后续学习遇到问题会及时更新此专栏):
Git原理及常用命令小结——实用版(ing......)、Git设置用户名邮箱-CSDN博客
解决git每次push代码到github都需要输入用户名以及密码-CSDN博客
在VScode中使用Git将本地已有文件夹提交到Github仓库以便于使用版本控制进行项目开发-CSDN博客
Git使用—把当前仓库的一个分支push到另一个仓库的指定分支、基于当前仓库创建另一个仓库的分支并推送到对应仓库(mit6828)-CSDN博客
目录
背景提示
将当前仓库的一个分支push到另一个仓库的指定分支
直接基于仓库rep1中的某个分支创建新的分支并将其推送到目标仓库rep2
补充
参考链接
背景提示
最近打算做一下mit6.828的项目,这个仓库使用问题困扰了自己一段时间,由于6828官方提供的代码有很多分支,克隆下来后如果不解除和原有仓库的关联,可以正常使用,但自己修改代码无法提交,并且不能使用自己的仓库。我希望的是将克隆下来的代码,作为自己的一个仓库,推送到自己Github网站,随后基于Git进行代码分支管理、开发。问题:将克隆的代码和官方仓库解除关联:
git remote rm origin
执行此操作后本地代码显示没有任何分支,无法切换到对应目录,无法进行后续操作,自己探索,一下。需要实现的功能是创建一个自己的仓库,当需要使用到对应分支时,将官方仓库对应分支拷贝到自己仓库对应分支。
将当前仓库的一个分支push到另一个仓库的指定分支
下面内容转载自:GIT操作:把当前仓库的一个分支push到另一个仓库的指定分支_gitpush到指定branch-CSDN博客
有时候我们想把当前仓库A的一个指定分支1 推给 另一个仓库B的另一个指定分支2,
可以通过2个主要命令git remote xxx 和 git push newOrigin 当前分支:目标分支 完成。
示例
假设有2个仓库rep1和rep2
rep1:当前仓库 rep2:目标仓库
我们想把当前仓库[rep1]的指定分支[branch1]
推给
另一个仓库[rep2]的指定分支[branch2]
具体步骤如下:
1.在当前仓库操作:更新代码库
git pull
2.查看当前仓库origin只有一个,接下来我们要add另一个仓库的origin
git remote
or
git remote -v(可以看到origin的url)
3.newOrigin:远程仓库名称,可以随便起个方便记忆的,目的是在本地添加一个新的远程链接
git remote add newOrigin mastereg:git remote add rep2 branch2
or
git remote add rep2 master
rep2后面是rep2的一个分支,可以指定为master或你要push的目标分支,都可以。执行完命令后可以再次通过git remote or git remote -v查看现在有几个origin,大家可以自行试一试。
4.为新加的仓库设置上目标仓库的url地址(以下以gitee为例)
git remote set-url rep2 https://gitee.com/greatoak/rep2.git
5.在A的本地仓库进行git push
git checkout 本地分支名
git push <远程主机名> <本地分支名>:<远程分支名>eg:git checkout branch1
git push newOrigin branch1:branch2
newOrigin是你想push上哪个远程库,branch1是你想push的那个分支,branch2是push到远程的那个分支。
注意,push前先切换到要push的当前分支上,然后再push。
使用上述命令完成操作后,在仓库rep2拉取创建的推送的分支的最新代码时,会报错:git pull "fatal: 拒绝合并无关的历史"
查了一下这个原因参考:
- 当你执行
git pull并遇到错误 "fatal: 拒绝合并无关的历史" 时,这是因为本地分支和远程分支之间的提交历史并不相关(即它们没有共同的祖先提交)。这种情况通常发生在以下几种场景:
- 你初始化了一个新的本地仓库,然后试图从一个远程仓库中拉取代码。本地仓库和远程仓库之间没有任何共同的提交历史。
- 远程仓库和本地仓库是由不同的历史创建的,比如远程仓库是一个独立创建的项目,而你的本地仓库是从零开始的
在pull命令后添加 --allow-unrelated-histories参数解决:
git pull origin feat/util --allow-unrelated-histories
直接基于仓库rep1中的某个分支创建新的分支并将其推送到目标仓库rep2
通过以上操作能够实现自己想要的效果,但又思考了一下,如果我每开发一个对应的分支,都需要关联新的分支到源仓库rep1,随后从源仓库rep1将新的分支推送到目标分支岂不是太麻烦了。
直接在关联了目标仓库Git的代码中,基于想要的分支创建新的分支,并将其提交到目标仓库中。实现方式参考乳如下:
1、查看源仓库和目标仓库
wt@wt:~/Backend/mit6828/codes/xv6-labs-2020$ git remote -v
origin git://g.csail.mit.edu/xv6-labs-2020 (fetch)
origin git://g.csail.mit.edu/xv6-labs-2020 (push)
wt_rep git@github.com:Wwt15537588047/mit6828.git (fetch)
wt_rep git@github.com:Wwt15537588047/mit6828.git (push)
上述仓库origin是mit6.828官方仓库,wt_rep仓库是基于第一种实现方式关联的目标仓库。
2、查看远程源仓库和目标仓库的分支:
git branch -a
3、切换到对应分支:
git checkout origin/lazy ;源仓库的对应分支。
4、 基于源仓库的某个分支创建新的分支:
git checkout -b new-branch
5、提交本地修改:
git add . 和 git commit -m "new-branch"
6、将新分支推送到目标仓库(我这里是wt_rep):
git push wt_rep new-branch。
7、设置跟踪分支:(这一步我直接跳过了)
git push --set-upstream wt_rep new-branch
以上操作完成后基本实现了基于源仓库rep1的某个分支创建新分支并将新分支推送到目标仓库rep2。此时使用命令git branch --remote从目标仓库拉取所有远程分支并不会出现刚刚新创建的分支。
按照以下命令从配置的远程仓库拉取所有的分支:(前两条命令只需要执行一条即可)
git fetch origin #从配置的远程仓库origin拉取所有分支
git fetch --all #从配置的所有远程仓库拉取分支
git branch -a #获取所有远程仓库和本地仓库的分支的信息
补充
git remote -v #获取所有远程仓库的信息
git branch #获取所有本地分支
git branch -r #获取所有远程分支
git branch -a #获取所有远程分支和本地分支
git fetch --all #当维护多个远程仓库时,并且希望获取所有远程的更新时使用
git fetch origin #仅仅维护一个默认仓库origin,并希望获取origin仓库的更新时使用
git remote prunge origin #清除本地缓存并重新获取远程分支
其他Git相关操作请参考笔者其他文章
参考链接
GIT操作:把当前仓库的一个分支push到另一个仓库的指定分支_gitpush到指定branch-CSDN博客
git pull "fatal: 拒绝合并无关的历史"-CSDN博客
相关文章:
Git使用—把当前仓库的一个分支push到另一个仓库的指定分支、基于当前仓库创建另一个仓库的分支并推送到对应仓库(mit6828)
把学习过程中遇到的Git问题汇总如下(后续学习遇到问题会及时更新此专栏): Git原理及常用命令小结——实用版(ing......)、Git设置用户名邮箱-CSDN博客 解决git每次push代码到github都需要输入用户名以及密码-CSDN博客…...
windows11+ubuntu20.04.6双系统安装
记录win11和ubuntu20.04.6在单个硬盘上安装的主要流程 系统说明 BIOS模式: UEFI 硬盘: 1TB固态 内存: 32GB 步骤 1、 准备两个不小于16GB的U盘,一个用于装Windows,一个用于装ubuntu,注意8G的U盘虽然能够…...
如何通过 PhantomJS 模拟用户行为抓取动态网页内容
引言 随着网页技术的不断进步,JavaScript 动态加载内容已成为网站设计的新常态,这对传统的静态网页抓取方法提出了挑战。为了应对这一挑战,PhantomJS 作为一个无头浏览器,能够模拟用户行为并执行 JavaScript,成为了获…...
ARM驱动学习之8 动态申请字符类设备号
ARM驱动学习之8 动态申请字符类设备号 KernelCode: • 字符设备函数在文件“include/linux/fs.h”中 • alloc_chrdev_region() 是动态分配主次设备号。 • 宏定义MAJOR提取dev_t数据中的主设备号源码: /*** alloc_chrdev_region() - register a range of char dev…...
TCP.IP四层模型
一、TCP/IP模型协议分层 1、应用层: 2、传输层: TCP:传输控制协议 UDP:用户数据报协议 3、网络层: IP: 国际协议(IP地址) ICMP: 互联网控制消息协议(互联网…...
极狐GitLab DevSecOps 功能合集(七大安全功能)
极狐GitLab 是 GitLab 在中国的发行版,专门面向中国程序员和企业提供企业级一体化 DevOps 平台,用来帮助用户实现需求管理、源代码托管、CI/CD、安全合规,而且所有的操作都是在一个平台上进行,省事省心省钱。可以一键安装极狐GitL…...
进阶SpringBoot之异步任务、邮件任务和定时执行任务
SpringBooot 创建 Web 项目 异步任务: service 包下创建 AsyncService 类 Async 异步方法 Thread.sleep(3000) 停止三秒,捕获异常 package com.demo.task.service;import org.springframework.scheduling.annotation.Async; import org.springfram…...
【设计模式-桥接】
定义 桥接模式(Bridge Pattern)是一种结构型设计模式,它通过将抽象部分与实现部分分离,使它们都可以独立地变化。桥接模式的关键在于将类的抽象部分与其实现部分解耦,以便两者可以独立地变化。这种设计模式的一个主要…...
JVM JMM 专题篇 ( 12000 字详解 )
一:JVM 简介 JVM 是 Java Virtual Machine 的简称,意为 Java 虚拟机,虚拟机是指通过软件模拟的具有完整硬件功能的、运行在一个完全隔离的环境中的完整计算机系统。 常见的虚拟机:JVM、VMwave、Virtual Box,JVM 和其…...
【C++】—— list 模拟实现
【C】—— list 模拟实现 1 list 基础结构2 默认构造3 迭代器3.1 整体框架3.2 成员函数3.3 begin() 与 end() 的实现3.4 operator-> 的实现3.5 const 迭代器3.5.1 const 迭代器为什么命名 const_iterator3.5.2 const 迭代器的实现3.5.3 合并两个迭代器 4 源码 1 list 基础结…...
Redis主要问题
Redis redis是单线程,基于内存操作,所以执行很快。,与网络延迟有关。 还是买早餐的例子,从早餐店买一个包子,首先早餐店得还有包子没有卖完,然后卖出,包子数量-1,重新设定早餐店包…...
vue3 ref的用法及click事件的说明
1、ref可以定义一个简单的属性,也可以是一个复杂的列表、数组等等。 2、为什么要使用 ref?简单的let个变量不行吗?const个变量不行吗? 其实这个跟vue的响应式的系统有关,官方的说明如下: 3、为 ref() 标注…...
通信工程学习:什么是HFC混合光纤同轴电缆
HFC:混合光纤同轴电缆 HFC(Hybrid Fiber Coaxial)混合光纤同轴电缆是一种结合了光纤与同轴电缆的宽带接入网技术。以下是对HFC混合光纤同轴电缆的详细解释: 一、HFC混合光纤同轴电缆的定义与概述 定义:HFC是一种结合光…...
怎么浏览URL的PDF文件呢
最近发现PDF文件网页端打开就是丑,不知道怎么办 1. 看着实在不舒服,用chorm的插件 然后原本本地用的也是2345pdf阅读器 2. 之后也下载了adobe pdf的桌面阅读器 2345打开是这个样子 这个是现在啦 如果要一些安装包什么的,评论见~ 最…...
【2025届华为秋招机考三道编程题之一】华为校招留学生软件开发工程师-真题机考笔试/(200分)- 跳格子3(Java JS Python C)
华为校招机考的题型: 编程:软件测试工程师,算法,OD岗,三道编程题不限语言【C,Python,Java】 校招:600分 120分钟,100/200/300 社招:400分 150分钟…...
高性能缓存利器:Caffeine 在 Spring Boot 中的应用
在现代应用程序中,缓存是提高数据检索速度、减少对数据库或其他数据源访问次数的重要手段。Spring Cache 提供了多种缓存实现方式,而在我们的 Spring Boot 项目中,我们选择了 Caffeine 作为默认的缓存库。 Caffeine 简介 Caffeine 是一个基…...
pWnOS的第二种全新解法(ssh私钥破解、webmin漏洞提权)
端口 端口扫描内容请看:vulnhub(8):pWnOS(还没信息收集就已经成功打点)-CSDN博客 打点 ssh登录公钥收集 ./2017.pl 192.168.234.116 10000 /home/vmware/.ssh/authorized_keys 0 ./2017.pl 192.168.234.11…...
Maven入门学习笔记
一、maven介绍 Maven是一款自动化构建工具,专注服务于JAVA平台的项目构建和依赖管理。在javaEE开发的历史上构建工具的发展也经历了一系列的演化和变迁。 管理jar包 当我们使用SSM之后我们就需要使用非常多的jar包 没有maven找jar包非常的麻烦。 使用maven下载…...
linux驱动开发-arm汇编基础
目录 写在前面 1、Cortex-A7 处理器有 9 种处理模式 2、Cortex-A 寄存器组 通用寄存器 1、汇编语法 2、Cortex-A7 常用汇编指令 2.1 处理器内部数据传输指令 2.1.1 传输数据操作类型 1、MOV指令 2、MRS指令 3、MSR指令 2.2、存储器访问指令 2.2.1 LDR指令 2.2.2 …...
【HarmonyOS】鸿蒙头像上传-(编辑个人信息页- 头像上传)+实时数据更新
#效果图 #思路 ##步骤: ###一、利用picker api选择1张图片 实例化选择器参数(使用new PhotoSelectOptions())实例化图片选择器 (使用newPhotoViewPicker() )调用图片选择器的select方法传入选择器参数完成图片选取获得结果 利用picker api选择1张图片 async sele…...
stm32G473的flash模式是单bank还是双bank?
今天突然有人stm32G473的flash模式是单bank还是双bank?由于时间太久,我真忘记了。搜搜发现,还真有人和我一样。见下面的链接:https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...
React Native 开发环境搭建(全平台详解)
React Native 开发环境搭建(全平台详解) 在开始使用 React Native 开发移动应用之前,正确设置开发环境是至关重要的一步。本文将为你提供一份全面的指南,涵盖 macOS 和 Windows 平台的配置步骤,如何在 Android 和 iOS…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...
大学生职业发展与就业创业指导教学评价
这里是引用 作为软工2203/2204班的学生,我们非常感谢您在《大学生职业发展与就业创业指导》课程中的悉心教导。这门课程对我们即将面临实习和就业的工科学生来说至关重要,而您认真负责的教学态度,让课程的每一部分都充满了实用价值。 尤其让我…...
GitHub 趋势日报 (2025年06月06日)
📊 由 TrendForge 系统生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日获星趋势图 今日获星趋势图 590 cognee 551 onlook 399 project-based-learning 348 build-your-own-x 320 ne…...
R 语言科研绘图第 55 期 --- 网络图-聚类
在发表科研论文的过程中,科研绘图是必不可少的,一张好看的图形会是文章很大的加分项。 为了便于使用,本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中,获取方式: R 语言科研绘图模板 --- sciRplothttps://mp.…...
日常一水C
多态 言简意赅:就是一个对象面对同一事件时做出的不同反应 而之前的继承中说过,当子类和父类的函数名相同时,会隐藏父类的同名函数转而调用子类的同名函数,如果要调用父类的同名函数,那么就需要对父类进行引用&#…...
tomcat指定使用的jdk版本
说明 有时候需要对tomcat配置指定的jdk版本号,此时,我们可以通过以下方式进行配置 设置方式 找到tomcat的bin目录中的setclasspath.bat。如果是linux系统则是setclasspath.sh set JAVA_HOMEC:\Program Files\Java\jdk8 set JRE_HOMEC:\Program Files…...
书籍“之“字形打印矩阵(8)0609
题目 给定一个矩阵matrix,按照"之"字形的方式打印这个矩阵,例如: 1 2 3 4 5 6 7 8 9 10 11 12 ”之“字形打印的结果为:1,…...
字符串哈希+KMP
P10468 兔子与兔子 #include<bits/stdc.h> using namespace std; typedef unsigned long long ull; const int N 1000010; ull a[N], pw[N]; int n; ull gethash(int l, int r){return a[r] - a[l - 1] * pw[r - l 1]; } signed main(){ios::sync_with_stdio(false), …...
