- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
在我的工作场所,我们使用 SVN 进行版本控制。当我发现它时,我切换到 git-svn,最近我决定将我的一些私有(private)分支同步到另一个远程 git 仓库。然后,工作流程包括通过 git-svn 从 SVN 存储库 rebase 并推送到 SVN 存储库,同时处理被推送到远程 git 存储库的单独的私有(private)功能分支,以便我可以在必要时在家处理它们。
现在,每次我从 git-svn rebase 时,我的远程 git 存储库都会要求首先被 pull 。有时,在进行 pull 时,更改不会完全 merge ,即使据推测,远程仓库应该包含与我与 svn 同步的本地仓库相同的提交。最近我求助于删除远程分支,然后再将它们再次推送到远程仓库,但这是不对的。
是 git 没有为这种工作流程设置,还是我做错了什么?
谢谢!
最佳答案
首先,感谢 Matthew 提供的链接——他们帮助我找到了我自己的解决方案。
这样做是可能的,但需要注意的是它需要一些小心并且很可能对所涉及的提交者数量有限制。我的用例基本上就是 mitjak 所描述的;需要和/或希望使用两个远程存储库(一个 SVN 和另一个 Git)的单个用户。在我的例子中,前者在防火墙后面工作,另一个在异地(也是私有(private)的)。目标是能够使用 Git 在存储库的本地副本上工作,并使两个远程存储库都满意。
我的程序:
这一切都取决于 git svn dcommit
更改与原始 git 提交关联的 SHA1 的事实。牢记这一点,在本地提交后,我 [可选地 git svn rebase
然后] git svn dcommit
,生成最终的 SHA1。那时,我推送到我的远程 git 仓库。如果像 Chacon 所说的那样,你要做的只是使用 git 提供一个更有效的克隆点,你就完成了。但您可能还希望能够:
第1步代表没有问题;在提交到本地“纯 git”存储库之后 git push
到远程 git 存储库。
第二步没问题;返回您的混合 git/svn 存储库,git pull
来自远程 git 存储库的更改。此时,与新提取的修订相关联的 SHA1 与远程 git 存储库中的那些同步。
第 3 步是该过程变得有点棘手的地方。你可以像上面描述的那样git svn dcommit
将它们推送到SVN仓库,但是情况和上面描述的有点不同。在这种情况下,您现在在远程 SVN 和 git 存储库中具有相同的修订,但由于 dcommit,它们具有不同的 SHA1。我按以下方式处理:
在第 2 步的 pull 过程中,我注意到关联的开头 SHA1;例如,
git pull someone@example.org's password: remote: Counting objects: 5, done. remote: Compressing objects: 100% (3/3), done. remote: Total 3 (delta 0), reused 0 (delta 0) Unpacking objects: 100% (3/3), done. From ssh://example.org/pub/scm/demonstrate 34b6260..17cd887 master -> origin/master Updating 34b6260..17cd887 Fast forward file3 | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-)
所以这里感兴趣的 SHA1 是 34b6260。 git log origin
应该确认这是远程 git 存储库中最后一次提交,它有一个与之关联的 git-svn-id。然后我执行以下操作:
git push -f origin 34b6260:master
执行远程存储库的强制更新以排除我从“纯 git”本地存储库进行的“纯 git”提交——小心使用!在这种情况下,我知道我在本地有这些提交;他们只是具有与 dcommit 不同的 SHA1。然后我 git push
到远程存储库,添加我刚刚删除的提交的“git-svn-id”版本,并且远程存储库同步。
将“纯 git”本地存储库与远程 git 存储库重新同步是最后一步,但类似的注意会产生令人满意的结果。在这种情况下,远程 git 存储库现在包含提交的“git-svn-id”版本,而本地“纯 git”存储库仍然包含原始 SHA1。处理这个问题的最简单方法是从远程 git 存储库 git fetch
,然后 git reset --hard origin
强制本地 git 存储库镜像状态远程。
关于svn - git-svn 和远程 git repo sync,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3623075/
是否可以使用 MS Sync Framework 同步不同数据库中的不同表(具有完全不同的结构),假设其中一个表具有主键,另一个具有唯一索引,其值与第一个表的 PK 一致(但不能晋级PK)?列名也可以
我正在开发一个使用 Twilio Sync 作为数据库的应用程序。我确实订阅了很多事件,例如 itemAdded、itemUpdated、itemRemoved,以使用 Sync Javascript
我们计划使用 ADO.NET 的同步服务将商店与总部同步,有人建议我通过 进行同步。 WCF 代理 . 通过 WCF 代理同步是否意味着我将能够 通过 http 同步 ?如果没有,是否可以使用同步服务
在 Sync Framework 2.1 中,批处理似乎得到了内置支持,因此在某些提供程序中,我们可以只提及批处理大小和假脱机文件位置(以及一些其他属性),批处理将得到处理。开发人员不必编写自己的批处
'sync' 事件和 Backbone.sync 有什么区别? ...它们分别是什么? 最佳答案 虽然两者都与向服务器同步数据的任务有关,但两者之间没有任何联系。 Backbone.sync实现您的
在 Go 中,我们可以使用: type Data struct { lock *sync.Mutex } 或 type Data struct { lock sync.Mutex
我们在各种客户项目中使用 Microsoft Sync Framework 2.1 进行文件和数据库同步。扩展支持将于 2021 年结束。 所以我的问题是: 微软的同步框架策略是什么?它会是开源的,所
我在这个站点和其他站点上看到了一些帖子,指出问题通常是由将表添加到客户端的 SyncAgent 配置或提供者端的 SyncAdapter 的顺序引起的。我相信我在这两个地方都正确地对表格进行了排序(我
Using an Asynchronous Controller in ASP.NET MVC 的使用 BeginMethod/EndMethod 模式部分指的是 Sync() 方法。它没有链接,我无
这是代码: type someThing struct { sync.Mutex cv *sync.Cond num int } func NewSometh
异步地做多项工作(排序向量,主要是函数计算(计算是计算或内存限制,目前,我可以用以下方式编写这些操作: 使用 Threads.@spawn _f1 = Threads.@spawn f1(x) _f2
我想使用 Rust 和 once_cell实现一些静态常量结构实例,一个静态常量向量包含这些静态结构实例。 示例代码如下: use once_cell::sync::Lazy; pub struct
我想使用 Rust 和 once_cell实现一些静态常量结构实例,一个静态常量向量包含这些静态结构实例。 示例代码如下: use once_cell::sync::Lazy; pub struct
看了sync.Pool的设计,发现是两个逻辑,为什么要用localPool来解决锁竞争。我们可以只使用 chan 来实现一个。 使用 channel 比 sync.pool 快 4 倍! pool除了
我有一个编码为在模糊时运行 save_notes 函数的文本区域。当 save_notes 调用时,我在控制台中得到以下内容: TypeError: Cannot read property 'syn
如果 Waitgroups 和 Mutex 总是需要通过引用传递,我们不能把它做成引用类型(禁止使用它们作为值传递)吗?我的意思是有没有我们需要使用它们按值传递的用例? 最佳答案 当您将任何参数作为值
背景:我正在尝试创建一个完全异步 Node js 演示的小测试。然后我可以看到一个好的样本是什么样的,以便清理我完成的其他一些项目。 这是我的代码 //https://medium.com/@tkss
http://msdn.microsoft.com/en-us/library/dd918848.aspx “了解作用域是表和筛选器的组合很重要。例如,您可以定义一个名为 sales-WA 的筛选作用
我尝试同步我的 Visual Studio 代码设置/扩展。我手动执行的许多同步步骤。 然后我发现了这两个工具 https://code.visualstudio.com/docs/editor/se
我正在尝试移植一个扩展,但我的 JS 非常生疏。 https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/Chro
我是一名优秀的程序员,十分优秀!