我想在可以轻松与网络应用交互的服务器上运行图像处理算法。图像处理算法计算量大,在定制库中不可用。目前,我正在为我的网站使用 Heroku 上的 Ruby on Rails。
实现此目标的最佳架构是什么?从网站上获取图像 - 在其上运行图像处理算法 - 在网站上显示
我的大部分图像处理代码都使用 C/C++。
我可以直接从 Ruby on Rails 调用 C/C++ 代码吗?这在 Heroku 上可行吗?
或者我应该设计一个系统,让 C/C++ 代码公开一些可以由 Ruby on Rails 服务器调用的 API?
最佳答案
Heroku 通常使用小型虚拟机实例,因此根据您的处理量,它可能不是最佳架构选择。但是,如果您确实使用它,我会这样做:
使用后台任务 gem 进行处理。让它在一个单独的进程上运行(在 Heroku 术语中称为 worker 而不是 dyno)。 Delayed Job 是一个久经考验的后台任务解决方案,有大量关于将其集成到 Heroku 的在线信息,但也有更新的解决方案,如 Sidekiq,它在现代版本的 Ruby 中使用了新的线程系统。他们会允许所有事情都在测功机中完成,但我会说让所有后台处理远离网络服务器测功机会很有用,所以延迟作业(或类似的)会很好。
至于集成C/C++,我还没有需要这样做。但是,我知道可以创建集成 C 或 C++ 代码并进行本地编译的 gem。只要您使用的是 ruby 而不是 JRuby,我认为 Heroku 应该不会有问题。还有其他方法可以完成此操作,请查看有关此主题的 SO 问题,例如
How can I call C++ functions from within ruby
看来您需要创建一个扩展,然后创建一个 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 的垫脚石。寻找 gems 来帮助.)
然后网络服务器可以请求后台任务来处理图像。
如果你不存储它们,事情会变得更有趣一点......如果你使用后台任务,你将需要一个数据库,这样你就可以将图像数据作为一个 blob 传递给工作人员也许是数据库。
我真的不会只在网络服务器 dyno 中进行所有处理,除非你真的只是偶尔碰到这个东西。如果有多个用户,您很快就会遇到瓶颈。
后台进程可以在图像表行上设置一个标志,这样网络服务器就可以在处理完成时通知用户。 (您可以使用 AJAX 在上传完成屏幕上使用 JS 轮询信息)
当然,还有许多其他方法可以实现这一点,具体取决于多种因素。
抱歉,答案含糊不清,但问题是开放式的。
祝你好运。
关于c++ - Web 服务器上的图像处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25013107/