26.7. 例子
将键/值放在命名的缓存中:
from("direct:start") .setHeader(InfinispanConstants.OPERATION).constant(InfinispanOperation.PUT) (1) .setHeader(InfinispanConstants.KEY).constant("123") (2) .to("infinispan:myCacheName&cacheContainer=#cacheContainer"); (3)
其中,
- 1 - 设置要执行的操作
- 2 - 设置用于标识缓存中元素的密钥
3 - 使用 registry 中配置的缓存管理器
cacheContainer
,将元素放在名为myCacheName
的缓存中可以配置条目过期前生命周期和/或闲置时间,并从缓存中驱除,例如:
from("direct:start") .setHeader(InfinispanConstants.OPERATION).constant(InfinispanOperation.GET) .setHeader(InfinispanConstants.KEY).constant("123") .setHeader(InfinispanConstants.LIFESPAN_TIME).constant(100L) (1) .setHeader(InfinispanConstants.LIFESPAN_TIME_UNIT.constant(TimeUnit.MILLISECONDS.toString()) (2) .to("infinispan:myCacheName");
其中,
- 1 - 设置条目的寿命
- 2 - 为 lifespan 设置时间单位
查询
from("direct:start") .setHeader(InfinispanConstants.OPERATION, InfinispanConstants.QUERY) .setHeader(InfinispanConstants.QUERY_BUILDER, new InfinispanQueryBuilder() { @Override public Query build(QueryFactory<Query> qf) { return qf.from(User.class).having("name").like("%abc%").build(); } }) .to("infinispan:myCacheName?cacheContainer=#cacheManager") ;
注意
域对象的 .proto 描述符必须注册到远程 Data Grid 服务器,请参阅官方 Infinispan 文档中的 远程查询示例。
Custom Listeners
from("infinispan://?cacheContainer=#cacheManager&customListener=#myCustomListener") .to("mock:result");
myCustomListener
的实例必须存在,Camel 应当能够从 Registry
查找它。我们鼓励用户将 org.apache.camel.component.infinispan.remote.InfinispanRemoteCustomListener
类扩展,并将生成的类标注为 @ClientListener
,它可在软件包 org.infinispan.client.client.hotrod.annotation
中找到。