Клиент когерентного кэша, обращающийся к разным кэшам в разных кластерах - PullRequest
2 голосов
/ 17 декабря 2011

У нас есть 2 кэша в разных кластерах. Я хочу получить доступ к ним обоим через моего расширенного клиента. Я могу получить доступ к первому кэшу (любому), но затем не удается получить доступ ко второму.

Например:

NamedCache cacheOne= CacheFactory.getCache("Cache-One");
NamedCache cacheTwo= CacheFactory.getCache("Cache-Two");

Второй вызов не удастся:

Exception in thread "main" java.lang.IllegalArgumentException: No scheme for cache: "Cache-Two".

Как я могу получить доступ к обоим кешам через клиента? Конфигурация клиента ниже:

*

<cache-config>
    <caching-scheme-mapping>
        <cache-mapping>
            <cache-name>Cache-One</cache-name>
            <scheme-name>Scheme-One</scheme-name>
        </cache-mapping>
        <cache-mapping>
            <cache-name>Cache-Two</cache-name>
            <scheme-name>Scheme-Two</scheme-name>
        </cache-mapping>
    </caching-scheme-mapping>
    <caching-schemes>
        <remote-cache-scheme>
            <scheme-name>Scheme-One</scheme-name>
            <service-name>TCPProxyCacheService</service-name>
            <initiator-config>
                <tcp-initiator>
                    <remote-addresses>
                        <socket-address>
                            <address>address of proxy one</address>
                            <port>2077</port>
                        </socket-address>
                    </remote-addresses>
                    <connect-timeout>300s</connect-timeout>
                </tcp-initiator>
                <outgoing-message-handler>
                    <request-timeout>300s</request-timeout>
                </outgoing-message-handler>
            </initiator-config>
        </remote-cache-scheme>
        <remote-cache-scheme> 
              <scheme-name>extend-castle</scheme-name> 
              <service-name>TCPProxyCacheService</service-name> 
              <initiator-config> 
                  <tcp-initiator> 
                     <remote-addresses> 
                               <socket-address> 
                                   <address>address of proxy two</address> 
                                  <port>20088</port> 
                               </socket-address> 
                      </remote-addresses> 
                      <connect-timeout>300s</connect-timeout> 
                   </tcp-initiator> 
                   <outgoing-message-handler> 
                      <request-timeout>300s</request-timeout> 
                   </outgoing-message-handler> 
              </initiator-config> 
        </remote-cache-scheme> 
    </caching-schemes>
</cache-config>

*

1 Ответ

1 голос
/ 18 декабря 2011

Вы определили схему extend-castle, где должна быть определена схема Scheme-Two.Измените имя схемы во втором remote-cache-scheme на Scheme-Two или измените имя схемы во втором cache-mapping на extend-castle.

...