小白入门:GitHub 远程仓库使用全攻略

news2025/5/20 4:00:22

一、Git 核心概念

1. 三个工作区域

  • 工作区(Working Directory):实际编辑文件的地方。
  • 暂存区(Staging Area):准备提交的文件集合(使用git add操作)。
  • 本地仓库(Local Repository):已提交的内容(通过git commit提交)。
  • 远程仓库(Remote Repository):如 GitHub 等托管平台上的仓库。

2. 分支

在 Git 版本控制系统中,分支(Branch) 是指从主分支(如main或master)分离出来的独立开发线路,每个分支都有独立的提交历史,允许开发者并行开展不同的开发任务。例如,当开发新功能、修复特定 Bug 或进行实验性开发时,都可以创建独立分支。

分支的核心优势在于代码隔离与并行开发

  • 功能隔离:以main(或master)作为默认分支,新功能开发可在独立分支上进行,避免直接修改主线代码。例如,开发电商网站的「直播带货」功能时,可创建feature/live-selling分支,确保核心购物流程(main分支)不受影响。
  • 版本管理:不同分支可对应不同版本迭代,便于团队分工协作。如dev分支用于日常开发,release分支用于预发布测试,hotfix分支用于紧急修复线上问题。
  • 风险可控:若分支开发中出现错误,可随时丢弃或回滚,不会破坏主分支稳定性,降低对整个项目的影响。
二、GitHub 远程仓库搭建步骤
  1. 注册 GitHub 账号访问 GitHub 官网 注册账号。
  1. 创建新仓库
    • 点击右上角 New repository → 填写仓库名(如 LM_Steer)→ 创建。
  1. 本地环境配置
    • 安装 Git:下载地址
    • 配置用户名和邮箱:

git config --global user.name "Your Name"

git config --global user.email "your_email@example.com"

三、Git 基本操作
  1. 本地仓库初始化

git init # 在项目目录初始化Git仓库

  1. 提交文件到本地仓库

git add . # 添加所有文件到暂存区

git commit -m "初始提交" # 提交到本地仓库

  1. 关联远程仓库

git remote add origin git@github.com:用户名/仓库名.git # 添加远程仓库

  1. 推送至远程仓库

git push -u origin main # 首次推送需指定上游分支

  1. 拉取远程更新

git pull origin main # 拉取并合并远程更新

  1. 分支 track(追踪分支)介绍

在 GitHub 协作开发中,追踪分支是连接本地分支与远程分支的桥梁。它具有两大核心优势:

  1. 自动同步更新:避免手动频繁拉取代码,执行git pull或git push命令时,本地分支会自动与追踪的远程分支交互。
  1. 明确关联关系:清晰展示本地与远程分支的对应关系,便于团队快速掌握代码同步状态。
创建方式

追踪分支的创建分为两种场景:

  • 新建分支时直接追踪:使用命令 git checkout -b feature/xxx origin/feature/xxx,在创建本地feature/xxx分支的同时,直接设置为追踪远程origin/feature/xxx分支。
  • 已有分支设置追踪:通过命令 git branch --set-upstream-to=origin/xxx local_xxx,将现有本地分支local_xxx关联至远程origin/xxx分支。
  1. 如何查看并删除远程关联的仓库
    • 查看远程仓库:在本地仓库的命令行中,输入 git remote -v 命令,即可列出所有已关联的远程仓库及其对应的 URL 地址。例如,输出可能类似 origin https://github.com/yourusername/yourrepository.git (fetch) 和 origin https://github.com/yourusername/yourrepository.git (push),其中 origin 是默认的远程仓库别名。
    • 删除远程仓库:若要删除某个远程仓库关联,使用 git remote remove <远程仓库别名> 命令,如 git remote remove origin 即可删除别名为 origin 的远程仓库关联。也可以使用 git remote rm <远程仓库别名> 达到同样效果 。
