我的问题基本上是两个问题,但由于它们密切相关,我认为有必要全盘提问。
案例:
我正在运行一个网络应用程序,它分布在 AWS 弹性负载均衡器后面的多个 AWS EC2 实例上
预期目标:
a) 当部署新的应用程序代码 (php) 时,它应该自动分发到所有 EC2 实例。
b) 添加新的 EC2 实例时,它们应该使用最新的应用程序代码自动“引导”
到目前为止我的想法:
广告一)
phing (http://phing.info) 可能是这部分的答案。我可能会为每个 EC2 实例添加多个目标,并且在运行部署时它会部署到所有机器。不幸的是,可能不是并行的。但是当以 EC2 实例在负载均衡器中“暂停”、升级、再次“取消暂停”并继续到下一个实例的方式编写脚本时,这甚至可能是有益的。
广告b)
不确定我将如何实现这一目标。在传统的“基于硬件的设置”中,我可能在网络存储设备上有一个“应用程序代码”卷,当添加新服务器时,我只需附加该卷。在部署新的应用程序代码时,我只对该卷进行了一次部署操作。所以我需要一些“中央存储”,新引导的机器/实例从那里下载它的应用程序代码。我想到了 git,但毕竟 git 不是一个部署工具,可能不应该被强制用作一个工具。
我很乐意看到您对此类任务的设置,并听到您对此类情况的提示和想法。
谢谢,
约书亚
最佳答案
这可以使用 phing 来完成。但是,我不确定您为什么希望新实例自动检索应用程序代码?你经常得到额外的实例吗?为了让 a) 将代码部署到多个实例,它仍然需要知道它们吗?
此设置需要主部署服务器并使用推送策略。主服务器需要 phing、任何必需的 phing 包,以及可选的 EC2 实例的 ssh key 。
a) 的建议
(这只是所需 phing 任务的大纲)
scp tarball 到所有 EC2 实例(到部署文件夹)rsh 在 EC2 实例上解压 tarballrsh 更新 EC2 实例上的符号链接(symbolic link),使网络服务器文件夹指向新的部署文件夹可以在发布新版本后调用上面的方法。
b) 的建议 这可以通过每隔几个小时运行一次 phing 脚本来实现,让它登录到 EC2 实例并检查应用程序代码。如果找不到,它将部署最新的最终版本。 当然,这需要在网络服务器、配置文件等方面正确设置 EC2 实例(但是,这也可以通过 phing 通过远程 shell 实现)。
我以前使用过类似的设置,但没有尝试过使用 EC2 等服务。
关于php - 将 PHP webapp 部署到 Elastic Load Balancer 后面的多个 EC2 实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5003564/
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我正在查看instance_variable_set的文档并看到给出的示例代码是这样做的:obj.instance_variable_set(:@instnc_var,"valuefortheinstancevariable")然后允许您在类的任何实例方法中以@instnc_var的形式访问该变量。我想知道为什么在@instnc_var之前需要一个冒号:。冒号有什么作用? 最佳答案 我的第一直觉是告诉你不要使用instance_variable_set除非你真的知道你用它做什么。它本质上是一种元编程工具或绕过实例变量可见性的黑客攻击
在我的应用程序中,我需要能够找到所有数字子字符串,然后扫描每个子字符串,找到第一个匹配范围(例如5到15之间)的子字符串,并将该实例替换为另一个字符串“X”。我的测试字符串s="1foo100bar10gee1"我的初始模式是1个或多个数字的任何字符串,例如,re=Regexp.new(/\d+/)matches=s.scan(re)给出["1","100","10","1"]如果我想用“X”替换第N个匹配项,并且只替换第N个匹配项,我该怎么做?例如,如果我想替换第三个匹配项“10”(匹配项[2]),我不能只说s[matches[2]]="X"因为它做了两次替换“1fooX0barXg
我有一个具有一些属性的模型:attr1、attr2和attr3。我需要在不执行回调和验证的情况下更新此属性。我找到了update_column方法,但我想同时更新三个属性。我需要这样的东西:update_columns({attr1:val1,attr2:val2,attr3:val3})代替update_column(attr1,val1)update_column(attr2,val2)update_column(attr3,val3) 最佳答案 您可以使用update_columns(attr1:val1,attr2:val2
我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这
我有一个正在构建的应用程序,我需要一个模型来创建另一个模型的实例。我希望每辆车都有4个轮胎。汽车模型classCar轮胎模型classTire但是,在make_tires内部有一个错误,如果我为Tire尝试它,则没有用于创建或新建的activerecord方法。当我检查轮胎时,它没有这些方法。我该如何补救?错误是这样的:未定义的方法'create'forActiveRecord::AttributeMethods::Serialization::Tire::Module我测试了两个环境:测试和开发,它们都因相同的错误而失败。 最佳答案
我是Google云的新手,我正在尝试对其进行首次部署。我的第一个部署是RubyonRails项目。我基本上是在关注thisguideinthegoogleclouddocumentation.唯一的区别是我使用的是我自己的项目,而不是他们提供的“helloworld”项目。这是我的app.yaml文件runtime:customvm:trueentrypoint:bundleexecrackup-p8080-Eproductionconfig.ruresources:cpu:0.5memory_gb:1.3disk_size_gb:10当我转到我的项目目录并运行gcloudprevie
我正在处理旧代码的一部分。beforedoallow_any_instance_of(SportRateManager).toreceive(:create).and_return(true)endRubocop错误如下:Avoidstubbingusing'allow_any_instance_of'我读到了RuboCop::RSpec:AnyInstance我试着像下面那样改变它。由此beforedoallow_any_instance_of(SportRateManager).toreceive(:create).and_return(true)end对此:let(:sport_