Ignite Spring Integration кажется сломанной с 2.4 (обновление с 2.3)

Мы обновились с 2.3 до 2.4 и поняли, что изменение, внесенное в IgniteSpringBean, на которое есть ссылки в этой добавленной строке в его javadoc, привело к тому, что мы переместили множество ссылок в PostConstruct на handleContextRefresh.

" Следует обратить внимание, что экземпляр Ignite запускается после инициализации всех других bean-компонентов Spring и непосредственно перед обновлением контекста Spring. Это означает, что недопустимо ссылаться на IgniteSpringBean из любых методов инициализации bean-компонента Spring, таких как PostConstruct. Если это требуется чтобы ссылаться на IgniteSpringBean для других целей инициализации bean-компонента, это следует делать из метода прослушивателя ContextRefreshedEvent, объявленного в этом bean-компоненте."

Однако это нарушает конфигурацию транзакции пружины, настроенную согласно предложению, которое я не уверен, как решить. В основном у нас есть нижеприведенное в весеннем приложении xml, где настроены IgniteSpringBean и SpringTransactionManager, который работал в 2.3, но не запускается, ссылаясь на вышеупомянутое изменение с 2.4 (я добавлю исключение через некоторое время, когда моя машина внезапно отключилась),

<bean id="igniteSpringBean" class="org.apache.ignite.IgniteSpringBean">
    <property name="configuration">
        <bean id="grid.cfg" class="org.apache.ignite.configuration.IgniteConfiguration">
            <property name="igniteInstanceName" value="ObjectManagerGrid"/>
            <property name="clientMode" value="true"/>
            ...
            ...
        </bean>
    </property>
</bean>

<!-- Enable Spring transaction abstraction for Ignite transactions -->
<bean id="transactionManager" class="org.apache.ignite.transactions.spring.SpringTransactionManager">
    <property name="igniteInstanceName" value="ObjectManagerGrid"/>
    <property name="transactionConcurrency" value="PESSIMISTIC"/>
</bean>

<!-- Enable annotation-driven transaction configuration/demarcation -->
<tx:annotation-driven/>

Любая подсказка о том, как обойти эту проблему?

Спасибо!

ОБНОВЛЕНИЕ: ниже исключение,

ignite-object-manager - [ОШИБКА] 2018-05-24 18:36:45.133 [main] org.springframework.boot.SpringApplication - сбой запуска приложения org.springframework.beans.factory.BeanCreationException: ошибка при создании компонента с именем'actionManager'определено в ресурсе пути к классу [applicationContext.xml]: сбой вызова метода init; Вложенное исключение - класс org.apache.ignite.IgniteIllegalStateException: экземпляр Ignite с указанным именем не существует. Вы вызывали Ignition.start(..), чтобы запустить экземпляр Ignite? [Имя =ObjectManagerGrid] в org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1628) в org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:555) в орг.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:483) в org.springframework.beans.factory.support..DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) в org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302).BeBean:197) в org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:761..context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) по адресу org.springframework.boot.SpringApplication.refresh(SpringApplication.java:737) в org.springframework.boot.Sava org.springframework.boot.SpringApplication.run(SpringApplication.java:314) в com.brocade.dcm.Application.main(Application.java:63) в sun.reflect.NativeMethodAccessorImpl.invoke0(собственный метод) в sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) в sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) в java.lang.reflect.Method.boj.rag.rag ot.loader.MainMethodRunner.run(MainMethodRunner.java:48) в org.springframework.boot.loader.Launcher.launch(Launcher.java:87) в org.springframework.boot.loader.Launcher.launch (Launcher.junch (Launcher.junch (Launcher.junch (Launcher.junch) 50) at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:51) Причина: org.apache.ignite.IgniteIllegalStateException: экземпляр Ignite с указанным именем не существует. Вы вызывали Ignition.start(..), чтобы запустить экземпляр Ignite? [name=ObjectManagerGrid] в org.apache.ignite.internal.IgnitionEx.grid(IgnitionEx.java:1376) в org.apache.ignite.Ignition.ignite(Ignition.java:530) в org.apache.ignite.transactions.spring.SpringTransactionManager.afterPropertiesSet(SpringTransactionManager.java:357) при org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1687) в org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean (AbstractAutowireCapableBeanFactory. Java:1624) ... 22 общих кадра опущены

1 ответ

Он не был сломан, а исправлен в IGNITE-6555.

К сожалению, это также означает, что вам придется пока найти способ отложить создание / инициализацию SpringTransactionManager.

Подробнее о проблеме в списке пользователей.

Другие вопросы по тегам