使用Spring MVC和Hibernate 4.2.0.Final的多租户Web应用程序

5
我用SpringMVC(3.1.3.RELEASE)和Hibernate 4.2.0.Final开发了一个小型Web应用程序。现在我想将其转换为多租户应用程序。虽然其他帖子已经涉及到类似的主题,但是我无法找到解决我的问题的明确解决方案。我试图设计一个Web应用程序,它能够:1.在启动时读取数据源配置(一个包含多个数据源定义的XML文件,位于WAR文件之外,而且不是应用程序上下文或Hibernate配置文件);2.为每个数据源创建一个会话工厂(考虑到每个数据源都是具有不同模式的数据库);3.如何将我的会话工厂范围设置为会话?(或者我可以重用同一个会话工厂吗?)。例如:
 Url for client a - URL: http://project.com/a/login.html
 Url for client b - URL: http://project.com/b/login.html

如果客户端“a”发出请求,则读取数据源配置文件并使用该XML文件为客户端“a”创建会话工厂。
如果客户端“b”发送请求,则重复相同的过程。
我正在寻找如何在客户订阅时实现数据源创建,而无需编辑Spring配置文件。它需要自动化。
这是我迄今为止完成的代码。
请问有什么修改需要做吗?
请给出一些示例代码的答案。我在Spring和Hibernate世界中还很新。
Spring.xml
  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
        destroy-method="close" p:driverClassName="${jdbc.driverClassName}"

        p:url="${jdbc.databaseurl}" 
p:username="${jdbc.username}" p:password="${jdbc.password}" />

    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="configLocation">
            <value>classpath:hibernate.cfg.xml</value>
        </property>

        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">${jdbc.dialect}</prop>
                <prop key="hibernate.show_sql">true</prop>
            </props>
        </property>
    </bean>

<bean id="transactionManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />

JDBC.properties文件

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.dialect=org.hibernate.dialect.MySQLDialect
jdbc.databaseurl=jdbc:mysql://localhost:3306/Logistics
jdbc.username=root
jdbc.password=rot@pspl#12

hibernate.cfg.xml 文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
    <session-factory>
    <mapping class="pepper.logis.organizations.model.Organizaions" />
    <mapping class="pepper.logis.assets.model.Assets" />

</session-factory>
</hibernate-configuration>

Thanks,


请查看http://mdeinum.wordpress.com/2007/01/05/one-application-per-client-database/。我们使用了一个sessionfactory,多个数据源。尽管代码有所改进,但仍然可用。 - M. Deinum
3个回答

1
首先创建一个租户表,包含租户ID,并将其与所有用户关联。现在,在用户登录时,您可以获取此详细信息并在会话中设置它。

0

我们正在使用AbstractRoutingDataSourceSpring Boot上为每个请求切换数据源。我认为这是@bhantol之前提到的可热交换目标/数据源

它解决了我们的问题,但我不认为这是一个稳妥的解决方案。我想JNDI可能比AbstractRoutingDataSource更好。


0

想知道你最终得到了什么。

这里有一些建议。

选项1)单个应用程序实例。

使用你实际尝试实现的东西来做到这一点有些雄心勃勃。
要点是在同一个JVM上部署完全相同的应用程序,但使用不同的上下文根。您仍然可以像真正的多租户应用程序一样整体调整JVM。但这是以类、上下文、本地缓存、启动时间等的重复为代价的。

但是,截至今天,Spring Framework 4.0并没有提供太多的多租户支持(除了可热交换的目标/数据源等)。我正在寻找一个好的框架,但现在离开Spring可能对我来说是一种浪费。

选项2)同一应用程序的多个部署(作为今天更实际的选择)

只需将完全相同的应用程序部署到同一个应用程序服务器JVM实例甚至不同的实例中即可。

如果您使用相同的实例,则现在可能需要引导您的应用程序以基于实例应该提供的DataSource进行拾取,例如client=a属性就足以拾取**a**DataSource或**b**DataSource。我自己最终采用了这种方法。

如果您有不同的应用服务器实例,您可以配置不同的JNDI路径并通用处理。无需使用client="a"属性,因为您可以自由定义具有相同名称但数据源不同的内容。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接