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 的上传完成屏幕上轮询信息)
当然,还有许多其他方法可以实现这一点,具体取决于许多因素。
很抱歉答案含糊不清,但问题是相当开放的。
祝你好运。