四、典型问题与解决方案
  1. 问题 1:认证失败(Authentication failed)
    • 原因:用户名 / 密码错误,或 GitHub 已禁用密码认证。
    • 解决方案
      • 生成 SSH 密钥:打开终端(Windows 用户可使用 Git Bash),输入ssh-keygen -t ed25519 -C "your_email@example.com",其中邮箱地址替换为你的 GitHub 注册邮箱,按三次回车键完成密钥生成。密钥文件默认存储在用户主目录的.ssh文件夹下。注意添加环境变量,否则可能无法使用ssh-keygen
      • 添加公钥到 GitHub:找到生成的公钥文件(后缀为.pub),使用文本编辑器打开,复制全部内容。登录 GitHub,进入Settings -> SSH and GPG keys,点击New SSH key,粘贴公钥内容并添加。
      • 测试 SSH 连接:在终端输入ssh -T git@github.com,首次连接会提示确认,输入yes。若出现Hi [你的用户名]! You've successfully authenticated, but GitHub does not provide shell access.,则表示 SSH 密钥配置成功,后续可通过 SSH 协议安全高效地操作远程仓库 。

ssh-keygen -t ed25519 -C "your_email@example.com" # 生成密钥

# 将公钥(~/.ssh/id_ed25519.pub)添加到GitHub

      • 使用个人访问令牌(PAT):GitHub Settings → Developer settings → Personal access tokens → 生成令牌,推送时用令牌替代密码。
  1. 问题 2:无法使用 ssh-keygen 命令
    • 原因:Windows 未安装 OpenSSH 客户端。
    • 解决方案

# 以管理员身份运行PowerShell

Add-WindowsCapability -Online -Name OpenSSH.Client~0.0.1.0

或安装 Git for Windows。

  1. 问题 3:推送被拒绝(non-fast-forward)
    • 原因:远程分支有新提交,本地历史落后。
    • 解决方案

git pull origin 分支名 # 先拉取合并

# 若有冲突,解决后再推送

  1. 问题 4:合并无关历史(refusing to merge unrelated histories)
    • 原因:本地与远程仓库无共同提交历史。
    • 解决方案

git pull origin 分支名 --allow-unrelated-histories # 强制合并

  1. 问题 5:修改 .gitignore 不生效
    • 原因:已跟踪的文件不受新规则影响。
    • 解决方案

git rm -r --cached . # 清除缓存

git add . # 重新添加

git commit -m "更新.gitignore

  1. 问题6:使用push命令时,它会推送本地仓库中所有未推送的commit。若不想将所有修改一次性推送,避免影响主分支稳定性,建议新建一个分支进行操作。具体可通过git branch new_branch_name创建新分支,再使用git checkout new_branch_name切换到新分支,在该分支上进行开发与提交,最后按需将分支合并到主分支。
五、分支管理
  1. 查看分支

git branch # 查看本地分支

git branch -r # 查看远程分支

git branch -a # 查看所有分支

  1. 创建与切换分支

git checkout -b 新分支名 # 创建并切换到新分支

  1. 合并分支

git checkout main # 切换到目标分支

git merge 源分支名 # 合并源分支到当前分支

六、最佳实践
  1. 保持 main 分支稳定:仅合并经过测试的代码。
  1. 使用分支开发新功能:避免影响主线。
  1. 定期同步远程分支

git fetch origin # 更新远程分支引用

  1. 通过 Pull Request 合并代码:便于代码审查。
七、常见命令速查表

操作

命令

初始化仓库

git init

添加文件到暂存区

git add <文件>

提交到本地仓库

git commit -m "描述"

查看状态

git status

查看提交历史

git log

拉取远程更新

git pull origin 分支名

推送至远程

git push origin 分支名

创建并切换分支

git checkout -b 分支名

切换分支

git checkout 分支名

合并分支

git merge 分支名

删除分支

git branch -d 分支名

通过以上步骤,你可以完成 GitHub 远程仓库的搭建与基本操作,解决常见问题,并建立规范的开发流程。

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

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

相关文章

RPC与SOAP的区别

一.RPC&#xff08;远程过程调用&#xff09;和SOAP&#xff08;简单对象访问协议&#xff09;均用于实现分布式系统中的远程通信&#xff0c;但两者在设计理念、协议实现及应用场景上存在显著差异。 二.对比 1.设计理念 2.协议规范 3.技术特性 4.典型应用场景 5.总结 三.总结…

