- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有几个使用 Drupal 的站点,我有几个服务器,live,dev1,dev2...
Drupal 的代码库存储库很大 (112Mb),所以我很想充分利用 git 的硬链接(hard link)功能,这样每次我添加一个站点时都不会复制它。
等等,比方说,我有一个裸主存储库的实时服务器,我所有的站点都是它的克隆,每个站点都使用不同的分支。这在一台服务器上很棒,使用了硬链接(hard link),速度快,效率高。
但在我的开发服务器上,它们通常都是从裸主存储库克隆的,这意味着同一台机器上的两个站点不能使用硬链接(hard link)来节省空间。
我想做的是在我的每台开发服务器上设置裸存储库的镜像,然后从中克隆。
dev1$ git clone --mirror live:master-bare-repo dev1-mirror-repo
dev1$ git clone -b site1 dev1-mirror-repo site1
dev1$ git clone -b site2 dev1-mirror-repo site2
到目前为止一切都很好。但我希望镜子始终保持同步。所以我用了 post-receive hook在 dev1 的镜像上执行 git push --mirror origin
。现在,如果 dev1 上的 site1 推送提交,它们会神奇地推送到 master-bare-repo。
但是如果我在实时服务器上进行更改并推送它会怎么样?我无法设置一个 post-receive
Hook 来推送给其他人,因为这可能会触发 他们的 post-receive
Hook 哪个会以递归结束?
有什么聪明的方法可以解决这个问题吗?
最佳答案
首先,您不会以递归结束,因为当“一切都是最新的”时不会执行接收后 Hook (如 this other question 中所述) ,这将是从镜像到实时服务器的推送的结果。
另一方面,这并不是可扩展设计的全部(每次添加新镜像时,您都需要更改实时服务器的 Hook 以添加要推送的站点)。您可能会发现在您的镜像中使用“惰性”同步策略更优雅:当他们收到推送时,他们不只是推送到主服务器,而是在此之前从主服务器获取/pull 。这样你就不需要在主服务器上设置 Hook ,同步策略将完全由镜像管理。这种策略的不利之处在于,您可能最终希望在需要推送任何更改之前对要传播到镜像的实时服务器进行更改。因此,您必须考虑对 master 进行更改对于补偿可扩展性的权衡是否如此重要。当然,使这种“可扩展”设计也“可同步”的补丁是使用外部 cron 作业定期检查 master 中的更改,如评论中所建议的那样。
关于git - 始终保持 git 镜像同步,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10851181/
我有一个包含一些宏和用户表单的 Excel 文件。 我不希望用户在没有密码的情况下访问文件本身。他们应该只能看到用户表单并通过用户表单输入数据。 这是我目前拥有的代码。 Private Sub Wor
我正在使用 ui 自动完成功能:over here 我需要始终打开自动完成功能,因此当单击正文中的某个位置时它不应该关闭。我已经用谷歌搜索过这个但我找不到任何东西。 最佳答案 抱歉,回复晚了! 我觉得
我有几个使用 Drupal 的站点,我有几个服务器,live,dev1,dev2... Drupal 的代码库存储库很大 (112Mb),所以我很想充分利用 git 的硬链接(hard link)功能
我需要一个始终保存 n 的数据结构迄今为止插入的最大项目(无特定顺序)。 所以,如果 n是 3,我们可以在下面的 session 中插入一些数字并且容器的内容发生变化: [] // now inse
这个问题在这里已经有了答案: Why don't flex items shrink past content size? (5 个答案) 关闭 5 年前。 我在 flexbox 中有 5 列 di
Smartgit 一直 pop 登录表单! 我已经在我的服务器上部署了 git。严格按照 git 设置的说明进行操作。 然后我用puttygen生成开放的SSH私钥,填写密码,把代码放在“public
我在对齐 div 时遇到问题。我在一个容器中有 5 个 div,全部向左浮动,按照下图设置。 每个 div 的宽度为 425px,div 与容器之间的边距始终为 15px,容器的宽度为 1350px。
我正在使用带有集成颠覆控制的 NetBeans。 如果我通过 TortoiseSVN 进行提交、添加等操作,NetBeans 将无法识别这些操作。 显然,如果我通过 NetBeans 进行更改,我的本
我知道有很多这样的问题,但我阅读了所有这些问题,其中没有一个解决了我的问题。下面我将展示我的 View 和 Controller 中的代码,以便您了解我的代码。 View :
我有一个 100% 高度的左浮动和 100% 的右浮动。一切正常,直到我用文本填充一侧,另一侧才会停止。 我该如何解决这个问题? 最佳答案 在为两列插入父 div 后,您可以使用 css 表。例如:
我使用此 JavaScript 代码是为了在验证失败后突出显示文本框和其他控件(在其上指定了 ASP.NET 验证器)。 $(document).ready(function() {
我是一名优秀的程序员,十分优秀!