使用SpringMVC和Hibernate4.2.0.Final的多租户webapp

使用SpringMVC和Hibernate4.2.0.Final的多租户webapp,spring,hibernate,spring-mvc,spring-security,multi-tenant,Spring,Hibernate,Spring Mvc,Spring Security,Multi Tenant,我使用SpringMVC(3.1.3.RELEASE)和Hibernate4.2.0.Final开发了一个小的webapp 我正在尝试将其转换为多租户应用程序 类似的主题已经在其他线程中讨论过,但我无法找到解决问题的最终方法 我试图实现的是设计一个能够: 在启动时读取数据源配置(一个包含多个数据源定义的XML文件,位于WAR文件之外,不是应用程序上下文或hibernate配置文件) 为它们中的每一个创建一个会话工厂(考虑到每个数据源都是一个具有不同模式的数据库) 如何将会话工厂范围设置为会话?(

我使用SpringMVC(3.1.3.RELEASE)和Hibernate4.2.0.Final开发了一个小的webapp

我正在尝试将其转换为多租户应用程序

类似的主题已经在其他线程中讨论过,但我无法找到解决问题的最终方法

我试图实现的是设计一个能够:

  • 在启动时读取数据源配置(一个包含多个数据源定义的XML文件,位于WAR文件之外,不是应用程序上下文或hibernate配置文件)

  • 为它们中的每一个创建一个会话工厂(考虑到每个数据源都是一个具有不同模式的数据库)

  • 如何将会话工厂范围设置为会话?(或者我可以重用同一会话工厂吗?)

  • 例如:

     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.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" />
    
    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>
    
    
    

    谢谢,

    首先为具有租户id的租户创建一个表,并将其与所有用户关联。现在,您可以在用户登录时获取此详细信息并在会话中进行设置。

    不知道您最终得到了什么

    这里有一些想法给你

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

    使用您实际想要实现的目标来实现这一点有些雄心勃勃。
    要点是简单地在同一JVM上部署具有不同上下文根的相同应用程序。您仍然可以将JVM作为一个整体进行调优,就像您拥有一个真正的多租户应用程序一样。但这是以类、上下文、本地缓存、启动时间等的重复为代价的

    但是到今天为止,SpringFramework4.0还没有提供太多的多租户支持(除了可热交换的目标/数据源)等等。我正在寻找一个好的框架,但对我来说,现在离开Spring可能是一个好机会

    选项2)同一应用程序的多个部署(目前更加实用)

    只需将相同的应用程序部署到相同的应用程序服务器JVM实例,甚至不同的实例

    如果您使用相同的实例,您现在可能需要引导应用程序根据实例应提供的服务来拾取数据源,例如,client=a属性将足以拾取**a**数据源”或**b**数据源。我本人最终采用了这种方法


    如果您有一个不同的应用程序服务器实例,您可以只配置一个不同的JNDI路径,并以一般方式处理问题“属性,因为您可以使用相同的名称以不同的方式定义数据源

    我们正在使用
    AbstractRoutingDataSource
    为每个请求切换数据源。我认为这是上面提到的
    热交换目标/数据源

    它解决了我们的问题,但我认为这不是一个好的解决方案。我想这可能比
    AbstractRoutingDataSource
    更好。我们使用了一个sessionfactory、多个数据源。代码仍然可用,尽管从那时起它有了一些发展。
    <?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>