Day11-苍穹外卖(数据统计篇)

前言&#xff1a; 今天写day11的内容&#xff0c;主要讲了四个统计接口的制作。看起来内容较多&#xff0c;其实代码逻辑都是相似的&#xff0c;这里我们过一遍。 今日所学&#xff1a; Apache ECharts营业额统计用户统计订单统计销量排行统计 1. Apache ECharts 1.1 介绍 A…

Tomcat简述介绍

文章目录 Web服务器Tomcat的作用Tomcat分析目录结构 Web服务器 Web服务器的作用是接收客户端的请求&#xff0c;给客户端作出响应。 知名Java Web服务器 Tomcat&#xff08;Apache&#xff09;&#xff1a;用来开发学习使用&#xff1b;免费&#xff0c;开源JBoss&#xff0…

《从零开始:Spring Cloud Eureka 配置与服务注册全流程》​

关于Eureka的学习&#xff0c;主要学习如何搭建Eureka&#xff0c;将order-service和product-service都注册到Eureka。 1.为什么使用Eureka? 我在实现一个查询订单功能时&#xff0c;希望可以根据订单中productId去获取对应商品的详细信息&#xff0c;但是产品服务和订单服…

FPGA学习知识(汇总)

1. wire与reg理解&#xff0c;阻塞与非阻塞 2. 时序取值&#xff0c;时钟触发沿向左看 3. ip核/setup debug 添加 ila 一、ila使用小技巧 二、同步复位、异步复位和异步复位同步释放 设计复位设计&#xff0c;尽量使用 异步复位同步释放&#xff1b;尽管该方法仍然对毛刺敏感…

Redisson分布式锁-锁的可重入、可重试、WatchDog超时续约、multLock联锁(一文全讲透,超详细!!!)

本文涉及到使用Redis实现基础分布式锁以及Lua脚本的内容&#xff0c;如有需要可以先参考博主的上一篇文章&#xff1a;Redis实现-优惠卷秒杀(基础版本) 一、功能介绍 (1)前面分布式锁存在的问题 在JDK当中就存在一种可重入锁ReentrantLock&#xff0c;可重入指的是在同一线…

语言模型:AM-Thinking-v1 能和大参数语言模型媲美的 32B 单卡推理模型

介绍 a-m-team 是北科 &#xff08;Ke.com&#xff09; 的一个内部团队&#xff0c;致力于探索 AGI 技术。这是一个专注于增强推理能力的 32B 密集语言模型。 a-m-team / AM-Thinking-v1 是其旗下的一个语言模型&#xff0c;采用低成本的方式能实现和大参数模型媲美。 DeepSe…

ChatGPT:OpenAI Codex—一款基于云的软件工程 AI 代理,赋能 ChatGPT,革新软件开发模式

ChatGPT&#xff1a;OpenAI Codex—一款基于云的软件工程 AI 代理&#xff0c;赋能 ChatGPT&#xff0c;革新软件开发模式 导读&#xff1a;2025年5月16日&#xff0c;OpenAI 发布了 Codex&#xff0c;一个基于云的软件工程 AI 代理&#xff0c;它集成在 ChatGPT 中&#xff0c…

智能视觉检测技术:制造业质量管控的“隐形守护者”

在工业4.0浪潮的推动下&#xff0c;制造业正经历一场以智能化为核心的变革。传统人工质检模式因效率低、误差率高、成本高昂等问题&#xff0c;逐渐难以满足现代生产对高精度、高速度的需求。智能视觉检测技术作为人工智能与机器视觉融合的产物&#xff0c;正成为制造业质量管控…

利用html制作简历网页和求职信息网页

前言 大家好&#xff0c;我是maybe。今天下午初步学习了html的基础知识。做了两个小网页&#xff0c;一个网页是简历网页&#xff0c;一个网页是求职信息填写网页。跟大家分享一波~ 说明:我不打算上传图片。所以如果有朋友按照我的代码运行网页&#xff0c;会出现一个没有图片…

