无法使用 h2o.loadModel() 函数导入 binay h2o 模型:412 先决条件失败

Can't import binay h2o model with h2o.loadModel() function: 412 Precondition Failed

过去几天我一直在使用 h2o 和 h2o Flow,并且非常喜欢它。两天前,我从 h2o Flow 导出了一些模型(二进制格式)并用 R 导入它们,这样我就可以做进一步的研究。直到今天它都运行良好。出于某种原因,当我尝试 h2o.loadModel 函数时出现以下错误(在我导出的所有二进制模型之前它工作得很好)。澄清一下,我已经 运行 成功地 h2o.init() 命令打开了 H2O 集群。

ERROR: Unexpected HTTP Status code: 412 Precondition Failed (url = http://localhost:54321/99/Models.bin/)

water.exceptions.H2OIllegalArgumentException
 [1] "water.exceptions.H2OIllegalArgumentException: Illegal argument: dir of function: importModel: H2O/H2O-XX/gbm_grid1_m02"
 [2] "    water.api.ModelsHandler.importModel(ModelsHandler.java:220)"                                                       
 [3] "    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)"                                                       
 [4] "    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)"                                     
 [5] "    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)"                             
 [6] "    java.lang.reflect.Method.invoke(Method.java:498)"                                                                  
 [7] "    water.api.Handler.handle(Handler.java:63)"                                                                         
 [8] "    water.api.RequestServer.serve(RequestServer.java:446)"                                                             
 [9] "    water.api.RequestServer.doGeneric(RequestServer.java:296)"                                                         
[10] "    water.api.RequestServer.doPost(RequestServer.java:222)"                                                            
[11] "    javax.servlet.http.HttpServlet.service(HttpServlet.java:755)"                                                      
[12] "    javax.servlet.http.HttpServlet.service(HttpServlet.java:848)"                                                      
[13] "    org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:684)"                                            
[14] "    org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:503)"                                        
[15] "    org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1086)"                                
[16] "    org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:429)"                                         
[17] "    org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1020)"                                 
[18] "    org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)"                                     
[19] "    org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154)"                             
[20] "    org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)"                                   
[21] "    water.JettyHTTPD$LoginHandler.handle(JettyHTTPD.java:189)"                                                         
[22] "    org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154)"                             
[23] "    org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)"                                   
[24] "    org.eclipse.jetty.server.Server.handle(Server.java:370)"                                                           
[25] "    org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:494)"                    
[26] "    org.eclipse.jetty.server.BlockingHttpConnection.handleRequest(BlockingHttpConnection.java:53)"                     
[27] "    org.eclipse.jetty.server.AbstractHttpConnection.content(AbstractHttpConnection.java:982)"                          
[28] "    org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.content(AbstractHttpConnection.java:1043)"          
[29] "    org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:865)"                                                  
[30] "    org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:240)"                                             
[31] "    org.eclipse.jetty.server.BlockingHttpConnection.handle(BlockingHttpConnection.java:72)"                            
[32] "    org.eclipse.jetty.server.bio.SocketConnector$ConnectorEndPoint.run(SocketConnector.java:264)"                      
[33] "    org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)"                                  
[34] "    org.eclipse.jetty.util.thread.QueuedThreadPool.run(QueuedThreadPool.java:543)"                                   
[35] "    java.lang.Thread.run(Thread.java:748)"                                                                             

Error in .h2o.doSafeREST(h2oRestApiVersion = h2oRestApiVersion, urlSuffix = page,  : 


ERROR MESSAGE:

Illegal argument: dir of function: importModel: H2O/H2O-XX/gbm_grid1_m02

我在 RStudio、macOS Sierra (10.12.6 (16G29)) 上使用最新的 h2o 版本 3.15.0.4029

更新: 根据 Erin 的要求,发布我如何尝试导入模型:

library(h2o)
#h2o.init(nthreads = -1, max_mem_size = "7G") # Already initiated 
#h2o.removeAll()   
h2oXX <- h2o.loadModel("H2O-XX/GBM_grid_0_AutoML_20171102_095446_model_41")

降级到最新的稳定版(h2o-3.14.0.7)并收到同样的错误:Illegal argument: dir of function: importModel: H2O-XX/GBM_grid_0_AutoML_20171102_095446_model_41

附模型(可以尝试导入):bit.ly/h2odemo

如果您看到如下所示的错误(关键标识符是此语句 Illegal argument: dir of function: importModel:

ERROR: Unexpected HTTP Status code: 412 Precondition Failed (url = http://localhost:54321/99/Models.bin/)

water.exceptions.H2OIllegalArgumentException
[1] "water.exceptions.H2OIllegalArgumentException: Illegal argument: dir of function: importModel: H2O/H2O-XX/gbm_grid1_m02"

那么这可能意味着您使用不同版本的 H2O 来训练和保存模型,而不是用来加载 H2O 模型。这是一个问题,因为 binary models(使用 h2o.saveModel() 函数保存的模型)在不同版本的 H2O 之间不兼容。

简单的解决方案是使用相同版本的 H2O 保存并重新加载模型。

另一种解决方案是使用 POJO or MOJO 类型的 H2O 模型。这种模型格式将模型导出为纯 Java 代码,并且不依赖于特定版本的 H2O。当您对测试数据生成预测时,它也不要求 H2O 集群为 运行。如果您要将 H2O 模型投入生产,这通常是您想要使用的。