[英]Why is it supposedly “hard” to deploy Ruby on Rails to production?
我承认在部署测试代码与生产代码时,我没有采取任何“正确”的措施。 我一直在使用ASP.NET,我通常在Visual Studio中本地运行它,它可以工作,我上传它,我在生产服务器上再次测试它。
我读过几个人说部署Rails应用程序比较困难,ruby网站上有关于部署RoR的特殊程序/方法。 我只玩过RoR。 部署有什么特别之处? 您不只是复制并粘贴代码并运行它(从开发机器到生产)? 是因为一个在Apache中而另一个在内置服务器上运行?
如果重要的话,这将在Mac服务器上。
部署RoR不再困难,特别是使用Phusion Passenger 。
有点困难的是,使用capistrano,vlad等设置自动化生产环境。如果您不介意只是将代码复制到服务器,那么就可以做到这一点。 大多数人选择不这样做,因为你失去了自动部署工具给你带来的很多好处。
我想人们认为Rails应用程序比部署PHP应用程序更难以部署,或者只是将代码放在某处,并指向Apache或其他任何东西。 但是,如上所述,你现在可以用Phusion Passenger做到这一点。
我们使用Nginx + Passenger,但不是为了简化部署。 Capistrano是我们选择的部署工具,实际上,除非你有一个非常简单的应用程序,否则你会想要像Capistrano这样的东西。 例如,通过我们的部署,我们做了很多事情:
除了Capistrano之外还有其他方法,但它是一个经过验证的工具,具有很大的灵活性,但设置一个vanilla配置非常简单。
所以,我的看法是,一旦你进入任何超出最简单的应用程序的应用程序,你将需要/想要做的事情,而不仅仅是简单地更新代码。 但是,如果您只需要代码更新,也许还需要Rails迁移,那么您可以执行更简单的操作,例如Passenger和代码同步,或者查看Heroku或Engine Yard等工具,通过执行Git克隆进行部署(然后提供一些额外的能力)。
另一个超级简单的部署方法是使用http://heroku.com/
这并不是特别难。 如果您坚持使用约定然后进行一些配置,可以归结为:
cap deploy
...但是,有时需要一些努力才能使工作流程到位。
好消息是很多人已经为RoR打包了解决方案和堆栈,您可以即插即用。 例如,谷歌ec2onrails - 这是一个打包的Ubuntu图像和一套capistrano任务,用于在亚马逊的EC2云中运行rails应用程序,已经开箱即用设置了许多常见的东西。
选择一个好的托管服务提供商,你也应该能够找到类似的东西。
部署Rails应用程序的一种简单方法是使用Phusion Passenger 。 部署并不比任何编程语言或框架容易得多。 您可以在Mac服务器上执行此操作。
部署rails的另一个非常简单的方法是使用jruby和glassfish gem。
将rails部署到生产中时遇到的一些问题:
数据库连接。 您需要确保为生产环境设置了数据库连接器。
数据库迁移。 即使您可能已在生产/测试/暂存中运行数据库迁移,也必须对生产数据库运行数据库迁移
Ruby版本。 版本或子版本或Ruby可能会让你失望,例如安装debugger-linecache(1.1.1)时出错,而Bundler无法继续
宝石依赖。 您的生产环境可能与开发有不同的包和宝石。 Bundler将在很大程度上解决这个问题,并安装依赖项,但有时仍然存在必须手动解决的问题。
依赖。 某些机器上的某些宝石具有特定的依赖性。 我已经看到在我的unix盒上使用gems的常见问题,这些gems可以在OSX上运行,反之亦然。
请注意,如果在同一台机器上,最后3个不应该影响您,但我根据标题包含它们并且是全面的。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.