git submodule的使用:将别人的git仓库作为自己的子仓库

ops/2025/1/8 13:12:28/
  • git的基本操作在该篇中展示:git的基本操作
  • 在日常开发中,我们经常会碰到需要将别人的仓库作为自己的子仓库来进行开发。下面将介绍具体将如何操作。

1、添加Submodule至自己的git仓库

1.1、创建自己的Git仓库

(1)在github中创建自己的仓库。

(2)在终端将该仓库clone下来,并cd至该目录。

git clone xxx
cd xxx

1.2、添加子模块

(1)使用 git submodule add 命令添加子模块。

git submodule add <子模块 URL> <子模块目录># eg:将abc的子模块添加至我们的项目中
git submodule add htps://github.com/xxx/abc.git abc

1.3、提交并上传变更

输入以下指令提交并上传:

git commit -m "添加子模块 abc"
git push

2、Submodule的使用规则

2.1、子模块的版本控制

管理子模块的规则和主模块相同。

  • 克隆子模块
--init 选项:如果子模块尚未初始化,则将其初始化。
--recursive 选项:递归更新所有子模块,包括嵌套子模块。

每次使用时输入:

git submodule update --init --recursive# 作用:
# 1、初始化所有未初始化的子模块。
# 2、更新所有子模块到最新提交。
# 3、递归更新所有嵌套子模块。
  • 更新子模块
git submodule update --recursive
  • 提交子模块变更
cd lib
git add .
git commit -m "更新子模块 lib"
cd ..
git submodule add lib
git commit -m "更新子模块版本"

2.2、子模块的分支管理

子模块可以独立进行分支管理。

  • 切换子模块分支:
git submodule checkout <分支名称>
  • 创建子模块分支:
git submodule branch <分支名称>
  • 合并子模块分支:
git submodule merge <分支名称>

3、更新Submodule

3.1、更新所有的子模块

git submodule update --recursive

3.2、更新指定子模块

git submodule update <子模块目录># eg:更新abc子模块
# git submodule update abc

3.3、单独更新子模块

使用 git fetchgit reset 单独更新子模块。

git fetch <子模块 URL>
git reset --hard <子模块版本>

例如,将 abc 子模块更新至 v1.0.0 版本:

git fetch https://github.com/user/abc.git
git reset --hard v1.0.0

4、合并Submodule

4.1、合并子模块变更

git submodule update --init --recursive
git add .
git commit -m "合并子模块变更"

4.2、解决冲突

如果遇到冲突,需要手动解决。

git submodule status
git submodule foreach git mergetool
git add .
git commit -m "解决子模块冲突"

5、子模块指针用法

我们可以使用子模块指针来指定子模块的特定版本。

git submodule add --depth 1 https://github.com/user/lib.git lib
git submodule update --init --recursive

6、子模块克隆

我们也可以单独克隆子模块至单独目录中。

git submodule clone https://github.com/user/lib.git lib

7、删除子模块

git submodule deinit abc
git rm -rf abc


http://www.ppmy.cn/ops/147807.html

相关文章

力扣--70.爬楼梯

题目 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f; 示例 1&#xff1a; 输入&#xff1a;n 2 输出&#xff1a;2 解释&#xff1a;有两种方法可以爬到楼顶。 1 阶 1 阶2 阶 示例 2&#…

【DevOps】Jenkins部署

Jenkins部署 文章目录 Jenkins部署资源列表基础环境一、部署Gilab1.1、安装Gitlab1.2、修改配置文件1.3、加载配置文件1.4、访问Gitlab1.5、修改root登录密码1.6、创建demo测试项目1.7、上传代码1.8、验证上传的代码 二、部署Jenkins所需软件2.1、部署JDK2.2、部署Tomcat2.3、部…

[RoarCTF 2019]Easy Calc1

检查源码&#xff0c;发现有一个url:calc.php。然后尝试去访问一下&#xff0c;还真的可以看到&#xff1a; 可以看到&#xff0c;get型获得num变量的值&#xff0c;然后设置了一个黑名单&#xff0c;进行过滤&#xff0c;这里就需要之前提到的&#xff0c;[极客大挑战 2019]Kn…

MySQL优化器估算SQL语句访问行数的深入分析

MySQL优化器估算SQL语句访问行数的深入分析 一、背景介绍 在数据库运维工作中&#xff0c;慢SQL是一个常见问题。导致慢SQL问题的原因很多&#xff0c;常见的包括资源瓶颈&#xff08;CPU、磁盘、网络等资源打满&#xff09;、不合理的参数配置、SQL语句自身问题以及SQL代价估…

[CTF/网络安全] 攻防世界 Web_php_include 解题详析(php伪协议、data伪协议、file伪协议)

代码审计 这段代码首先通过 show_source(__FILE__) 显示当前文件的源代码&#xff0c;然后通过 $_GET[hello] 显示 URL 参数中名为 hello 的值。 接下来&#xff0c;代码使用 $_GET[page] 获取 URL 参数中名为 “page” 的值&#xff0c;并进行字符串替换&#xff0c;将 php:…

RestClient操作Elasticsearch

简介 Elasticsearch Elasticsearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎&#xff0c;基于RESTful web接口。Elasticsearch是用Java语言开发的&#xff0c;并作为Apache许可条款下的开放源码发布&#xff0c;是一种流行的企业级搜索引擎…

一、Git与GitHub基础说明

Git与GitHub Git与GitHub一、Git1定义2核心功能(1) 版本控制(2) 分支管理(3) 合并操作 二、GitHub1定义2核心功能(1)远程仓库托管(2)Pull Requests&#xff08;拉取请求&#xff09;(3) Issue Tracking&#xff08;问题跟踪&#xff09;(4) 团队管理(5) 社交功能(6)个人资料和贡…

爬虫代码中如何添加异常处理?

在编写爬虫代码时&#xff0c;添加异常处理是非常重要的一步&#xff0c;因为它可以帮助我们处理网络请求中可能出现的各种问题&#xff0c;比如网络连接错误、超时、解析错误等。以下是如何在Python爬虫代码中添加异常处理的示例&#xff1a; import requests from bs4 impor…