卷积神经网络进阶:转置卷积与棋盘效应详解

【内容摘要】 本文深入解析卷积神经网络中的转置卷积&#xff08;反卷积&#xff09;技术&#xff0c;重点阐述标准卷积与转置卷积的计算过程、转置卷积的上采样作用&#xff0c;以及其常见问题——棋盘效应的产生原因与解决方法&#xff0c;为图像分割、超分辨率等任务提供理论…

2025年5月13日第一轮

1.百词斩 2.安全状态和死锁 3.银行家算法和状态图 4.Vue运行 5.英语听力 6.词汇 7.英语 长篇:数学竞赛 8.数学 间断点类型和数量 The rapid development of artificial intelligence has led to widerspareasd concreasns about job displacemant.As AI technology conti…

小结:Android系统架构

https://developer.android.com/topic/architecture?hlzh-cn Android系统的架构&#xff0c;分为四个主要层次&#xff1a;应用程序层、应用框架层、库和运行时层以及Linux内核层。&#xff1a; 1. 应用程序层&#xff08;Applications&#xff09; 功能&#xff1a;这一层包…

基于C#的MQTT通信实战:从EMQX搭建到发布订阅全解析

MQTT(Message Queueing Telemetry Transport) 消息队列遥测传输&#xff0c;在物联网领域应用的很广泛&#xff0c;它是基于Publish/Subscribe模式&#xff0c;具有简单易用&#xff0c;支持QoS&#xff0c;传输效率高的特点。 它被设计用于低带宽&#xff0c;不稳定或高延迟的…

ISP中拖影问题的处理

有时候会出现如下的阴影问题该如何处理呢&#xff1f;本文将提供几个思路。 1、降低曝光时间 如果曝光时间过大&#xff0c;会统计整个曝光时间内的图像信息&#xff0c;就会导致拖影的产生&#xff0c;这个时候可以考虑降低一下曝光时间。 2、时域降噪过大 只要明白时域降噪…

SQLMesh 模型管理指南:从创建到验证的全流程解析

本文全面介绍SQLMesh这一现代化数据转换工具的核心功能&#xff0c;重点讲解模型创建、编辑、验证和删除的全生命周期管理方法。通过具体示例和最佳实践&#xff0c;帮助数据工程师掌握SQLMesh的高效工作流程&#xff0c;包括增量模型配置、变更影响评估、安全回滚机制等关键操…

HarmonyOS AVPlayer 音频播放器

鸿蒙文档中心&#xff1a;使用AVPlayer播放视频(ArkTS)文档中心https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/video-playback 这张图描述的是 HarmonyOS AVPlayer 音频播放器的状态流转过程&#xff0c;展示了 AVPlayer 在不同状态之间的切换条件和关键操作…

⭐️白嫖的阿里云认证⭐️ 第二弹【课时1:提示词(Prompt)技巧】for 「大模型Clouder认证:利用大模型提升内容生产能力」

「大模型Clouder认证:利用大模型提升内容生产能力」这个认证目前在阿里云认证中心还是免费的,简单几步就可以申请考试,有两次的免费考试机会。而且,这个课程中的内容对于所有普通用户来说都非常实用,课程整体长度也就3节课,非常快速就能学完。心动不如行动,赶紧开始吧!…

Filament引擎(一) ——渲染框架设计

filament是谷歌开源的一个基于物理渲染(PBR)的轻量级、高性能的实时渲染框架&#xff0c;其框架架构设计并不复杂&#xff0c;后端RHI的设计也比较简单。重点其实在于项目中材质、光照模型背后的方程式和理论&#xff0c;以及对它们的实现。相关的信息&#xff0c;可以参考官方…

c++从入门到精通(六)--特殊工具与技术-完结篇

文章目录 特殊工具与技术-完结篇控制内存分配运行时类型识别成员指针嵌套类局部类固有的不可抑制特性位域volatile限定符链接指示 extern "C" 特殊工具与技术-完结篇 控制内存分配 重载new和delete&#xff1a; ​ 如果应用程序希望控制内存分配的过程&#xff0c;…