1

我想在可以与网络应用程序轻松交互的服务器上运行图像处理算法。图像处理算法的计算量很大,在定制的库中不可用。目前我在 Heroku 上为我的网站使用 Ruby on Rails。

实现这一目标的最佳架构是什么?从网站获取图像 - 在其上运行图像处理算法 - 显示回网站

我的大部分图像处理代码都在 C/C++ 上。

我可以直接从 Ruby on Rails 调用 C/C++ 代码吗?这在 Heroku 上可行吗?

或者我应该设计一个系统,其中 C/C++ 代码公开一些可由 Ruby on Rails 服务器调用的 API?

4

1 回答 1

3

Heroku 通常使用小型虚拟机实例,因此取决于您的处理量,它可能不是架构的最佳选择。但是,如果您确实使用它,我会这样做:

使用后台任务 gem 进行处理。让它在一个单独的进程上运行(在 Heroku 术语中称为 worker 而不是 dyno)。Delayed Job 是一个久经考验的后台任务解决方案,其中包含大量与将其集成到 Heroku 相关的在线信息,但是有像 Sidekiq 这样的较新的解决方案,它在现代版本的 Ruby 中使用新的线程系统。他们将允许在测功机中完成所有事情,但我想说让所有后台处理远离网络服务器测功机会很有用,因此延迟作业(或类似的)会很好。

至于集成 C/C++,我还不需要这样做。但是,我知道可以创建集成 C 或 C++ 代码并进行本机编译的 gem。只要您使用的是 ruby​​ 而不是 JRuby,我认为 Heroku 应该不会对它们有问题。还有其他方法可以做到这一点,请查看专门针对此主题的 SO 问题,例如

如何从 ruby​​ 中调用 C++ 函数

看来您需要创建一个扩展,然后创建一个 gem 来包含它。这些链接可能有帮助,也可能没有帮助。

http://www.rubyinside.com/how-to-create-a-ruby-extension-in-c-in-under-5-minutes-100.html

http://guides.rubygems.org/gems-with-extensions/

我建议制作一个 gem,因为我认为可能很难将库或可执行文件放到 Heroku 实例上。如果您不想公开它,可以将 gem 存储在您的供应商目录中。

总的来说,我会将网络服务器上传到 S3 或您存储图像的任何地方(这可以直接在浏览器中完成,而无需使用网络服务器作为 AWS JS API 的垫脚石。寻找可以帮助的宝石。)

然后网络服务器可以请求后台任务来处理图像。

如果您不存储它们,事情会变得更有趣......如果您使用后台任务,您将需要一个数据库,因此您可以将图像数据作为数据库中的 blob 传递给工作人员。

我真的不会只在网络服务器测功机中进行所有处理,除非你真的只是偶尔打这个东西。对于多个用户,您很快就会遇到瓶颈。

后台进程可以在图像表行上设置一个标志,以便网络服务器可以在处理完成时通知用户。(您可以使用 JS 在使用 AJAX 的上传完成屏幕​​上轮询信息)

当然,还有许多其他方法可以实现这一点,具体取决于许多因素。

很抱歉答案含糊不清,但问题是相当开放的。

祝你好运。

于 2014-07-29T10:47:19.767 回答