最新资讯

  • 使用git+github进行多人协同开发全过程详细步骤手把手教学!分支管理,合并分支从此不再迷惑~(含网络问题等各种细节问题的解决办法)

使用git+github进行多人协同开发全过程详细步骤手把手教学!分支管理,合并分支从此不再迷惑~(含网络问题等各种细节问题的解决办法)

2025-05-14 05:37:38 2 阅读

想看详细步骤点目录里面的 典型多人协作流程示例,实例演示:多人协作开发同一项目全过程 直达,我操作了一遍都截图注释了


在实际开发的时候,大家还是各有不同的问题用不好分支,这里给出低难度的在同一个分支上多人合作的步骤多人在同一个分支上合作


常用git命令


这段时间实在太忙,主包对git+github已经有了更深入的理解和使用,等稍微空闲点一定大更新一波。主包是不会把它加入会员可看的,大家放心


目录

git使用指南

入门介绍:Git 的几项神奇功能:

1. 一个仓库管理所有分支

2. 分支切换

3. 分支合并

4. 超强历史记录

多说一句:Git 是效率提升神器

什么是本地?

本地仓库的结构

本地仓库和远程仓库的关系

你提到的文件夹

总结

什么是暂存区?

暂存区的作用

回退和暂存区的关系

1. 撤销暂存区的内容(回退到工作区)

2. 撤销工作区的内容(还原到上一次的版本)

3. 回滚到某个提交

工作目录、暂存区、仓库的关系

总结

git push

分支基本操作

1. 拉取并合并远程分支 (git pull)

2. 只拉取远程更改,不合并 (git fetch)

3. 推送本地更改到远程 (git push)

4. 查看当前本地分支与远程分支的状态 (git status)

​编辑

5. 查看所有远程分支 (git branch -r)

新建本地分支并追踪远程分支

1. 从远程仓库拉取新分支并追踪

2. 使用 git fetch 获取远程分支

3. 将本地分支与远程分支建立追踪关系

4. 创建一个本地分支并推送到远程仓库

6. 查看本地和远程分支的差异 (git log)

7.切换 Git 分支时提示有未提交的更改

1. 检查未提交的更改

2. 解决方法

方法 1:提交更改

方法 2:暂存更改(使用 Stash)

方法 3:放弃更改

方法 4:强制切换分支

3. 注意事项

本地文件的存储方式

实际工作中的文件情况

是否需要多份文件?

重要注意事项

典型多人协作流程示例

实例演示:多人协作开发同一项目全过程

​编辑

异常情况(需要手动处理):

为什么正常情况下不需要手动创建本地 master?

在Git中,冲突通常发生在以下几种情况:

1. 合并不同分支时

2. 推送本地分支到远程时

3. 分支历史不一致时

详细解释:

4. 合并分支与主分支时

如何解决冲突?

多人在同一个分支上合作

在本地创建自己的分支(第一次加入分支工作)

完成后上传(可以不用每次都上传,但顺手的事)

下一次工作

遇到的一些问题

1.大文件不能上传,如build文件夹


git使用指南

常用git命令

🧭 一、配置与初始化

命令说明
git config --global user.name "你的名字"设置全局用户名
git config --global user.email "你的邮箱"设置全局邮箱
git init初始化本地 Git 仓库
git clone <仓库地址>克隆远程仓库到本地

使用场景:

在本地工作文件夹初始化本地Git仓库-----克隆远程仓库到本地


📌 二、远程仓库相关

命令说明
git remote -v查看远程仓库地址
git remote add origin <远程地址>添加远程仓库
git remote set-url origin <地址>修改远程地址(如切换 HTTPS/SSH)

使用场景:

遇到网络问题时:

查看远程仓库地址-----修改远程地址(如切换 HTTPS/SSH)


📦 三、本地操作(版本控制核心)

命令说明
git status查看当前状态
git add <文件>暂存单个文件
git add .暂存所有更改
git commit -m "提交说明"提交更改
git log查看提交历史
git diff查看未暂存的更改
git diff --cached查看已暂存但未提交的更改

使用场景:

需要回退版本查看提交历史进行回退


📤 四、推送与拉取

命令说明
git pull从远程仓库拉取并合并
git push推送本地提交到远程仓库
git push -u origin main首次推送并设置默认上游分支

🌿 五、分支操作

命令说明
git branch查看所有本地分支
git branch <分支名>创建新分支
git checkout <分支名>切换分支
git switch <分支名>更现代的切换方式(推荐)
git checkout -b <分支名>创建并切换到新分支
git merge <分支名>合并某分支到当前分支
git branch -d <分支名>删除分支(已合并)


🧹 六、撤销与恢复

命令说明
git restore <文件>撤销对文件的修改(未 add)
git restore --staged <文件>撤销已添加到暂存区的文件
git reset HEAD~1回退上一次 commit(保留更改)
git reset --hard HEAD~1强制回退并删除改动(危险)

入门介绍:Git 的几项神奇功能

1. 一个仓库管理所有分支
  • 一套工作区文件,N 个分支的版本共存:只要切换分支,文件内容就变了,就像多次元平行世界一样,你只需专注一个版本,剩下的交给 Git。

  • 核心:一切都存在 .git 文件夹里,是真正的“幕后英雄”。


2. 分支切换
  • git checkout <分支名> 只需一行命令,分支间的内容瞬间切换。

  • Git 还会帮你记录工作区的状态,不用担心切换分支时丢失更改。


3. 分支合并
  • 假如 master 是主线,你的 feature-A 分支开发了新功能,只要 git merge feature-A,代码就合并了,还能智能解决冲突。

  • 多人协作时,团队开发效率直接起飞!🚀


4. 超强历史记录
  • 无论什么文件,改了多少次,Git 都能帮你保存下来。

  • 想看历史?一条命令搞定:git log


多说一句:Git 是效率提升神器

用好了 Git,你可以:

  • 在任意分支间无缝切换工作。

  • 随时追踪修改、恢复误删、回滚历史。

  • 快速合并代码,拥抱团队协作。

所以赶紧玩起来,Git 的世界真的很酷! 😄

什么是本地?

本地指的就是 当前你的 Git 仓库所在的目录,即项目的文件夹。

本地仓库的结构

当你在某个目录下初始化 Git 仓库时(通过 git init 或克隆远程仓库时 git clone),Git 会在该目录中生成一个隐藏的 .git 文件夹。这个 .git 文件夹包含了所有 Git 用来管理版本控制的元数据和对象。

以下是常见的本地 Git 仓库结构:

  1. 工作区(Working Directory)

    • 这是你在本地仓库目录下直接可见的文件和文件夹,也就是你正常开发和修改代码的地方。

    • Git 会监控这些文件和文件夹的状态,判断它们是未跟踪的、修改过的还是已暂存的。

  2. 暂存区(Staging Area/Index)

    • 是一个临时区域,用来记录你添加(git add)的文件更改,这些更改会在提交(git commit)时进入本地仓库的历史记录。

    • 暂存区是虚拟的,它实际存储在 .git/index 文件中。

  3. 本地分支和提交历史(.git 文件夹)

    • .git 文件夹是 Git 的核心,包含了所有版本管理信息,例如分支、标签、提交历史、配置等。

    • 本地分支就是 .git/refs/heads 文件夹中的记录,比如 .git/refs/heads/master 表示 master 分支的引用。


本地仓库和远程仓库的关系

  • 本地仓库:是你机器上的文件和 .git 元数据的集合,它完全独立于远程仓库。

  • 远程仓库:是托管在 Git 服务器上的仓库(例如 GitHub、GitLab 或你的公司内部服务器),通常通过 origin 这个默认名称来引用。

