gpt4 book ai didi

java - 从本地用户和 glassfish 到 Mysql DB 的并发连接

转载 作者:行者123 更新时间:2023-11-29 03:09:19 26 4
gpt4 key购买 nike

我的 Glassfish Web 应用程序有问题:我在我的 glassfish 应用程序上使用持久性提供程序和 EJB 接口(interface)。 Mysql 连接配置为 JDBC 资源。问题是当我在本地更新数据库(使用 mysql promt 或其他客户端)时,glassfish 服务器仍然“看到”旧值。我意识到在 glassfis 服务器和 Msyql DB 之间的某处可能存在某种类型的缓存。我很确定我可以更改一些参数来解决这个问题,但是在搜索了一段时间之后我似乎找不到它。任何人都可以指导我到有问题的地区吗? mysql JDBC 驱动器?网络.xml?连接池?

一些技术细节:数据库:Mysql 5.1服务器:Glassfish 3.1服务器正在使用 root 用户名连接到数据库我在 glassfish 应用程序上使用 EclipseLink 作为持久性提供程序配置(sun-resources.xml):

<jdbc-connection-pool allow-non-component-callers="false" associate-with-thread="false" connection-creation-retry-attempts="0" connection-creation-retry-interval-in-seconds="10" connection-leak-reclaim="false" connection-leak-timeout-in-seconds="0" connection-validation-method="auto-commit" datasource-classname="com.mysql.jdbc.jdbc2.optional.MysqlDataSource" fail-all-connections="false" idle-timeout-in-seconds="300" is-connection-validation-required="false" is-isolation-level-guaranteed="true" lazy-connection-association="false" lazy-connection-enlistment="false" match-connections="false" max-connection-usage-count="0" max-pool-size="32" max-wait-time-in-millis="60000" name="mysql_drivingschool_rootPool" non-transactional-connections="false" pool-resize-quantity="2" res-type="javax.sql.DataSource" statement-timeout-in-seconds="-1" steady-pool-size="8" validate-atmost-once-period-in-seconds="0" wrap-jdbc-objects="false">
<property name="serverName" value="localhost"/>
<property name="portNumber" value="3306"/>
<property name="databaseName" value="drivingschool"/>
<property name="User" value="*****"/>
<property name="Password" value="****"/>
<property name="URL" value="jdbc:mysql://localhost:3306/******"/>
<property name="driverClass" value="com.mysql.jdbc.Driver"/>
</jdbc-connection-pool>

最佳答案

JPA 使用两层缓存机制。一级缓存是当前的 PersistenceContext。二级缓存在不同上下文之间共享。

您可以控制缓存行为。它取决于您使用的 JPA 实现。由于您在 EclipseLink 上,请参阅 this introduction .但是,这会降低应用程序的性能。

如果我们需要手动更新数据库,我们会重新启动应用程序(而不是服务器)。如果它在生产状态下更频繁地发生,您应该直接从数据库中获取相关数据。

关于java - 从本地用户和 glassfish 到 Mysql DB 的并发连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10750416/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com