推送到Heroku的一个不好的方面是我必须在运行我的数据库迁移之前推送代码(并且服务器会自动重启)。这显然会导致用户在没有新表/属性的情况下浏览具有新代码的网站时出现大约500个错误:Heroku提出的解决方案是使用维护模式,但我想要一种没有缺点的方法让我的webapp运行每次!有办法吗?例如Capistrano:我准备将代码部署到新目录我运行(向后)迁移,旧代码继续完美运行我将mongrel实例切换到新目录并重新启动服务器...而且我没有停机时间! 最佳答案 您可以设置第二个Heroku应用程序,它指向与主要生产应用程序相同的数据
在www.Heroku.com上具有1或2个Dynos的站点可以处理多少流量增加worker会改善这一点吗?对测功机/worker的任何帮助将不胜感激。 最佳答案 这blogentry可能有用。他详分割析了heroku可能遇到的瓶颈类型,以及增加dynos的帮助,并提供了officialperformanceguideonheroku的链接和信息。以及一些可帮助您测试自己的应用的工具。工作人员的表现实际上取决于您的网站是如何构建的以及您将它们用于什么目的。称为DelayedJobs的后台处理(图像格式化、帐户修剪等)是你如何让他们工
当使用ActionMailer异步发送延迟电子邮件时,我不断收到OpenSSL::SSL::SSLError消息SSL_read:certalreadyinhashtable。我们使用Sidekiq异步发送所有电子邮件。当在SidekiqGitHub存储库中将这个问题作为一个问题提出时,我被告知Sidekiq对SSL连接一无所知,也不知道如何管理SSL连接。我们的应用托管在Heroku上,它正在运行OpenSSL0.9.8k2009年3月25日。我们在其他作业中多次看到此错误,并且发现作业有时得到处理,但有时却没有。这是一个OpenSSL线程问题,其中多个Sidekiq线程试图使用相同
我创建了一个使用whenevergem的应用程序。gem创建cron作业。我让它在本地工作,但似乎无法让它在herokucedar上工作。执行此操作的命令是什么?运行:herokurunwhenever--update-crontabjob1没用 最佳答案 简短回答:使用调度程序插件:http://addons.heroku.com/scheduler长答案:当你运行herokurun时,我们启动测功机放上你的代码执行你的命令,等待它完成把测功机扔掉您对crontab所做的任何更改都会立即被丢弃。一切都是短暂的,你不能在heroku
所以我在我的Rails应用程序中使用HerokuPostgres,但我没有在Heroku本身上托管我的应用程序。我在我的database.yml中使用了来自Heroku的ActiveRecord连接详细信息,它看起来像这样:development:adapter:postgresqlencoding:unicodepool:5database:[database]username:[username]password:[password]host:ec2-54-227-243-78.compute-1.amazonaws.comport:5432但是,现在我正在尝试rakedb:mig
有没有更快的方法将我的生产数据库转移到测试应用程序?目前我正在对我的本地计算机执行herokudb:pull然后herokudb:push--apptestapp但这变得很耗时。我有一些种子数据,但它远不如用我的真实数据进行简单测试那么准确。由于它们都存储在相邻的AWS云中,因此必须有更快的方法来移动数据吗?我考虑过使用heroku包,但我注意到animate命令不见了?bundles:animate#animateabundleintoanewapp 最佳答案 在Rails应用程序的暂存、测试和生产环境之间迁移数据库是很常见的。而
当我运行工头时,我得到以下信息:>foremanstart16:47:56web.1|startedwithpid27122只有当我停止它(通过ctrl-c)时,它才会显示缺少的内容:^CSIGINTreceived16:49:26system|sendingSIGTERMtoallprocesses16:49:26web.1|=>BootingThin16:49:26web.1|=>Rails3.0.0applicationstartingindevelopmentonhttp://0.0.0.0:500016:49:26web.1|=>Callwith-dtodetach16:49
我使用PostgreSQL数据库在Heroku上的Rails中创建了一个应用程序。它有几个表,旨在能够与移动设备同步,在这些设备上可以在不同的地方创建数据。因此,我有一个uuid字段,它是一个存储GUID以及自动递增主键的字符串。uuid是在服务器和客户端之间通信的。我在服务器端实现同步引擎后意识到,当需要一直在uuidid之间映射时,这会导致性能问题(在编写对象时,我需要先查询uuid以获取id保存和发回数据时相反)。我现在正在考虑切换到仅使用UUID作为主键,从而使写入和读取变得更加简单和快速。我读到UUID作为主键有时会在使用聚簇主键索引时导致糟糕的索引性能(索引碎片)。Post
同时遵循MichaelHartl的Rails4Beta版本RubyonRailsTutorial,我的应用程序无法在Heroku上启动,但可以在本地使用bundleexecrailsserver正常运行。检查herokulogs-t显示以下错误:$heroku[web.1]:Statechangedfromcrashedtostarting$heroku[web.1]:Startingprocesswithcommand`bin/railsserver-p33847-e$RAILS_ENV`$app[web.1]:bash:bin/rails:Nosuchfileordirectory
我目前在Ubuntu12.04中通过RVM安装了RubyonRails。默认数据库是在SQLite3中设置的,但为了推送到Heroku,我想切换到PostgreSQL。我怎样才能做到这一点? 最佳答案 以下是我遵循的步骤:安装PostgreSQL和开发包$sudoapt-getinstallpostgresql$sudoapt-getinstalllibpq-dev设置一个与我的Ubuntu登录相同的用户$sudosupostgres-cpsqlpostgres=#CREATEROLESUPERUSERLOGIN;postgres=