本地和远程仓库的文件、分支等是通过以下命令同步的:

  1. 从远程拉取(git fetchgit pull:将远程的更新下载到本地。

  2. 推送到远程(git push:将本地分支的更改上传到远程仓库。


你提到的文件夹

例如,你的路径是:xxx/xxx,就是你的本地 Git 仓库目录。在这个目录下,应该有:

  1. .git 文件夹:存储版本管理数据。

  2. 其他项目相关的文件和文件夹:你在开发中修改的代码。

只有在这个路径中操作 Git 命令,它才会生效,因为 Git 需要依赖 .git 文件夹中的元数据。


总结

本地仓库 = 当前项目文件夹下的 .git 文件夹 + 工作区文件

当你执行 Git 命令时(比如 git checkoutgit branch),Git 实际上是在操作 .git 文件夹中的数据,确保工作区文件的状态与版本管理保持一致。

什么是暂存区?

暂存区 (staging area) 是 Git 用来存放将要提交的更改的地方。它是 Git 工作流程中很重要的一部分,主要用来控制哪些改动会被提交到仓库。以下是它的作用和与回退的关系:


暂存区的作用

  1. 选择性提交

    • 暂存区允许你精确选择要提交的文件或更改,而不是一次性提交所有改动。

    • 比如,你修改了 a.cppb.cpp,但只想提交 a.cpp,你可以只把 a.cpp 暂存。

  2. 记录提交内容

    • 当你运行 git commit 时,Git 只会提交暂存区中的内容,工作目录中的其他改动不会被提交。

  3. 文件状态跟踪

    • Git 用暂存区跟踪文件从“修改”到“准备提交”的状态。


回退和暂存区的关系

暂存区可以配合回退操作,但它不是唯一的工具。Git 的回退机制主要涉及以下几个方面:

1. 撤销暂存区的内容(回退到工作区)

如果你已经把改动添加到暂存区,但想撤回(不提交),可以用:

git restore --staged 或git reset HEAD 

作用:让文件从“暂存区”回到“工作目录”,但文件的实际改动内容不会丢失。

2. 撤销工作区的内容(还原到上一次的版本)

如果想丢弃工作目录中的改动,让文件回到仓库中的最新版本:

git restore 

作用:直接覆盖工作区中的文件,慎用!

3. 回滚到某个提交

如果已经提交,但发现问题需要回滚,可以用:

git reset --hard 

作用:回滚到指定提交,并覆盖暂存区和工作区内容。


工作目录、暂存区、仓库的关系

  1. 工作目录:你实际操作的文件。修改代码时的内容存在这里。

  2. 暂存区:准备提交的地方,记录你挑选的改动。

  3. 本地仓库:你用 git commit 把暂存区的内容提交到这里。

  4. 远程仓库:通过 git push 把本地仓库的提交上传到远程。


总结

  • 暂存区是提交的中间站,你可以选择哪些改动需要提交。

  • 如果要回退,可以根据需要选择回退暂存区、工作目录,或者整个提交。

  • 熟练使用 git restoregit reset,可以灵活控制代码版本和状态。🎯

git push

git push 后面需要加上目标远程仓库和分支名,具体的格式是:

git push  
  • :指的是远程仓库的名字,通常是 origin(默认的远程仓库名)。

  • :指的是你要推送的本地分支名。

  1. 推送当前分支到远程仓库: 如果你在本地的 test 分支上并且想要将该分支推送到远程仓库 origin,可以运行:

    git push origin test
  2. 推送所有本地分支到远程仓库: 如果你想要推送所有本地分支到远程仓库,可以使用:

    git push --all origin
  3. 推送标签(tag)到远程仓库: 如果你有标签需要推送,可以使用:

    git push origin 
  4. 推送并设置上游分支(首次推送): 如果这是你第一次将一个本地分支推送到远程仓库,且需要设置追踪信息(即将本地分支与远程分支关联),可以使用:

    git push --set-upstream origin test

分支基本操作

1. 拉取并合并远程分支 (git pull)

git pull 会将远程仓库指定分支的更改拉取到本地,并尝试自动合并:

git pull origin 

例如:

  • git pull origin master 会将远程仓库 origin 中的 master 分支拉取并与本地的 master 分支合并。

2. 只拉取远程更改,不合并 (git fetch)

git fetch 会将远程仓库的更改拉取下来,但不会自动合并,只是将远程分支更新到本地:

git fetch

然后,如果你需要合并某个分支到当前分支,可以使用:

git merge origin/

例如:

  • git merge origin/master 会将远程仓库 origin 中的 master 分支合并到当前本地分支。

3. 推送本地更改到远程 (git push)

如果你在本地进行了更改并希望将其推送到远程仓库:

git push origin 

例如:

  • git push origin master 会将本地的 master 分支推送到远程仓库。

4. 查看当前本地分支与远程分支的状态 (git status)

在进行合并或者推送之前,可以使用 git status 来检查当前的工作状态,例如:

git status
  • 这会显示你当前所在的分支、工作区的修改状态、以及是否有需要推送或者拉取的更改。

5. 查看所有远程分支 (git branch -r)

如果你想查看所有远程分支,可以使用:

git branch -r

新建本地分支并追踪远程分支

1. 从远程仓库拉取新分支并追踪

假设你在远程仓库 origin 中有一个分支(比如 feature),但本地没有该分支。你可以通过以下命令创建本地分支并设置追踪远程分支:

git checkout -b  origin/

2. 使用 git fetch 获取远程分支

如果你不确定远程仓库有哪些分支,可以先使用 git fetch 拉取所有远程分支的更新,但不合并到本地分支:

git fetch

执行 git fetch 后,你可以查看所有远程分支:

git branch -r

然后,你可以按照第一步的命令来新建并切换到本地分支。

3. 将本地分支与远程分支建立追踪关系

如果你已经在本地创建了一个分支,并且想让它追踪远程的某个分支,可以使用以下命令:

git branch --set-upstream-to=origin/ 

例如,你在本地创建了 feature 分支,并想让它追踪远程 origin/feature 分支:

git branch --set-upstream-to=origin/feature feature

4. 创建一个本地分支并推送到远程仓库

如果你已经在本地创建了一个分支,并且希望将它推送到远程仓库,并且在推送时同时设置追踪关系,可以使用 -u 选项:

git push -u origin 

这会将该本地分支推送到远程仓库 origin,同时设置追踪关系,以后你可以在该分支下直接使用 git pushgit pull

6. 查看本地和远程分支的差异 (git log)

你可以通过 git log 来查看本地分支和远程分支的提交差异。例如,查看本地 master 和远程 origin/master 之间的差异:

git log origin/master..master

7.切换 Git 分支时提示有未提交的更改

在切换 Git 分支时提示有未提交的更改,说明当前分支存在未提交的修改或新增文件。Git 不允许切换分支,以免未提交的更改导致数据丢失或冲突。以下是解决方法:


1. 检查未提交的更改

运行以下命令,查看具体有哪些修改:

git status 
  • 红色文件:表示未添加到暂存区的更改。
  • 绿色文件:表示已添加到暂存区但未提交的更改。

2. 解决方法

根据需求选择以下操作之一:

方法 1:提交更改

将更改提交到当前分支:

git add . git commit -m "保存当前更改" 

然后切换分支:

git checkout <目标分支> 
方法 2:暂存更改(使用 Stash)

如果不想提交更改,可以将更改保存到 Git 的临时存储区(Stash):

git stash 

然后切换分支:

git checkout <目标分支> 

切换回原分支后,可以恢复暂存的更改:

git stash pop 
方法 3:放弃更改

如果确认更改不需要保存,可以直接放弃未提交的修改:

  1. 放弃工作区的所有更改:
    git checkout . 
  2. 删除未跟踪的文件或目录:
    git clean -fd 
    然后切换分支:
    git checkout <目标分支> 
方法 4:强制切换分支

如果不关心当前未提交的更改,可以强制切换分支,但这样会丢失未提交的内容:

git checkout -f <目标分支>


3. 注意事项
  • 如果更改非常重要,建议备份或提交后再切换分支,以免数据丢失。
  • 使用 git stash 时,可以创建多个存储记录,使用 git stash list 查看所有存储项。

本地文件的存储方式

  1. 单份工作区文件 Git 的所有分支共享一份工作区文件。每次切换分支时,Git 会根据分支的内容更新工作区中的文件。

    • 你在本地文件夹中看到的文件,就是当前检出的分支对应的文件。

    • 如果你切换到另一个分支,Git 会更新这些文件,变成新分支的状态。

  2. Git 仓库的管理 Git 仓库实际上存储了项目的所有历史记录和所有分支的内容,但它们是以一种高效的方式压缩保存的(.git 文件夹中)。

    • 本地分支的内容实际上都保存在 .git 文件夹中。

    • 你只需要一个项目文件夹,Git 会在你切换分支时动态修改工作区文件,不需要为每个分支保存独立的文件夹。


实际工作中的文件情况

假设你的项目包含三个分支:masterfeature-Afeature-B

  1. 文件在分支间的共享机制

    • 如果某个文件在所有分支中都相同,那么它不会被修改。

    • 如果某个文件在分支间有差异,Git 会根据切换的分支动态更新工作区中的文件。

  2. 场景演示

    • master 分支:你看到的是 master 分支的文件内容。

    • 切换到 feature-A 分支:

      git checkout feature-A

      Git 会替换工作区中的文件,使之变为feature-A分支的内容。

    • 切换回 master 分支:

      git checkout master

      工作区文件再次恢复为master分支的内容。


是否需要多份文件?

答案:不需要。Git 的分支机制非常高效:

  • 文件夹只需要一份,你无需为每个分支单独创建文件夹。

  • Git 会自动切换工作区的文件内容,你只需要专注于当前分支。


重要注意事项

  1. 未提交的更改 如果你修改了文件但尚未提交,切换分支可能会遇到问题,Git 会提示你“工作区中有未提交的更改”:

    • 解决办法是先提交更改,或将更改暂存到“暂存区”:

      bash复制代码git stash
      git checkout 
      git stash pop
  2. 多个副本的极端情况 在少数情况下,如果你需要同时处理多个分支的文件,可以通过创建项目文件夹的副本来操作(如 Gem_master_v1Gem_master_v2),但这通常不是必要的,Git 分支已经足够应对多数场景。

典型多人协作流程示例

  1. 团队远程仓库中有一个 master 分支,每个人都拉取 master 到本地。

  2. 每个人基于master创建自己的分支:

    git checkout -b feature-branch master
  3. 在个人分支上开发并提交代码:

    git commit -m "完成某功能"
  4. 推送到远程的个人分支:

    git push origin feature-branch
  5. 提交合并申请,将个人分支的内容合并到 master

  6. 代码审查通过后,项目管理员或开发者将其合并到远程的 master 分支。

实例演示:多人协作开发同一项目全过程

异常情况(需要手动处理):

如果你遇到了 fatal: 'master' is not a commit,说明本地的 master 无效,解决方法如下:

  1. 确认本地没有有效的 master 分支

    • 查看本地分支:

      git branch

      如果master不在列表中,说明本地没有master

  2. 同步远程分支到本地

    • 获取远程分支的所有更新:

      git fetch origin
    • 基于远程origin/master

      创建一个本地master分支:

      git checkout -b master origin/master

      这会在本地创建一个与远程同步的master分支。

  3. 创建新分支

    • 在本地master基础上创建你的新分支:

      git checkout -b new master

为什么正常情况下不需要手动创建本地 master

因为 Git 的设计允许在创建分支时隐式使用远程分支作为基准。例如,git checkout -b new master 本质上会:

  1. 检查本地 master 是否存在。

  2. 如果本地不存在,就去远程仓库查找 origin/master 并拉取其内容。

但是当本地或远程配置出现异常时(如本地分支未跟踪远程分支、远程仓库不完整等),Git 无法完成上述隐式步骤,因此会报错。

在github上点击pull request提交

上面是在远程合并(一般都在远程合并),也可以从远程拉到本地再合并然后传回远程(多此一举)。

最后关于冲突,

分好工,大家在自己的branch,写分给自己的文件一般不会产生冲突。

在Git中,冲突通常发生在以下几种情况:


1. 合并不同分支时

  • 不同分支有相同的文件改动:

    • 当你尝试将 new 分支与 master 分支合并时,如果两个分支上对同一个文件做了不同的改动,Git就会提示你处理冲突。

    • 例子:

      • master 分支对 config.txt 文件做了修改(增加一行内容),而 new 分支也对 config.txt 文件做了不同的修改(删除了一行内容)。

      • 在合并时,Git无法确定使用哪个版本,因而会产生冲突。


2. 推送本地分支到远程时

  • 在远程已经有新提交的情况下推送:

    • 如果你在 new 分支上工作,并且已经做了一些提交,但在推送到远程之前,其他开发者也在 new 分支上工作并做了新的提交,那么推送时会发生冲突。

    • 例子:

      • 你在 new 分支上提交了一些改动后准备推送,但此时远程的 new 分支已经被其他开发者更新。

      • 当你推送时,Git会发现你的提交历史与远程的不同,无法自动合并,所以会提示你解决冲突。


3. 分支历史不一致时

  • 使用 git pull 时:

    • 当远程仓库和本地仓库有不同的提交历史,使用 git pull 就可能会产生冲突。

    • 例子:

      • 你在 new 分支上做了一些工作,但在 master 分支上有新的提交。如果你 git pull origin master,Git会发现这两个分支历史之间不一致,并提示你解决冲突

      • 详细解释:

        1. 远程和本地历史不一致

          • git pull 命令实际上是两个命令的组合:git fetchgit merge.

          • git fetch 会从远程仓库获取更新,但不会直接合并到本地。它只是将远程仓库的最新内容下载到本地。

          • git merge 将本地分支与远程分支合并。在这一步,Git会检查两者的历史提交,寻找共同的祖先。如果无法找到,则意味着两个分支的历史并没有关联,或者已经被重新初始化了。

        2. 发生冲突的情况

          • 例子:假设你在 new 分支上工作了一段时间,做了一些提交(A、B、C),这时 new 分支的历史是独立的。与此同时, master 分支有一些新的提交(D、E、F)。

          • 当你在new分支上运行

            git pull origin master
            时:
            • Git 会将远程 master 分支的内容下载到本地。

            • 然后,它会尝试将本地 new 分支与远程 master 分支合并。

            • 因为这两个分支的历史没有交集(可能是由于不同的开发人员操作或某些历史变化),Git无法自动决定合并哪个版本。

            • 因此,它会提示你手动解决冲突,因为它无法直接合并两者。

        3. 解决冲突的步骤

          • Git会标记有冲突的文件,并且会告诉你具体冲突在哪些文件中。你需要手动合并这些文件,处理冲突后,才能完成 git pull

          • 解决冲突后,你需要确认合并:git commit 解决掉冲突,并将修改提交。


4. 合并分支与主分支时

  • 分支历史不连贯或不一致:

    • 如果你合并 new 分支到 master 分支时,两个分支的提交历史不连贯(例如 new 分支没有基于 master 创建),Git会产生冲突。

    • 例子:

      • new 分支是从一个完全不同的历史创建的,合并到 master 时,Git发现无法直接合并,因为它们之间没有共同的祖先。


如何解决冲突?

  1. 手动解决冲突

    • Git会标记有冲突的文件,并提示你在工作目录中解决冲突。你需要手动修改文件,根据需求选择保留某个版本的改动或合并两者的差异。

多人在同一个分支上合作(旧)

前置必会:如何回退版本

可能其它人会传一些bug,或者你们共同修改了同样的地方,一拉取下来就会造成冲突,最后导致程序运行不了,现给目前我用的解决办法:

!!!!在拉取之前一定要commit自己的代码!!!!commit是完成在本地git仓库的提交,这样修改就不会丢失(相当于复制备份了,以后能随时取出来),push后才会上传到远程仓库

这样通过下面的指令就可以再把代码变回未拉取前良好的状态,然后可以之后再尝试拉取,能够反复做冲突合并,以免改坏了回不去

git reflog # 查看查看所有操作历史
git reset --hard HEAD@{序号}  # 把本地代码回到HEAD@{序号} 对应的commit 

现在共同用一个分支,

在本地创建自己的分支(第一次加入分支工作)

1.创建好本地仓库连接上github仓库

2.git fetch,拉取远程分支到本地

3.git checkout -b master origin/master,创建本地分支关联远程分支

此时本地已经有我们的共同项目,用qt打开构建(第一次较慢),写自己的部分。 此后只需:

完成后上传(可以不用每次都上传,但顺手的事)

1.git add .,把本地文件加入暂存区

2.以防万一用git status检查下修改对不对

3.没问题用git commit -m "(你对本次修改注释)",提交到本地git仓库

4.git push,推送到远程仓库。推送成功在github上就能看见你的提交了 

下一次工作

1.git pull,拉取远程仓库最新的更新

2.coding自己的部分

3.重复 <完成后上传>

多人在同一个分支上合作(新)

1.先在github创建远程仓库

2.使用git clone在本地克隆一份

3.然后在此基础上开发


容易发生的问题

1.大文件不能上传,如build文件夹

如果 build 文件夹已经被提交到 Git 仓库中怎么办?push会失败,提交不能覆盖,经过我艰难操作,什么lfs管理,.gitinore,.gitattributes啥的都别整,没办法补救。首先上传不需要把build文件夹提交,每个人本地上都有的,不要git add .然后不加思考就commit了,这不就悲剧了吗(push会失败,提交不能覆盖)。那已经提交了怎么办呢?包成功的办法是:

1.先把你的代码复制到另一个地方放着(不然一回退你还没提交到仓库的本地修改就没了或者会很混乱)

2.然后用git log,git reset --hard xxxx,回退到你把大文件提交到本地仓库的前一个状态

3.把你的代码复制回来覆盖,旧状态多余不需要的删掉,build文件夹不用移回来。这下再提交就只有这一个提交并且能成功。

4.最后把build文件夹移回来,里面有.exe项目一点秒跑。下次再提交,单独git add 文件名或者把build文件夹移出去再git add .,就不会出问题了。

没问题后就可以添加.gitnore啦

1. 在项目根目录创建 .gitignore 文件
  • 通过命令行创建

    touch .gitignore

    如果你已经有 .gitignore 文件,直接编辑即可。

  • 在文件管理器中手动创建: 在项目的根目录中,右键选择 新建文件,命名为 .gitignore。(随便选个格式重命名改成.gitignore就行)


2. 编辑 .gitignore 文件

这是个默认的,主要是忽略build

# 忽略操作系统文件
.DS_Store
Thumbs.db

# 忽略日志文件
*.log

# 忽略构建目录
build/
dist/

# 忽略临时文件
*.tmp
*.swp

3. 添加到 Git 并提交

如果这是第一次添加 .gitignore 文件,按以下步骤操作:

  1. .gitignore 文件添加到版本控制:

    git add .gitignore

  2. 提交更改:

    git commit -m "Add .gitignore file"


    接下来再git add .的时候就不会把build也添加了,push到远程,其他小伙伴拉取下就都有了。

2.fatal: refusing to merge unrelated histories

这个错误是因为 Git 认为本地仓库和远程仓库的历史没有共同点(即它们的 commit 历史无关)。通常发生在以下情况:

  1. 本地仓库是新初始化的,但你没有从远程仓库 clone,而是直接 init 并尝试 pull
  2. 远程仓库有历史,但你的本地仓库也是独立创建的,并且两者没有共同的 commit。

解决方案:

✅ 允许合并不相关历史(推荐)

运行以下命令:

git pull origin main --allow-unrelated-histories

🔹 这里的 main 需要替换为你的实际分支名称,比如 master

✅ 强制让本地仓库与远程保持一致(⚠️ 会丢失本地修改)

如果你希望完全使用远程仓库的内容并覆盖本地:

git fetch --all git reset --hard origin/main # 替换 main 为你的分支

✅ 先添加远程再合并

如果你还没有关联远程仓库:

git remote add origin <远程仓库URL> git fetch origin git merge origin/main --allow-unrelated-histories # 解决不相关历史问题

⚠️ 注意:

  • --allow-unrelated-histories 只建议用于 合并两个独立的 Git 历史,正常情况下不应该使用。
  • reset --hard丢失本地未提交的修改,请谨慎使用!

3.网络问题

前置知识:

git访问远程仓库的两种方式

SSH 和 HTTPS 

SSH 方式HTTPS 方式
认证方式SSH 密钥(id_rsa.pub用户名 + 访问令牌
是否需要输入密码不需要(配置一次 SSH Key 后免密)需要(除非使用凭据管理器缓存)
适合场景长期使用 Git,比如开发、贡献代码临时访问,比如克隆仓库或在防火墙环境下
安全性较高,基于 SSH 密钥较低,需要使用 Token 或密码
网络要求需要 SSH 端口(22 或 443),部分网络可能会被封锁无需特殊端口,一般不会被防火墙拦截

如何切换 SSH 和 HTTPS 访问

  1. 切换到 SSH 方式

    git remote set-url origin git@github.com:your-username/your-repo.git

  2. 切换到 HTTPS 方式

    git remote set-url origin https://github.com/your-username/your-repo.git

如果遇到网络问题

Failed to connect to github.com port 443 after 21112 ms: Could not connect to server

1.先在两种方式中切换,其中一种可能成功(一般http更容易遇到网络问题)

2.若ssh报错

说明网络限制了 SSH 端口 22,导致 GitHub 连接超时

测试 SSH 连接

ssh -T git@github.com

如果显示:

ssh: connect to host github.com port 22: Connection timed out

说明端口 22 被封锁。

解决方案:

        1.切换网络:尝试使用手机热点、VPN 或其他网络环境。

        2. 修改 SSH 端口

                GitHub 还提供了一个备用 SSH 端口(443),可以尝试使用:

        ssh -T -p 443 git@ssh.github.com

这个提示是 SSH 在连接 GitHub 的备用 SSH 服务器(ssh.github.com 端口 443)时,检测到该主机的身份尚未被信任。你可以按照以下步骤处理:

  1. 确认连接安全

    • 这个提示是正常的,SSH 需要你手动确认 GitHub 服务器的指纹。

    • GitHub 官方 文档 提供的 ED25519 指纹:

      SHA256:+DiY3wvvV6TuJJhbpZisF/zLDA0zPMSvHdkr4UvCOqU

      这和你的输出 一致,所以可以放心继续。

  2. 输入 yes 并按回车

    这样 SSH 会将 GitHub 的主机密钥添加到 ~/.ssh/known_hosts,下次就不会再询问。

  3. 如果连接成功,你会看到类似的消息

    Hi your-username! You've successfully authenticated, but GitHub does not provide shell access.

    这意味着 SSH 连接 GitHub 成功。


如果还是无法 git pull

如果连接成功但 git pull 仍然失败:

  • 修改 Git 远程仓库 URL 让 Git 使用 ssh.github.com 端口 443:

    git remote set-url origin ssh://git@ssh.github.com:443/your-username/your-repo.git

  • 然后再尝试:

    git pull

问题解决!

4.合并分支进入vim

在执行 git merge 操作时遇到了需要输入合并提交信息的情况。

当前情况分析:

  1. 你正在将远程分支 xxxx 合并到本地同名分支

  2. Git 要求你为这次合并提交输入说明信息

  3. 界面中已经显示了最近的提交历史(05afbb3 是之前的提交)

你可以采取以下操作:

1. 直接接受默认合并信息(推荐)

直接按以下步骤操作:

  1. 保持文件内容不变(已经包含有用的上下文信息)

  2. 按 Esc 键

  3. 输入 :wq 然后按回车(保存并退出)

2. 如果想自定义合并信息:

  1. 删除以 # 开头的注释行

  2. 在第一行写上有意义的合并说明,例如:

    复制

    下载

    合并远程'调整ui路径问题'分支的更新到本地分支
    
    这个合并包含了UI路径调整的相关修改,解决了路径冲突问题。
  3. 然后按 Esc,输入 :wq 保存退出

3. 如果想取消合并:

  1. 直接删除所有内容(使文件为空)

  2. 按 Esc,输入 :wq 保存退出

  3. Git 会中止合并操作

专业建议:

  • 合并提交信息应该说明为什么需要这次合并

  • 可以提及合并解决了哪些具体问题

  • 保持信息简洁但要有足够上下文

  • 如果是团队项目,可以加上相关issue或任务的编号

5.Git 子仓库(submodule)问题


 

本文地址:https://www.vps345.com/10381.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP docker 容器 运维 java-rabbitmq java 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 服务器 linux 游戏 云计算 网络工程师 网络管理 软考 2024 2024年上半年 下午真题 答案 Deepseek Deepseek-R1 大模型 私有化部署 推理模型 deepseek DeepSeek-R1 API接口 物联网 ubuntu 人工智能 redis 英语 Ollama Qwen2.5-coder 离线部署 DNS ddos android 网络安全 web安全 RTSP xop RTP RTSPServer 推流 视频 c语言 macos windows conda YOLO pytorch vscode python yolov5 django php 开发语言 javascript 前端 chrome edge 神经网络 深度学习 计算机视觉 卷积神经网络 llama 算法 opencv 自然语言处理 语言模型 阿里云 网络 网络协议 ssh CH340 单片机 嵌入式硬件 串口驱动 CH341 uart 485 centos gcc centos 7 tcp/ip ip协议 进程 操作系统 进程控制 Ubuntu 部署 pycharm ide nginx 负载均衡 tomcat 游戏引擎 学习 MCP 计算机外设 bug ai nlp 模型联网 API CherryStudio 开发环境 arm开发 架构 数据库 oracle 关系型 安全 分布式 vue.js spring boot https 笔记 网络结构图 harmonyos 华为 数据库系统 经验分享 jvm 虚拟机 学习方法 mysql adb springsecurity6 oauth2 授权服务器 前后端分离 asm gnu 高级IO epoll 目标跟踪 目标检测 OpenVINO 推理应用 fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse dify debian PVE kubernetes prometheus grafana 云原生 live555 rtsp rtp word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 typescript 计算机网络 node.js virtualenv 策略模式 c++ 机器学习 jenkins gitee 知识库 本地化部署 数据分析 自动化 ui vnc 后端 eureka outlook 错误代码2603 无网络连接 2603 apache jellyfin nas ffmpeg 音视频 视频编解码 pip fstab 智能路由器 外网访问 内网穿透 端口映射 并查集 leetcode udp 本地环回 bind 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 ubuntu 18.04 安装教程 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 科技 个人开发 ip 鸿蒙 USB转串口 mcu 课程设计 LDAP 虚拟现实 JAVA Java spring cloud kylin xcode ollama llm Alexnet Dify json 腾讯云 devops elasticsearch C# MQTTS 双向认证 emqx ue4 着色器 ue5 虚幻 cron crontab日志 大数据 spark hive git 思科 react.js 前端面试题 持续部署 github uni-app 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 transformer 机器人 kafka 运维开发 qt arm Doris搭建 docker搭建Doris Doris搭建过程 linux搭建Doris Doris搭建详细步骤 Doris部署 华为云 sublime text 编辑器 HarmonyOS Next websocket AI编程 集成学习 集成测试 媒体 vim pillow 小程序 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 spring UEFI Legacy MBR GPT U盘安装操作系统 TCP WebServer AI grub 版本升级 扩容 opengl QT 5.12.12 QT开发环境 Ubuntu18.04 进程优先级 调度队列 进程切换 多线程 cpu 内存 实时 使用 matplotlib fonts-noto-cjk Flask FastAPI Waitress Gunicorn uWSGI Uvicorn protobuf 序列化和反序列化 安装 yum docker-compose docker compose axure 富文本编辑器 pygame Ubuntu20.04 GLIBC 2.35 虚拟显示器 远程控制 Linux 维护模式 监控k8s集群 集群内prometheus windows 服务器安装 openvpn server openvpn配置教程 centos安装openvpn ssh漏洞 ssh9.9p2 CVE-2025-23419 EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 C 环境变量 进程地址空间 c# Linux PID 安卓模拟器 mac perf AI大模型 大模型技术 本地部署大模型 maven svn dubbo 面试 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 快捷键 旋转屏幕 自动操作 聚类 audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 compose zotero WebDAV 同步失败 代理模式 ubuntu20.04 Linux 开机黑屏 VMware AIGC 人工智能生成内容 数据结构 链表 flutter Google pay Apple pay iftop 网络流量监控 vite vue3 intellij idea 实时音视频 DevEco Studio rpc 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 vu大文件秒传跨域报错cors filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 开源 milvus 创意 社区 ruoyi VMware创建虚拟机 elk 远程工作 AI-native Docker Desktop 微信小程序 读写锁 open webui MacOS录屏软件 centos-root /dev/mapper yum clean all df -h / du -sh gpu算力 性能优化 串口服务器 大模型入门 大模型教程 GPU 缓存 sql 3d 数学建模 计算生物学 生物信息学 生物信息 基因组 stm32 bash GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 国产数据库 瀚高数据库 数据迁移 下载安装 golang 程序人生 http ESP32 camera Arduino 电子信息 华为od onlyoffice gitlab unity notepad unix vue wsl chatgpt oneapi 嵌入式 linux驱动开发 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 numpy hadoop cursor pdf iot 信息与通信 eclipse 热榜 deepseek-r1 大模型本地部署 指令 安卓 进程信号 1024程序员节 ros 话题通信 服务通信 智慧农业 开源鸿蒙 团队开发 灵办AI rag ragflow 大模型部署 Hyper-V WinRM TrustedHosts 离线部署dify 驱动开发 电脑 软件需求 华为认证 交换机 ssl flask oracle fusion oracle中间件 k8s rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK ecmascript nextjs react reactjs WSL2 上安装 Ubuntu 压测 ECS HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 多层架构 解耦 remote-ssh webdav vr GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 升级 CVE-2024-7347 漏洞 微信 微信分享 Image wxopensdk tcp odoo 服务器动作 Server action Dell R750XS ip命令 新增网卡 新增IP 启动网卡 Mac内存不够用怎么办 DeepSeek 统信 NFS vmware 卡死 C++ WSL2 Ubuntu22.04 虚拟化 开发人员主页 oceanbase 传统数据库升级 银行 MacMini Mac 迷你主机 mini Apple 虚拟局域网 redhat 温湿度数据上传到服务器 Arduino HTTP ipython 游戏程序 ios 多线程服务器 Linux网络编程 postman 测试工具 aws maxkb ARG WebUI DeepSeek V3 list rust rabbitmq fork wait waitpid exit YOLOv8 NPU Atlas800 A300I pro asi_bench Trae IDE AI 原生集成开发环境 Trae AI mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 硬件工程 嵌入式实习 efficientVIT YOLOv8替换主干网络 TOLOv8 Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 gpt Agent LLM CrewAI edge浏览器 html Cline python2 ubuntu24.04 VMware安装mocOS macOS系统安装 浪潮信息 AI服务器 CPU 主板 电源 网卡 网络药理学 生信 gromacs 分子动力学模拟 MD 动力学模拟 database SRS 流媒体 直播 Cursor dell服务器 IIS .net core Hosting Bundle .NET Framework vs2022 产品经理 agi microsoft burp suite 抓包 rancher linux内核 .netcore openEuler gateway Clion Nova ResharperC++引擎 Centos7 远程开发 区块链 powerpoint visual studio code C语言 rust腐蚀 webrtc intellij-idea 云电竞 云电脑 todesk lvm 磁盘挂载 磁盘分区 命令 jupyter VMware安装Ubuntu Ubuntu安装k8s nftables 防火墙 前端框架 jar shell 互信 vSphere vCenter 软件定义数据中心 sddc 私有化 本地部署 stm32项目 程序 编程 性能分析 ocr 大语言模型 LLMs java-ee jmeter 软件测试 远程桌面 rdp 远程服务 实时互动 matlab 7z 深度求索 私域 CPU 使用率 系统监控工具 linux 命令 IM即时通讯 QQ 企业微信 剪切板对通 HTML FORMAT 硬件架构 系统架构 TrueLicense 软件工程 软件构建 主从复制 etcd 数据安全 RBAC 远程连接 实验 Kali Linux 黑客 渗透测试 信息收集 报错 沙盒 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos ESXi 硬件 设备 PCI-Express ux 鲲鹏 昇腾 npu 开发 cuda CLion c/c++ 串口 YOLOv12 AutoDL Samba NAS 模拟实现 HCIE 数通 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap sysctl.conf vm.nr_hugepages nohup 异步执行 代码调试 ipdb adobe 视觉检测 文件系统 路径解析 db ubuntu24.04.1 源码剖析 rtsp实现步骤 流媒体开发 threejs 3D 压力测试 okhttp top Linux top top命令详解 top命令重点 top常用参数 MQTT协议 消息服务器 代码 图像处理 自动驾驶 firewalld netty Qualcomm WoS Python QNN AppBuilder 监控 自动化运维 远程看看 远程协助 直播推流 sqlite3 机柜 1U 2U Windsurf jdk .net DIFY chatbox npm mongodb 物联网开发 MQTT DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 bcompare Beyond Compare Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer springboot 高德地图 鸿蒙接入高德地图 HarmonyOS5.0 r语言 Cookie 云耀服务器 linux环境变量 gradle ragflow 源码启动 微服务 springcloud IO Reactor 设计模式 kind 雨云 NPS html5 css less 统信UOS 麒麟 bonding 链路聚合 匿名管道 命名管道 程序员 KylinV10 麒麟操作系统 Vmware 执法记录仪 智能安全帽 smarteye IPMI cudnn anaconda kali 共享文件夹 windows日志 OpenManus 版本 tar 键盘 GCC aarch64 编译安装 HPC 隐藏文件 隐藏目录 管理器 通配符 网易邮箱大师 HP Anyware linux安装配置 SSH Xterminal iBMC UltraISO 计算机 中兴光猫 换光猫 网络桥接 自己换光猫 嵌入式系统开发 miniapp 真机调试 调试 debug 断点 网络API请求调试方法 HiCar CarLife+ CarPlay QT RK3588 ros1 Noetic 20.04 apt 安装 go CentOS ollama下载加速 fpga开发 磁盘监控 内网渗透 靶机渗透 磁盘清理 鸿蒙系统 大模型微调 ROS2 端口号 开放端口 访问列表 rsyslog 设置代理 实用教程 状态管理的 UDP 服务器 Arduino RTOS WSL win11 无法解析服务器的名称或地址 智能手机 MS Materials postgresql file server http server web server retry 重试机制 镜像下载 freebsd 搜索引擎 x64 SIGSEGV SSE xmm0 frp 硅基流动 ChatBox GameFramework HybridCLR Unity编辑器扩展 自动化工具 权限 UOS 统信操作系统 LLM Web APP Streamlit n8n 工作流 mybatis DevOps 软件交付 数据驱动 应用场景 minicom 串口调试工具 回显服务器 UDP的API使用 飞牛nas fnos armbian u-boot log4j 交互 qps 高并发 ArkTs ArkUI xrdp RustDesk自建服务器 rustdesk服务器 docker rustdesk 软链接 硬链接 教程 环境搭建 Maven llama3 Chatglm 开源大模型 迁移指南 SWAT 配置文件 服务管理 网络共享 vscode1.86 1.86版本 ssh远程连接 5G 3GPP 卫星通信 环境迁移 mq rocketmq 服务器扩容没有扩容成功 Linux的权限 flash-attention ansible 宠物 毕业设计 免费学习 宠物领养 宠物平台 selenium 系统安全 burpsuite 安全工具 mac安全工具 burp安装教程 渗透工具 IIS服务器 IIS性能 日志监控 正则表达式 webstorm 强制清理 强制删除 mac废纸篓 WLAN 视频平台 录像 视频转发 性能测试 视频流 存储 nvm Docker Hub docker pull 镜像源 daemon.json 矩阵 VSCode gitea CosyVoice 监控k8s 监控kubernetes playbook 剧本 FTP 服务器 su sudo 客户端 zip unzip 博客 ebpf uprobe 无人机 程序员创富 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 ROS PX4 MAVROS 四旋翼无人机 AI写作 clickhouse 工业4.0 爬虫 数据集 KingBase xml 客户端与服务端通信 WebVM 基础环境 网络爬虫 流水线 脚本式流水线 工具 ufw v10 软件 智能体 autogen openai coze vmamba Kylin-Server 国产操作系统 服务器安装 数据挖掘 弹性计算 云服务器 裸金属服务器 弹性裸金属服务器 express p2p kotlin android studio iphone 远程 执行 sshpass 操作 c Ubuntu共享文件夹 共享目录 Linux共享文件夹 信号 内核 dns googlecloud 显示器 进程程序替换 execl函数 execv函数 execvp函数 execvpe函数 putenv函数 curl wget linux上传下载 arkUI JDK LInux Windows Web服务器 多线程下载工具 网络编程 PYTHON mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 RAGFLOW 自动化编程 openwrt 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 VMware Tools vmware tools安装 vmwaretools安装步骤 vmwaretools安装失败 vmware tool安装步骤 vm tools安装步骤 vm tools安装后不能拖 vmware tools安装步骤 安装MySQL zabbix mariadb ros2 moveit 机器人运动 服务器配置 termux 高效I/O ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 selete yolov8 firefox Mermaid 可视化图表 自动化生成 kamailio sip VoIP wireshark 显示过滤器 ICMP Wireshark安装 大数据平台 copilot iperf3 带宽测试 毕设 全文检索 图搜索算法 系统 黑苹果 环境配置 通信工程 毕业 rime sqlserver systemctl ci/cd composer 低代码 网络用户购物行为分析可视化平台 大数据毕业设计 alias unalias 别名 rc.local 开机自启 systemd 实战案例 功能测试 自动化测试 openstack Xen KVM asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 Docker Compose mysql离线安装 ubuntu22.04 mysql8.0 ping++ Ubuntu 22.04 MySql 算家云 算力租赁 Termux 拓扑图 Chatbox 僵尸进程 Invalid Host allowedHosts TRAE 银河麒麟 samba Hive环境搭建 hive3环境 Hive远程模式 一切皆文件 nac 802.1 portal diskgenius 计算机系统 next.js 部署next.js MCP server C/S Redis Desktop 框架搭建 Mac软件 政务 分布式系统 监控运维 Prometheus Grafana yaml Ultralytics 可视化 H3C 中间件 iis 移动云 安防软件 宝塔面板无法访问 云服务 大屏端 大模型应用 shell脚本免交互 expect linux免交互 tcpdump harmonyOS面试题 云桌面 微软 AD域控 证书服务器 seatunnel 腾讯云大模型知识引擎 个人博客 浏览器自动化 SSH 密钥生成 SSH 公钥 私钥 生成 unity3d kylin v10 麒麟 v10 图文教程 VMware虚拟机 macOS系统安装教程 macOS最新版 虚拟机安装macOS Sequoia 云原生开发 K8S k8s管理系统 王者荣耀 Linux的基础指令 visual studio glibc 豆瓣 追剧助手 迅雷 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 网工 反向代理 服务器主板 AI芯片 CUPS 打印机 Qt5 MI300x springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 excel CORS 跨域 工具分享 autoware make命令 makefile文件 openjdk 华为OD 华为OD机试真题 可以组成网络的服务器 双系统 GRUB引导 Linux技巧 大文件秒传跨域报错cors cpp-httplib 镜像 消息队列 用户缓冲区 游戏服务器 TrinityCore 魔兽世界 zerotier 支付 微信支付 开放平台 京东云 信号处理 uv lio-sam SLAM fd 文件描述符 vasp安装 wps web stable diffusion 能力提升 面试宝典 技术 IT信息化 新盘添加 partedUtil nvidia 生活 cocoapods 自学笔记 小米 澎湃OS Android code-server SVN Server tortoise svn 群晖 文件分享 多进程 pppoe radius SenseVoice Node-Red 编程工具 流编程 雨云服务器 minio 办公自动化 pdf教程 rnn Kali 渗透 安全威胁分析 mamba Vmamba fast 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 workflow echarts 信息可视化 网页设计 linuxdeployqt 打包部署程序 appimagetool ftp服务 文件上传 图片增强 增强数据 HarmonyOS Tabs组件 TabContent TabBar TabsController 导航页签栏 滚动导航栏 saltstack Attention NLP 相差8小时 UTC 时间 laravel risc-v RAG 检索增强生成 文档解析 大模型垂直应用 虚拟机安装 arcgis 三级等保 服务器审计日志备份 kernel trea idea React Next.js 开源框架 联想开天P90Z装win10 web3.py 模拟器 加解密 Yakit yaklang bootstrap pyautogui EMQX 通信协议 ShenTong 国产化 DBeaver 医疗APP开发 app开发 其他 开机自启动 RTMP 应用层 bot Docker 线程 宕机切换 服务器宕机 分子对接 autodock mgltools PDB PubChem 代理 孤岛惊魂4 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? 音乐服务器 Navidrome 音流 es6 qt6.3 g726 java-zookeeper ollama api ollama外网访问 Minecraft opcua opcda KEPServer安装 宝塔 Kubernetes DOIT 四博智联 Linux find grep IMM 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 数码 联机 僵尸毁灭工程 游戏联机 开服 idm DeepSeek r1 Open WebUI cd 目录切换 代理服务器 多端开发 智慧分发 应用生态 鸿蒙OS tensorflow 树莓派 VNC 可信计算技术 密码学 AD域 thingsboard NLP模型 单例模式 宝塔面板 笔灵AI AI工具 安全架构 蓝桥杯 iDRAC R720xd 域名服务 DHCP 符号链接 配置 powerbi Obsidian Dataview apt 国内源 日志分析 系统取证 Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 自定义客户端 SAS dba XFS xfs文件系统损坏 I_O error 单元测试 visualstudio xpath定位元素 bat python3.11 Claude Desktop Claude MCP Windows Cli MCP 服务器繁忙 源代码 跨平台 kvm conda配置 conda镜像源 图形化界面 换源 Debian pyicu 智能电视 linux 命令 sed 命令 FunASR ASR RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 蓝桥杯C++组 职场和发展 Linux权限 权限命令 特殊权限 X11 Xming 管道 MAC SecureCRT 命令行 基础入门 prompt easyui langchain AimRT 流式接口 wsl2 稳定性 看门狗 Typore SSH 服务 SSH Server OpenSSH Server Wi-Fi trae Spring Security k8s部署 MySQL8.0 高可用集群(1主2从) EasyConnect AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 自动化任务管理 SysBench 基准测试 推荐算法 css3 ssrf 失效的访问控制 Ardupilot 蓝耘科技 元生代平台工作流 ComfyUI vpn Docker快速入门 大版本升 升级Ubuntu系统 Isaac Sim 虚拟仿真 jetty undertow yum源切换 更换国内yum源 金仓数据库 2025 征文 数据库平替用金仓 openssl 文心一言 深度优先 图论 并集查找 换根法 树上倍增 Office 语音识别 Xinference RAGFlow 分析解读 MNN Qwen sublime text3 SSL证书 ftp 交叉编译 远程过程调用 Windows环境 免费域名 域名解析 Netty 即时通信 NIO docker命令大全 gaussdb llama.cpp 边缘计算 DocFlow ubuntu24 vivado24 Dell HPE 联想 浪潮 数据可视化 initramfs Linux内核 Grub ELF加载 Linux环境 相机 思科模拟器 Cisco nuxt3 测试用例 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 小艺 Pura X AI作画 聊天室 cmake localhost 动静态库 飞牛 HistoryServer Spark YARN jobhistory 华为证书 HarmonyOS认证 华为证书考试 银河麒麟服务器操作系统 系统激活 ShapeFile GeoJSON Nginx 影刀 #影刀RPA# 算力 服务器管理 配置教程 网站管理 微信公众平台 VPN wireguard muduo AnythingLLM AnythingLLM安装 Ark-TS语言 社交电子 实习 VR手套 数据手套 动捕手套 动捕数据手套 Socket 大模型面经 大模型学习 服务器部署 本地拉取打包 qemu libvirt 直流充电桩 充电桩 微信开放平台 微信公众号配置 远程登录 telnet rpa 服务器时间 SEO 输入法 LVM lvresize 磁盘扩容 pvcreate 磁盘 空间 查错 av1 电视盒子 机顶盒ROM 魔百盒刷机 显示管理器 lightdm gdm cnn DenseNet cmos vscode 1.86 网站搭建 serv00 neo4j 数据仓库 数据库开发 网络攻击模型 Nuxt.js 电视剧收视率分析与可视化平台 重启 排查 系统重启 日志 原因 lighttpd安装 Ubuntu配置 Windows安装 服务器优化 7-zip nacos 实时内核 banner can 线程池 nohup后台启动 keepalived Webserver 异步 考试 sonoma 自动更新 CNNs 图像分类 scapy NAT转发 NAT Server Echarts图表 折线图 柱状图 异步动态数据 鸿蒙开发 可视化效果 网络穿透 grep chrome devtools chromedriver ssh远程登录 HarmonyOS NEXT 原生鸿蒙 virtualbox rustdesk 常用命令 文本命令 目录命令 sudo原理 su切换 网卡的名称修改 eth0 ens33 毕昇JDK ArcTS 登录 ArcUI GridItem 小智 致远OA OA服务器 服务器磁盘扩容 服务网格 istio 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 js 游戏机 iTerm2 终端 export env 变量 行情服务器 股票交易 速度慢 切换 股票量化接口 股票API接口 docker run 数据卷挂载 交互模式 micropython esp32 mqtt 论文阅读 系统开发 binder 车载系统 framework 源码环境 deep learning 半虚拟化 硬件虚拟化 Hypervisor k8s集群资源管理 Web应用服务器 scikit-learn 端口测试 模拟退火算法 田俊楠 Reactor反应堆 mosquitto dash 软件卸载 系统清理 OpenHarmony etl 蓝牙 本地部署AI大模型 多产物 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 技能大赛 业界资讯 dity make NVML nvidia-smi RAID RAID技术 eNSP 网络规划 VLAN 企业网络 UDP UOS1070e 联网 easyconnect 图形渲染 代码托管服务 网络文件系统 小游戏 五子棋 pyside6 界面 sdkman umeditor粘贴word ueditor粘贴word ueditor复制word ueditor上传word图片 ueditor导入word ueditor导入pdf ueditor导入ppt 免密 公钥 私钥 AISphereButler hibernate import save load 迁移镜像 ajax CentOS Stream ukui 麒麟kylinos openeuler perl W5500 OLED u8g2 TCP服务器 chfs ubuntu 16.04 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm Linux Vim searxng FTP服务器 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 Carla 智能驾驶 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 火绒安全 VPS firewall cfssl 源码 Pyppeteer Playwright 产测工具框架 IMX6ULL 管理框架 桌面环境 混合开发 环境安装 ArkTS 移动端开发 考研 在线office 玩游戏 WebRTC uniapp 恒源云 P2P HDLC webgl OD机试真题 服务器能耗统计 健康医疗 互联网医院 DeepSeek行业应用 Heroku 网站部署 big data 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 opensearch helm 大模型训练/推理 推理问题 mindie chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 聊天服务器 套接字 智能音箱 智能家居 IPMITOOL BMC 硬件管理 lb 协议 token sas rclone AList fnOS 强化学习 macbook XCC Lenovo 向日葵 ceph beautifulsoup 繁忙 解决办法 替代网站 汇总推荐 AI推理 AI代码编辑器 CDN 服务器数据恢复 数据恢复 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 邮件APP 免费软件 embedding 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 银河麒麟操作系统 显卡驱动 Ubuntu Server Ubuntu 22.04.5 wsgiref Web 服务器网关接口 nfs 服务器部署ai模型 SSL 域名 skynet gpt-3 飞牛NAS 飞牛OS MacBook Pro 终端工具 远程工具 代码规范 机架式服务器 1U工控机 国产工控机 Jellyfin 同步 备份 建站 Linux24.04 deepin LORA safari netlink libnl3 阻塞队列 生产者消费者模型 服务器崩坏原因 金融 MobaXterm 文件传输 历史版本 下载 容器技术 序列化反序列化 jina Xshell IPv4 子网掩码 公网IP 私有IP Kylin OS java-rocketmq api pyqt ruby 内网环境 计算机科学与技术 黑客技术 底层实现 URL mac设置host 文件存储服务器组件 对比 meld DiffMerge open Euler dde gunicorn 用户管理 ubuntu安装 linux入门小白 项目部署 wpf navicat Charles 崖山数据库 YashanDB NVM Node Yarn PM2 GRE 打不开xxx软件 无法检查其是否包含恶意软件 arkTs 软负载 锁屏不生效 NFC 近场通讯 智能门锁 信创 信创终端 中科方德 商用密码产品体系 sentinel Alist mount 挂载 网盘 搭建个人相关服务器 端口 查看 ss midjourney deployment daemonset statefulset cronjob 无桌面 做raid 装系统 数据采集 Crawlee g++ g++13 Radius 佛山戴尔服务器维修 佛山三水服务器维修 swoole 我的世界服务器搭建 minecraft wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 WireGuard 异地组网 glm4 运维监控 材料工程 可用性测试 k8s二次开发 集群管理 多个客户端访问 IO多路复用 TCP相关API word 干货分享 黑客工具 密码爆破 IMX317 MIPI H265 VCU VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 GPU训练 达梦 DM8 流量运营 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 钉钉 进程间通信 IDEA 录音麦克风权限判断检测 录音功能 录音文件mp3播放 小程序实现录音及播放功能 RecorderManager 解决录音报错播放没声音问题 Trae叒更新了? 端口聚合 windows11 tailscale derp derper 中转 autodl 裸机装机 linux磁盘分区 裸机安装linux 裸机安装ubuntu 裸机安装kali 裸机 triton 模型分析 线性代数 电商平台 单一职责原则 vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 可执行程序 嵌入式Linux IPC 抓包工具 System V共享内存 进程通信 photoshop Unity Dedicated Server Host Client 无头主机 EMUI 回退 降级 欧标 OCPP 软件开发 信任链 语法 lua docker desktop image NVIDIA 源代码管理 qt5 客户端开发 网络建设与运维 ECT转485串口服务器 ECT转Modbus485协议 ECT转Modbus串口服务器 音乐库 iventoy VmWare OpenEuler 内存管理 开源软件 mysql安装报错 windows拒绝安装 僵尸世界大战 游戏服务器搭建 es c/s docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 kubeless 星河版 vsxsrv GIS 遥感 WebGIS crosstool-ng post.io 企业邮箱 搭建邮箱 MDK 嵌入式开发工具 论文笔记 显卡驱动持久化 GPU持久化 Qwen3 qwen3 32b vllm 技术共享 企业网络规划 华为eNSP 我的世界 我的世界联机 Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 查看显卡进程 fuser client-go ArtTS ISO镜像作为本地源 IO模型 游戏开发 deekseek comfyui comfyui教程 SystemV 大模型压力测试 EvalScope IPv6 IPv6测试 IPv6测速 IPv6检测 IPv6查询 负载测试 GeneCards OMIM TTD massa sui aptos sei MacOS 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 Erlang OTP gen_server 热代码交换 事务语义 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 子系统 hugo csrf AI员工 dns是什么 如何设置电脑dns dns应该如何设置 xss Ubuntu 24.04.1 轻量级服务器 win服务器架设 windows server AI agent 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 分布式训练 机械臂 知识图谱 rtc 券商 股票交易接口api 类型 特点 Python基础 Python教程 Python技巧 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 状态模式 授时服务 北斗授时 docker部署Python Helm k8s集群 qt项目 qt项目实战 qt教程 docker search Qwen2.5-VL VS Code hosts VGG网络 卷积层 池化层 Claude 冯诺依曼体系 nosql hexo ecm bpm 小智AI服务端 xiaozhi TTS AD 域管理 resolv.conf figma hdc 增强现实 沉浸式体验 技术实现 案例分析 AR 智能体开发 web3 区块链项目 GoogLeNet rsync xshell termius iterm2 IPv4/IPv6双栈 双栈技术 网路规划设计 ensp综合实验 IPv4过渡IPv6 IPv4与IPv6 HTTP 服务器控制 ESP32 DeepSeek 虚幻引擎 备选 网站 调用 示例 问题解决 csrutil mac恢复模式进入方法 恢复模式 USB网络共享 Sealos 弹性服务器 查询数据库服务IP地址 SQL Server 浏览器开发 AI浏览器 极限编程 合成模型 扩散模型 图像生成 iNode Macos 烟花代码 烟花 元旦 智能合约 哈希算法 性能调优 安全代理 本地知识库部署 DeepSeek R1 模型 sqlite pthread pgpool 移动开发 react native 捆绑 链接 谷歌浏览器 youtube google gmail 网络搭建 神州数码 神州数码云平台 云平台 银河麒麟高级服务器 外接硬盘 Kylin flink WINCC 网页服务器 web服务器 桥接模式 windows虚拟机 虚拟机联网 电路仿真 multisim 硬件工程师 硬件工程师学习 电路图 电路分析 仪器仪表 kerberos xfce 服务器ssl异常解决 配置原理 prometheus数据采集 prometheus数据模型 prometheus特点 PPI String Cytoscape CytoHubba 超融合 内网服务器 内网代理 内网通信 Zoertier 内网组网 需求分析 规格说明书 whistle TCP协议 抗锯齿 postgres Dify重启后重新初始化 deepseak 豆包 KIMI 腾讯元宝 多路转接 regedit 开机启动 chromium dpi 飞书 Logstash 日志采集 servlet ranger MySQL8.0 银河麒麟桌面操作系统 玩机技巧 软件分享 软件图标 OpenCore shard 动态规划 dock 加速 IP配置 netplan Headless Linux proxy模式 程序化交易 量化交易 高频交易 webpack zookeeper Apache Beam 批流统一 案例展示 数据分区 容错机制 OpenSSH Anolis nginx安装 linux插件下载 移动魔百盒 根服务器 ldap IP 地址 llamafactory 微调 junit 软考设计师 中级设计师 SQL 软件设计师 分布式账本 共识算法 ai工具 阿里云ECS 项目部署到linux服务器 项目部署过程 架构与原理 deepseek r1 安全漏洞 信息安全 seleium EVE-NG h.264 支持向量机 卸载 列表 粘包问题 Bug解决 Qt platform OpenCV 搜狗输入法 中文输入法 tidb node Masshunter 质谱采集分析软件 使用教程 科研软件 百度云 矩池云 数据下载 数据传输 brew AI Agent 字节智能运维 火山引擎 框架 yashandb Maxkb RAG技术 本地知识库 pycharm安装 Putty 花生壳 RK3568 ACL 流量控制 基本ACL 规则配置 EMC存储 NetApp存储 充电桩平台 充电桩开源平台 RDP mvc AzureDataStudio qwen2vl 免费 物理地址 页表 虚拟地址 Unity插件 数字证书 签署证书 接口优化 桌面快捷方式 元服务 应用上架 华为机试 带外管理 解决方案 静态IP linux子系统 忘记密码 服务器正确解析请求体 风扇控制软件 李心怡 fiddler mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 金仓数据库概述 金仓数据库的产品优化提案 计算虚拟化 弹性裸金属 finebi yum换源 创业创新 MVS 海康威视相机 solr easyTier 组网 PyQt PySide6 线程同步 线程互斥 条件变量 mybase 飞腾处理器 solidworks安装 计算机学习路线 编程语言选择 lrzsz ABAP authing UFW sequoiaDB 存储维护 海康 大模型推理 输入系统 设备树 网络原理 华为鸿蒙系统 ArkTS语言 Component 生命周期 条件渲染 Image图片组件 西门子PLC 通讯 watchtower macOS 北亚数据恢复 oracle数据恢复 Qt QModbus mcp服务器 client close Python 视频爬取教程 Python 视频爬取 Python 视频教程 HAProxy ardunio BLE 大大通 第三代半导体 碳化硅 paddle 电脑桌面出现linux图标 电脑桌面linux图标删除不了 电脑桌面Liunx图标删不掉 linux图标删不掉 logstash pythonai PlaywrightMCP MinIO webview 知行EDI 电子数据交换 知行之桥 EDI 设计规范 caddy vCenter服务器 ESXi主机 监控与管理 故障排除 日志记录 CAD瓦片化 栅格瓦片 矢量瓦片 Web可视化 DWG解析 金字塔模型 gru d3d12 跨域请求 Linux的基础开发工具 STL 命令模式 vm 零售 VM虚拟机 element-ui 上传视频并预览视频 vue上传本地视频及进度条功能 vue2选择视频上传到服务器 upload上传视频组件插件 批量上传视频 限制单个上传视频 脚本 三次握手 homeassistant 鸿蒙NEXT 网络库 DrissionPage 向量数据库 安装部署 milvus安装 archlinux kde plasma AWS 华为昇腾910b3 android-studio web开发 hosts文件管理工具 cocos2d 3dcoat Github加速 Mac上Github加速 Chrome浏览器插件 #STC8 #STM32 win向maOS迁移数据 finalsheel 教育电商 anythingllm open-webui docker国内镜像 cpolar PTrade QMT 量化股票 deepseek-v3 ktransformers 进程池实现 ECS服务器 欧拉系统 接口返回 匿名FTP 邮件传输代理 SSL支持 chroot监狱技术 qtcreator gitee go 数据库管理 bigdata OS fpga GRANT REVOKE pxe Metastore Catalog aac harmonyosnext