MySQL 集群(主/从)和休眠

Jer*_*ese 5 mysql spring hibernate

开发时的应用是单数据库,spring配置如下。

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="com.mysql.jdbc.Driver" />
    <property name="url" value="jdbc:mysql://localhost:3306/test" />
    <property name="username" value="root" />
    <property name="password" value="" />
</bean>


<bean id="hibernateProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
    <property name="properties">
    <props>
        <prop key="hibernate.hbm2ddl.auto">update</prop>
        <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
        ...
        </props>
    </property>
</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource">
        <ref local="dataSource" />
    </property>
    <property name="hibernateProperties">
    <ref bean="hibernateProperties" />
    </property>
    <property name="mappingResources">
    <list>
        <value>...</value>
    </list>
    </property>
</bean>

<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="dataSource" ref="dataSource" />
    <property name="sessionFactory" ref="sessionFactory" />
</bean>
Run Code Online (Sandbox Code Playgroud)

然而,对于生产,有可能使用 MySQL 集群或主/从复制。关于此代码/配置更改的任何想法?

还有一个对所有人的快速问题 - 在专用服务器上运行的单个 mysql 服务器实例可以处理多少事务/秒?

mls*_*ter 1

我曾经研究过类似的问题,尽管 Spring 没有涉及。我们针对 MySQL 的本地实例进行开发(每个开发人员的盒子上都有一个),生产系统是一个主/从复制环。我们实际上更进一步,将应用程序服务器与数据库服务器放在同一位置,因此应用程序和数据库级别都有一个四节点集群。

我们的应用程序在 JBoss 中运行。它相当轻,但在应用程序服务器级别确实有一些严重的集群。尽管如此,我们每秒能够处理超过 300 个请求,有时甚至接近每秒 1000 个请求(取决于应用程序处理)。数据库从来都不是瓶颈 - 即使在这样的速率下,我们也很少看到连接池超过 5 个连接。

在这两种情况下(我的和你的),由于 JDBC URL 指向本地服务器,因此从应用程序的角度来看,实际上没有任何功能差异。我必须玩一些有趣的配置游戏,使用自动增量设置来防止数据被踩到;如果您只有一个部署点(因此只有一个对 MySQL 实例的访问点),则无需担心这些问题。

因此,没有代码更改,也没有配置更改。它会起作用的。在标准条件下,您由主/从实例对或集群支持的事实不会产生影响,因为您很可能指向集群前面的主实例或 MySQL 实例(在 MySQL 中) ,集群位于一台或多台数据库服务器后面,复制数据)。

您希望处理什么类型的负载?MySQL过去的基准测试结果为 >1000 TPS,但结果往往会根据底层系统特性(内存、CPU 内核、处理器速度)、应用程序的响应能力和并发线程而有所不同。