首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Apache Ignite上部署服务

在Apache Ignite上部署服务
EN

Stack Overflow用户
提问于 2017-08-17 14:56:45
回答 1查看 656关注 0票数 0

我有一个在Ignite上部署服务的util方法:

代码语言:javascript
复制
private static void startNewService(String queryId, String sqlQuery, long timeInterval) {
    QueryServiceImpl cepService = new QueryServiceImpl(queryId, sqlQuery, timeInterval);

    ServiceConfiguration cfg = new ServiceConfiguration();
    cfg.setService(cepService);
    cfg.setName(queryId);
    cfg.setTotalCount(1);
    cfg.setMaxPerNodeCount(1);

    System.out.println("---- Deploying the service. "+queryId);
    services.deploy(cfg);
    System.out.println("---- Deployed the service. "+queryId);
}

当我从我的客户机上运行这个命令时,我在服务器机上得到以下错误:

代码语言:javascript
复制
[12:13:26,640][SEVERE][srvc-deploy-#35%myGrid%][GridServiceProcessor] Failed to initialize service (service will not be deployed): Query1
class org.apache.ignite.IgniteCheckedException: com.demo.ignite.service.QueryServiceImpl
    at org.apache.ignite.internal.util.IgniteUtils.unmarshal(IgniteUtils.java:9739)
    at org.apache.ignite.internal.processors.service.GridServiceProcessor.copyAndInject(GridServiceProcessor.java:1206)
    at org.apache.ignite.internal.processors.service.GridServiceProcessor.redeploy(GridServiceProcessor.java:1127)
    at org.apache.ignite.internal.processors.service.GridServiceProcessor.processAssignment(GridServiceProcessor.java:1750)
   ......
 Caused by: class org.apache.ignite.binary.BinaryInvalidTypeException: com.demo.ignite.service.QueryServiceImpl
    at org.apache.ignite.internal.binary.BinaryContext.descriptorForTypeId(BinaryContext.java:695)
    at org.apache.ignite.internal.binary.BinaryReaderExImpl.deserialize0(BinaryReaderExImpl.java:1755)
    ....
 Caused by: java.lang.ClassNotFoundException: com.demo.ignite.service.QueryServiceImpl
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    .... 
    at org.apache.ignite.internal.util.IgniteUtils.forName(IgniteUtils.java:8465)
    at org.apache.ignite.internal.MarshallerContextImpl.getClass(MarshallerContextImpl.java:347)
    at org.apache.ignite.internal.binary.BinaryContext.descriptorForTypeId(BinaryContext.java:686)

我的QueryServiceImpl实现了服务,QueryService,其中QueryService是一个带有runContinuousQuery()方法的接口。

请注意,我没有手动将这个jar/类复制到服务器类路径中。我期望ignite将所需的类加载到Ignite服务器节点并在那里运行服务。我该怎么做呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-17 15:21:47

目前服务不支持对等部署,因此您的服务应该在每个节点的类路径上。您可以在文档中找到关于它的注释:https://apacheignite.readme.io/docs/service-grid

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45728451

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档