我们有一个现有的Vaadin 8 JavaEE webapp,它已经过Tickets Dashboard演示的调整和大量修改。我们正在计划一个计划,将应用程序迁移到使用Spring(非启动)并采用MVC模型用于下一个版本。但是,在阅读了Vaadin Spring文档并比较当前应用程序,样本烘焙应用程序(spring,使用Framework 8)和使用Hibernate 4和Spring 4的旧项目之间的源代码之后,我们仍然有一些关键问题,需要帮助改进我们的迁移方法:
我们之前在Vaadin论坛上提出了关于逐步迁移的问题,但没有任何回复:https://vaadin.com/forum/thread/17468362/17468363
计划的移民活动后我们的近期目标是:
如上所述,这适用于使用MSSQL数据库和TomEE Plume容器在Azure Cloud上运行。
我们做了一些初步的代码修改,包括:
网嗯
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<listener>
<listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
</listener>
<servlet>
<servlet-name>SycardaDashboard2</servlet-name>
<servlet-class>com.example.dashboard.DashboardServlet</servlet-class>
<init-param>
<param-name>UI</param-name>
<param-value>com.example.dashboard.DashboardUI</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>SycardaDashboard2</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
应用程序的context.xml
<beans>
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath*:application-development.properties</value>
<value>classpath*:application-production.properties</value>
</list>
</property>
</bean>
<import resource="classpath*:applicationContext-dao.xml" />
<import resource="classpath*:applicationContext-service.xml" />
<context:component-scan base-package="com.example.dashboard">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
</beans>
应用道的context.xml
<!-- Activates scanning of @Autowired -->
<context:annotation-config/>
<!-- Activates scanning of @Repository -->
<context:component-scan base-package="com.igi.sycarda.dashboard.dao"/>
<bean class="org.springframework.orm.hibernate4.HibernateExceptionTranslator"/>
<bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/>
<bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean" destroy-method="destroy">
<property name="dataSource" ref="dataSource" />
<property name="packagesToScan">
<list>
<value>com.example.dashboard.entities</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.query.substitutions">true 'Y', false 'N'</prop>
<prop key="hibernate.cache.use_second_level_cache">true</prop>
<prop key="hibernate.cache.use_query_cache">true</prop>
<prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</prop>
<prop key="current_session_context_class">thread</prop>
<prop key="show_sql">${hibernate.show.sql}</prop>
<prop key="format_sql">${hibernate.format.sql}</prop>
<prop key="use_sql_comments">${hibernate.use.sql.comments}</prop>
</props>
</property>
</bean>
<!-- Transaction manager for a single Hibernate SessionFactory (alternative to JTA) -->
<bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
首先,在迁移的第一周之后,我们希望应用程序仍然是90%的JavaEE,并且一个或两个函数将在Spring中。在每周更新之后,现有功能的数量将转变为使用Spring,直到完全合并为止。
这种迁移是可能的。你在问题中有多个问题,我只回答其中两个问题。
IMO是迁移过程中的主要目标,应该进行合理的模块化,并将整体块分成逻辑单元。我不是在谈论单独的可部署和微服务,所以没有必要这么做。但逻辑上拆分它可能会为您提供迁移映射。