- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
关于强制 git push
的问题和答案并不难找到(here 是 two)。标准答案是这样的:
If you have to force a
git push
, technically you can with the--force
option, but procedurally you shouldn't because someone may have already pulled and somewhere a kitten will die.
我认为这通常是明智的建议 - 更安全的方法是再次提交,修复你破坏的任何东西。但是,比方说,我知道(神奇地)还没有人撤回提交。或者更妙的是,这是一个私有(private)仓库,因此一开始就没有破坏任何其他人的克隆的危险。
--force
推送是否有任何其他[负面]后果,特别是技术后果?也许它会在远程中导致一些额外的垃圾,或者它破坏了 X Corps 分析工具的 1.2.3 版,或者它使以后的 rebase 变得更加困惑,等等。有什么吗?
编辑 1: 我有自己的轶事证据表明 --force
推送私有(private)仓库 似乎造成任何问题。不过,我对感知不感兴趣。我正在寻找此类引用资料和/或证据。
最佳答案
为了补充 torek 的出色回答:
强制推送可能会导致以后的 merge 出现问题。
问题:
如果你强制推送一个分支 A,你将从该分支中删除一些现有的提交(否则你不需要强制)。如果(如 torek 的回答中所述)这些提交也被另一个分支 B 引用,那么它们将保留在该分支中。如果稍后 merge 两个分支 A 和 B,A 将包含"new"(强制)提交,B 将包含“旧”提交。
在这种情况下,git merge
可能不会执行您想要的操作。在最好的情况下,您将遇到 merge 冲突。最坏的情况是,你不会,但结果仍然是错误的。例如,如果您使用 git rebase -i
从 A 中删除了提交 c1,如果 c1 也在 B 中,则如果您 merge A 和 B,它将被重新引入。这可能会默默地重新引入 a错误:-(。
因此,如果您强制推送,请确保您删除的提交未被其他分支/标签引用(或者也强制推送这些分支/标签)。
已删除提交“返回”的图示
运行下面的 bash 脚本。该脚本创建一个 git 存储库,并使用以下提交分支 master、branch1:
然后它:
git reset --hard
丢弃来自 master 的“错误提交”脚本输出:
Initialized empty Git repository in ....
[... creating commits ...]
### Bad commit in history:
* 7549dcc (HEAD, master) bad commit
* 31afec8 Initial
### Removing bad commit:
HEAD is now at 31afec8 Initial
### Bad commit no longer in history:
31afec8 (HEAD, master) Initial
### Merging branch1:
Updating 31afec8..be801e5
Fast-forward
0 files changed, 0 insertions(+), 0 deletions(-)
create mode 100644 b
create mode 100644 c
### Bad commit is back!
be801e5 (HEAD, master, branch1) good commit
7549dcc bad commit
31afec8 Initial
如您所见,使用 git reset --hard
从 master 中删除了“错误提交”。但是,“bad commit”仍然包含在branch1中,所以当branch1 merge 到master时,“bad commit”返回。
注意:此示例实际上并未强制推送,但如果您使用上游存储库,则必须在删除错误提交后强制推送 - 结果是相同的。
脚本:
#!/bin/bash
set -e
if [ -e gitrepo ]; then echo "Please remove gitrepo"; exit 1; fi
git init gitrepo; cd gitrepo; git config core.pager cat
touch a; git add a; git commit -m Initial
touch b; git add b; git commit -m "bad commit"
git checkout -b branch1; touch c; git add c; git commit -m "good commit"
git checkout master
echo "### Bad commit in history: "
git log --oneline --decorate
echo "### Removing bad commit: "
git reset --hard HEAD~1
echo "### Bad commit no longer in history: "
git log --oneline --decorate
echo "### Merging branch1: "
git merge branch1
echo "### Bad commit is back!"
git log --oneline --decorate
关于git - `git push --force` 的其他后果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21259585/
我试图理解两者之间的区别 git push --force 和 git push --force-with-lease 我的猜测是后者只推送到远程如果远程提交了本地分支没有? 最佳答案 force 用
我在将项目发布到本地系统时收到此错误 Copying file obj\Debug\build.force to obj\Release\Package\PackageTmp\obj\Debug\bu
这个例子的描述:http://bl.ocks.org/mbostock/4062045 (见下图),声明它是“带电粒子和 Spring 的物理模拟,使相关 Angular 色更接近。” 我只是好奇该代
请不要标记重复的问题。 大家好, 我正在执行 NSURLAuthenticationMethodClientCertificate,我在其中使用以下代码。如果我不使用 swiftlint,哪个代码没问
我似乎无法删除文件/文件夹,而无需为所有人输入 [A]。我错过了什么? Get-Childitem "C:\Users\*\AppData\Local\Temp\*" -ErrorAction S
我一直在尝试编写在 Streams 上运行的程序和它们的属性,但我觉得即使是最简单的事情我也被困住了。当我在标准库的 Codata/Streams 中查看 repeat 的定义时,我发现了一个我在 A
我正在尝试使用 symfony2 创建一个下载文件的链接。它确实下载了一个文件,但它没有用,因为它是零八位字节。我不知道如何让它工作。有人知道怎么做吗? 文件位于web/uploads/documen
我需要为MySQLd打开网络,但是每次这样做,服务器都会被强行淘汰。一些卑鄙的密码猜测脚本开始在服务器上运行,在端口3306上打开连接并永久尝试随 secret 码。 我该如何阻止这种情况的发生? 对
Azure Functions 是否可以强制通过 HTTPS 进行连接? 我没有在应用程序设置中看到它,也没有看到任何对 Azure Functions 的 web.config 的引用。 最佳答案
我正在使用 Firebird 数据库并正在尝试以下 sql,但每次它返回 0,而不是 0.61538(等等)。 SELECT (COUNT(myfield)/26) totalcount FROM m
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我想要一个永远未定义的属性: var foo = {bar:undefined} 如果有人稍后尝试更改属性栏,那么它也应该导致未定义。 foo.bar = 'someValue'// foo.bar/
我有课,Target无法更改,具有通用约束。我想从没有约束的泛型类中构建该类的实例。下面演示了我想要做的事情的意图,但我意识到这段代码将无法编译并且 typeof(T).IsClass是运行时检查,通
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
假设我在包中编写了一个类,名为 mypackage.myclass。我已经为包和类编写了自己的 HTML 文档,并将其包含在 MATLAB 帮助浏览器中,如 the MATLAB documentat
我们有一个多平台项目,它为几个平台生成二进制文件,比如 mac、windows、linux...是否可以强制 git 将所有文件的编码更改为某个特定平台(例如:Linux)。那么如何在每次用户提交或推
我正在使用 MSBuild 自动为标签创建一个文本文件和一个 ZIP 文件。我的 MSBuild 项目由 CruiseControl.NET 调用. 文本文件总是latest.txt,ZIP 文件是(
根据我的一些 API 规范: Force to place an Auth transaction into the current batch (PostAuth) or to place a tr
我正在使用超集 0.20.4 如果我想在我的 URL 中添加一个 token 以自动登录到特定用户超集/仪表板/3?standalone=true&token=123456789 我应该在代码的哪个位
我有一个大问题:我有一个 listview,每个项目都链接到页面 #concorsi。当我单击链接时,URL 会变为 #concorsi?numero=1,因为我正在从 JSON 中获取表单编号 1。
我是一名优秀的程序员,十分优秀!