- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我刚开始使用git,所以我需要将文件从master分支推送到另一个分支,以便在发生错误时进行备份,然后继续处理master分支。在Git Bash我该怎么做?
最佳答案
git不推送文件;git推送提交。提交包含文件,因此效果类似,但记住这一点很重要:存储库要么有提交(然后有每个文件的快照),要么没有提交(然后没有这些快照)。
要将master
上的提交推送到另一个git存储库(您称之为origin
)-但让另一个存储库知道它们的名称而不是它的master
,可以执行以下操作:
git push origin master:some-new-branch-name
origin
上向他们发送git—任何您拥有的、他们不需要(但确实需要)的提交。然后它向他们发送一个礼貌的请求:请设置名为
some-new-branch-name
的分支,以便它记住我调用的提交。
master
。如果愿意,可以使用以下命令查看原始哈希ID:
git rev-parse master
git fetch origin
master
。这是您git的原始git分支名称的副本。如果你跑步:
git log --all --decorate --oneline --graph
origin/some-new-branch-name
完全相同的提交。
some-new-branch-name
这样的分支名称只是作为起点:您的git将您的名称
master
转换为一个大而难看的hash id,并使用它来查找最后一次提交。最后一次提交具有其前一次提交或父次提交的丑陋哈希ID,因此从最后一次提交开始,Git可以向后退一步。parent commit存储另一个父散列id,这样git就可以从父散列id向后移动一步。该提交还有另一个父ID:
... <-F <-G <-H ...
master
,git可以读取提交并获取其父id,然后读取
master
并获取另一个父id,它可以使用该id读取
H
,依此类推。分支就是这样的:它只是一系列提交,由哈希ID向后排列,分支名称指向系列中的最后一个。如果
G
是最后一次提交,则序列如下:
...--F--G--H <-- master
F
允许git查找commit
H
。它让您的git找到
master
,然后找到
H
,依此类推。
G
添加一个新的提交时,git真正做的是写出一个新的提交(带有一些新的随机散列id),其父级是commit
F
。然后git将新提交的hash id(我们称之为
master
)写入名称
H
,现在您有:
...--F--G--H--I <-- master
I
,Git只是创建这个名字,指向一些现有的提交。默认情况下,新名称的提交是当前提交:
...--F--G--H--I <-- master, some-new-branch-name
master
的含义。如果您有多个分支名称,那么git如何知道在进行新提交时要更新哪个名称?答案是:git将特殊名称
some-new-branch-name
附加到一个分支名称。这是进行新提交时要更新的名称。所以我们应该把它画成:
...--F--G--H--I <-- master (HEAD), some-new-branch-name
...--F--G--H--I <-- master, some-new-branch-name (HEAD)
HEAD
选择的分支名称。当前提交是(的实际哈希ID)
HEAD
;当前分支名称是附加到的名称。
git checkout
创建一个新的分支名称,如果需要,提交(如果您希望先将更改添加到另一个分支,如果更合适,请先提交)。以前的分支名称现在会记住上次提交的哈希ID,而新的分支名称会记住您进行的任何新提交的哈希ID:
...--F--G--H--I <-- master
\
J--K <-- some-new-branch-name (HEAD)
I
的提交在两个分支上。)
关于git - 如何将文件从master分支推送到另一个分支?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57321871/
我在 2 个不同的节点中设置了 master-master mysql 复制。假设如果我要再添加一个节点,即 3rd master ,我是否需要在新服务器中拥有与节点 1 和节点 2 中完全相同的数据
我认为我在理解 git 的基本概念方面是正确的。 我已经设置并克隆了一个远程存储库。我还创建了一个服务器端空存储库,并将我的本地存储库链接到它。 我的问题是我不明白: origin/master 与
从概念上讲,Master-Master 复制是如何工作的? 我认为碰撞将是一种需要以某种方式解决的常见事件。 最佳答案 主-主复制(更一般地——多主复制)在概念上的工作原理是假设冲突并不常见,并且只保
众所周知,mysql 是异步复制的。我听说我需要一些额外的插件来做 同步复制。 那么让我们考虑一下异步复制的情况:master 将事件写入其二进制日志,但不知道 master2 是否或何时检索并处理了
我正在寻求有关 MySql Master-Master 配置问题的帮助。 我正在处理由另一名员工设置的服务器配置,该员工现在无法就此事提供任何帮助。这是我第一次体验这样的设置,在做了相当多的研究之后,
尝试使用 HADOOP 运行 HBASE 时出现以下错误HBASE 0.98.xHADOOP 2.4.0 ERROR [main] master.HMasterCommandLine: Mas
停止独立 Spark Master 失败并显示以下消息: $ ./sbin/stop-master.sh no org.apache.spark.deploy.master.Master to sto
我不确定这是否是一个正常的分支场景,但是...... 假设我从 master 创建一个分支,比如分支 C,然后 merge 回其他先前存在的分支,比如分支 A 和 B,回到 master,然后我需要分
我无法推送到我的 git 存储库。 git clone和 git pull工作正常,但 git push不起作用。 我检查了其他答案,如 here尝试了几种方法,例如 git push origin
所以如果我在 master 中做: git checkout -b my-branch 并在那里做几次提交+推送。然后我做: git checkout master git pull 我现在能以某种方
我设置了 2 个 MYSQL 服务器: my.cnf server1: auto_increment_increment = 2 auto_increment_offset = 1 my.cnf se
我想知道一个服务器是否可以同时是slave和master。我们的问题是我们有很多移动单元需要同步到主服务器,但它们只需要主服务器上 100 个表中的 6 个。除了延迟同步和增加数据成本之外,所有额外的
我有主-主 Mysql 复制。每个主控复制其他主控。谁能解释一下为什么该主机上的 log-bin 文件不同? (尺寸差异很小)。谢谢! 最佳答案 嗯。我们决定使用 mysql 5.6 及其功能 - G
我正在努力理解这里的逻辑,如果术语不正确,我深表歉意。 我正在尝试构建一个功能类似于邮件的应用程序,IE: 所有邮箱 > 特定邮箱 > 消息 其中“所有邮箱”和“特定邮箱”占据 Controller
我一直在使用 master 分支进行开发,并希望将其清除为只有发布提交,以及它的用途。如何将所有内容从 master 复制到开发分支,然后重新启动 master? 最佳答案 Create develo
两周前,我创建了一个新分支,我们称它为exp。在此期间,exp 和 master 中都有几次提交。在此期间,exp 尚未更新 master 的更改 现在我想把所有从 exp 到 master 的更改都
我克隆:https://github.com/vy2014/git_lesson.git 然后我做了一些改动,尝试通过命令git push推送到远程服务器,但是错误: Counting objects
有没有好的方法来解释如何在 Git 中解决“![rejected] master -> master (fetch first)'”? 当我使用此命令时 $ git push origin maste
我该怎么办: 1)恢复推送到主(远程)的更改 2)将这些更改移动到单独的分支 3) 稍后将这些更改移回 master 最佳答案 首先做 2),但前提是你真的需要分支。 git branch chang
符号上有什么区别? 在我的一个工作站上,我克隆的 git 存储库显示(master),而另一个工作站则显示(master -> origin) 我还创建了一个新的本地存储库,提交了一个文本文件,提示仍
我是一名优秀的程序员,十分优秀!