草庐IT

git - 将 Git 分支直接推送到实时服务器目录中,以便实时查看文件

coder 2023-06-25 原文

我如何在 Git 中设置远程目录,我可以在其中将暂存分支本地推送到远程目录并在暂存服务器(例如 stage.example.com)上查看实时更改?

我的想法(我离开 SVN 的部分原因)是我可以(在本地)维护 3 个不同的“主要”分支,如下所示:

  • ma​​ster - 用于本地开发,工作目录
  • stage - 应与暂存服务器目录(远程)同步
  • live - 这应该是可公开访问的网站(远程)

我的想法(以及其他人声称的可能)是我可以从我的本地计算机维护这些远程“站点”,而不必经常登录到我的远程服务器 shell 并运行 svn update (在我当前的 svn 工作流程中,我需要一直这样做……)或者当然在我的 Git 工作流程中,在远程运行 git pull

如何设置远程目录,以便我可以在本地将我的 stage 分支推送到 staging 远程服务器 并在 上查看更改(例如) stage.example.com 马上?

然后,一旦 stage 一切正常并经过测试,我就可以在本地pushlive 远程进行这些更改我已经在实时网站的 stage 上进行了测试。

这甚至可以完成吗?还是我在这里得到了根本不应该用 Git 完成的疯狂想法?

如果这很重要,这里有一些关于我的本地和远程服务器的统计信息:

remote server:      Dreamhost (shared account)
remote GIT version: 1.7.1.1
remote GIT client:  shell

local computer:     Mac Pro (Snow Leopard 10.6.6)
local GIT version:  1.7.2.3
local GIT client:   Tower.app // git-tower.com

此外,到目前为止,我未成功尝试了以下工作流程:

  1. 在远程创建一个 --bare Git 仓库(这样我就可以从任何地方访问它)
  2. 将此远程仓库克隆到本地目录并使用 Git Tower 应用程序对其进行管理
  3. 在本地工作 master (HEAD)
  4. scp -r--bare git repo 从远程服务器复制到我的远程实时域 stage.example.com
  5. 将远程添加到本地工作副本,然后尝试推送到origin/stage

显然这行不通,但我不知道为什么或如何做得更好。

来自 SVN 背景,我是 Git 的新手,但看了很多教程(Peepcode 和 ThinkVitamin),但仍然不知道如何设置它。

最佳答案

使用 DVCS(“分布式”VCS,如 Git 或 Mercurial)实现的一个概念是它添加了 notion of publication (推/pull )到分支的概念。
CVCS(“集中式”VCS,如 SVN)只有分支(和一个要推送到服务器上的中央仓库)。

在您的情况下,暂存或实时是发布步骤,即准备好接收您希望在暂存或实时环境中看到的修改的不同 Git 存储库。

这意味着:

  • 2 个分支来跟踪属于暂存(“staging”分支)或实时(“live”分支)的内容
  • 1 个远程裸仓库 ( in order to be able to push to it ,推送 staginglive 分支
  • 1 post-update hook对于裸仓库 in order to checkout and update a working tree (代表您实际的“暂存”或“实时”文件)
  • 1 个本地存储库,您可以在其中将裸存储库添加为远程存储库,并且可以将其推送到暂存或上线。
    您还可以将裸存储库克隆到您需要使用的任何其他本地计算机。

post-receivepost-update Hook 的区别在于 post-update 对每个分支执行一次修改:
请参阅“Git hook to update various web folders based on branch pushed to remote server”SO 问题。

在初始推送时,执行“git push --all origin”,所有分支都将在远程裸仓库上创建。

这个想法是服务器端不应该涉及 pull :只有 git --work-tree=/path/to/your/live/files/checkout livegit --work-tree=/path/to/your/staging/files/checkout staging,取决于更新后 Hook 的参数:您只将裸仓库的文件 check out 到这些“文件夹”中服务器。

如果你为你的钩子(Hook)编写了一个 ruby​​ 脚本,请确保:

  • 使用right shebang : #!/usr/bin/env ruby​​,
  • 用反引号包围你的 git 命令就足够了:`git ...`, like in this script ,
  • 使用 ENV['HOME'] 在所述脚本中指定当前用户的 homedir,如果你想要像 `cd ~/stagedomain.com``--work-tree=~/stagedomain.com` 工作(将 `~` 设置为正确的路径),
  • 如果您选择 git pull,请在与其他命令相同的行上取消设置 GIT_DIR like in your other question : `cd ~/stage.mydomain.com && unset GIT_DIR && git pull core stage`

关于git - 将 Git 分支直接推送到实时服务器目录中,以便实时查看文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5520141/

有关git - 将 Git 分支直接推送到实时服务器目录中,以便实时查看文件的更多相关文章

  1. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. ruby-on-rails - 如果 Object::try 被发送到一个 nil 对象,为什么它会起作用? - 2

    如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象

  4. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  5. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  6. ruby - 用 Ruby 编写一个简单的网络服务器 - 2

    我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b

  7. ruby-on-rails - 在 Rails 中调试生产服务器 - 2

    您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除

  8. git使用常见问题(提交代码,合并冲突) - 2

    文章目录git常用命令(简介,详细参数往下看)Git提交代码步骤gitpullgitstatusgitaddgitcommitgitpushgit代码冲突合并问题方法一:放弃本地代码方法二:合并代码常用命令以及详细参数gitadd将文件添加到仓库:gitdiff比较文件异同gitlog查看历史记录gitreset代码回滚版本库相关操作远程仓库相关操作分支相关操作创建分支查看分支:gitbranch合并分支:gitmerge删除分支:gitbranch-ddev查看分支合并图:gitlog–graph–pretty=oneline–abbrev-commit撤消某次提交git用户名密码相关配置g

  9. ruby - 我的 Ruby IRC 机器人没有连接到 IRC 服务器。我究竟做错了什么? - 2

    require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame

  10. ruby - 未定义的方法 auto_upgrade!将 Sinatra/DataMapper 应用程序推送到 Heroku 时 - 2

    有谁知道在Heroku的Bamboo堆栈上启动并运行使用DataMapper的Sinatra应用程序所需的魔法咒语?Bamboo堆栈不包含任何预安装的系统gem,无论我尝试使用何种gem组合,我都会不断收到此错误:undefinedmethod`auto_upgrade!'forDataMapper:Module(NoMethodError)这是我的.gems文件中的内容:sinatrapgdatamapperdo_postgresdm-postgres-adapter这些是我将应用程序推送到Heroku时安装的依赖项:----->Herokureceivingpush----->Si

随机推荐