java - 我是否正确地将 Hibernate 与 Hikari 一起使用?

标签 java hibernate hikaricp

这是我第一次使用 hibernate,所以我有一个小问题。 这种使用 hibernate 5.1 和 hikariCP 2.4.3 的方法正确吗?

我不确定池化是否是这样工作的。

我应该打电话吗

Session session = sessionFactory.openSession();

Session session = sessionFactory.getCurrentSession();

获得 session ? 当我打电话时

session.close();

连接是关闭还是返回到池中。

线程使用 HibernateDataStore 来访问数据库

感谢帮助

配置

<hibernate-configuration>

    <session-factory>
        <property name="hibernate.connection.provider_class">
            org.hibernate.hikaricp.internal.HikariCPConnectionProvider
        </property>
        <property name="hibernate.hikari.dataSourceClassName">
            com.mysql.jdbc.jdbc2.optional.MysqlDataSource
        </property>
        <property name="hibernate.hikari.dataSource.url">
            jdbc:mysql://localhost/xyz
        </property>
        <property name="hibernate.hikari.dataSource.user">user</property>
        <property name="hibernate.hikari.dataSource.password">xyz</property>

        <property name="hibernate.hikari.minimumIdle">20</property>
        <property name="hibernate.hikari.maximumPoolSize">100</property>

        <property name="hibernate.current_session_context_class">
            org.hibernate.context.internal.ThreadLocalSessionContext
        </property>

        <!-- SQL dialect -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>

        <!-- Names the annotated entity class -->
        <mapping class="XYZ"/>
    </session-factory>
</hibernate-configuration>

我的 DataStore 类

public class HibernateDataStore implements DataStore {
    private static final Logger logger = LogManager.getLogger();

    /** factory for hibernate sessions */
    private static SessionFactory sessionFactory;

    static {
        setUpHibernate();
    }

    /**
     * set up the hibernate session-factory
     */
    private static void setUpHibernate() {
        logger.debug("building session factory");
        final StandardServiceRegistry registry = new StandardServiceRegistryBuilder()
                .configure( "config/server/hibernate.cfg.xml" )
                .build();
        try {
            sessionFactory = new MetadataSources( registry ).buildMetadata().buildSessionFactory();
        }
        catch (Exception e) {
            logger.error("problems building hibernate sessionFactory " + e.getMessage());

            // The registry would be destroyed by the SessionFactory, but we had trouble building the SessionFactory
            // so destroy it manually.
            StandardServiceRegistryBuilder.destroy( registry );
        }
        logger.debug("finished building session factory");
    }


    @Override
    public void storeProduct(Product product) {
        logger.info("storing product: " + product.getTitle());
        Instant start = Instant.now();

        final Session session = sessionFactory.openSession();
        //final Session session = sessionFactory.getCurrentSession();
        session.beginTransaction();
        session.save( product );
        session.getTransaction().commit();
        session.close();

        Instant stop = Instant.now();
        logger.debug("product saved (took " + Duration.between(start, stop).toMillis() + "ms)");
    }
}

最佳答案

我认为你应该使用Spring来处理 session 工厂

<bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource"
    destroy-method="close">
    <constructor-arg ref="hikariConfig" />
</bean>

<bean id="hikariConfig" class="com.zaxxer.hikari.HikariConfig">
    <property name="poolName" value="springHikariCP" />
    <property name="connectionTestQuery" value="SELECT 1" />
    <property name="dataSourceClassName"
        value="com.mysql.jdbc.jdbc2.optional.MysqlDataSource" />
    <property name="dataSourceProperties">
        <props>
            <prop key="url">jdbc:mysql://localhost:3306/xyz</prop>
            <prop key="user">root</prop>
            <prop key="password"></prop>
        </props>
    </property>
</bean>

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource"></property>
    <property name="packagesToScan" value="com.xyz.model" />
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
            <!-- <prop key="hibernate.hbm2ddl.auto">update</prop> -->
            <prop key="hibernate.show_sql">false</prop>
            <prop key="hibernate.hikari.dataSource.minimumIdle">5</prop>
            <prop key="hibernate.hikari.dataSource.maximumPoolSize">20</prop>
            <prop key="hibernate.hikari.dataSource.idleTimeout">30000</prop>
        </props>
    </property>
</bean>

<bean id="transactionManager"
    class="org.springframework.orm.hibernate4.HibernateTransactionManager"
    p:sessionFactory-ref="sessionFactory">
</bean>

关于java - 我是否正确地将 Hibernate 与 Hikari 一起使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35539517/

相关文章:

postgresql - 如何将一组 ID 映射到 Hibernate 中的其他表?

java - @Transactional 在未提交的事务上采用旧值

java - Spring Boot数据源延迟初始化

java - HikariCP 和服务线程

java - SQLite 卡在 SQLite.trampoline() 方法上

java - 无法将 java.lang.Long 字段 Event.idEvent 设置为 java.lang.Long

hibernate - 如何在 Grails 中创建 "view"域对象

hikaricp - HikariPool 与 HikariDataSource

java - IntStream 分步迭代

Java 移位运算符对于预保存值的作用与对于直接值的作用不同