当前位置: 首页 > 知识库问答 >
问题:

camel-sql使用者数据库连接问题

栾鸣
2023-03-14

我正在使用Apache Camel和Spring Boot。我在没有任何服务器的情况下使用我的spring boot应用程序作为jar。

共有1个答案

松英叡
2023-03-14

下面是我的一个Oracle配置:

<cm:property-placeholder id="server.placeholder" persistent-id="name.of.company.datasource">
    <cm:default-properties>
        <cm:property name="db.host" value="host"/>
        <cm:property name="db.port" value="1521"/>
        <cm:property name="db.instance" value="dbname"/>
        <cm:property name="db.user" value="user"/>
        <cm:property name="db.password" value="password"/>
        <cm:property name="driverClassName" value="oracle.jdbc.pool.OracleDataSource" />
        <cm:property name="validationQuery" value="SELECT 1 FROM DUAL" />
        <cm:property name="defaultReadOnly" value="false" />
        <cm:property name="defaultAutoCommit" value="true" />
        <cm:property name="maxActive" value="100" />
        <cm:property name="whenExhaustedAction" value="2" />
        <cm:property name="maxWait" value="-1" />
        <cm:property name="maxIdle" value="8" />
        <cm:property name="minIdle" value="1" />
        <cm:property name="testOnBorrow" value="true" />
        <cm:property name="testOnReturn" value="true" />
        <cm:property name="timeBetweenEvictionRunsMillis" value="-1" />
        <cm:property name="numTestsPerEvictionRun" value="3" />
        <cm:property name="minEvictableIdleTimeMillis" value="1800000" />
        <cm:property name="testWhileIdle" value="false" />
        <cm:property name="softMinEvictableIdleTimeMillis" value="-1" />
        <cm:property name="lifo" value="true" />
    </cm:default-properties>
</cm:property-placeholder>

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
  <property name="driverClassName" value= "${driverClassName}" />
  <property name="url" value="jdbc:oracle:thin:@${db.host}:${db.port}:${db.instance}" />
  <property name="username" value="${db.user}" />
  <property name="password" value="${db.password}" />
  <property name="maxIdle" value="1" />
</bean>

<bean id="connectionFactory" class="org.apache.commons.dbcp.DataSourceConnectionFactory">
  <argument ref="dataSource" />
</bean>

<bean id="connectionPool" class="org.apache.commons.pool.impl.GenericObjectPool" >
  <argument><null/></argument>
  <argument value="${maxActive}" />
  <argument value="${whenExhaustedAction}" />
  <argument value="${maxWait}" />
  <argument value="${maxIdle}" />
  <argument value="${minIdle}" />
  <argument value="${testOnBorrow}" />
  <argument value="${testOnReturn}" />
  <argument value="${timeBetweenEvictionRunsMillis}" />
  <argument value="${numTestsPerEvictionRun}" />
  <argument value="${minEvictableIdleTimeMillis}" />
  <argument value="${testWhileIdle}" />
  <argument value="${softMinEvictableIdleTimeMillis}" />
  <argument value="${lifo}" />
</bean>

<bean id="pooledConnectionFactory" class="org.apache.commons.dbcp.PoolableConnectionFactory" >
  <argument ref="connectionFactory" />
  <argument ref="connectionPool" />
  <argument><null/></argument>
  <argument value="${validationQuery}" />
  <argument value="${defaultReadOnly}" />
  <argument value="${defaultAutoCommit}" />
</bean>

<bean id="poolingDataSource" class="org.apache.commons.dbcp.PoolingDataSource" depends-on="pooledConnectionFactory">
  <argument ref="connectionPool" />
</bean>

<service interface="javax.sql.DataSource" ref="poolingDataSource"> 
    <service-properties>
        <entry key="osgi.jndi.service.name" value="jdbc/oracle/db"/>
        <entry key="datasource.name" value="jdbc/oracle/db" />
    </service-properties>
</service>

也许会对你有帮助。我认为DB连接只是没有时间在查询之间返回池。您需要配置连接超时和类似的参数(idle params、minEvictableIdleTimeMillis、timeBetweenEvictionRunsMillis、numTestsPerEvictionRun)。

 类似资料:
  • 本文向大家介绍java连接mysql数据库 java连接sql server数据库,包括了java连接mysql数据库 java连接sql server数据库的使用技巧和注意事项,需要的朋友参考一下 在java的应用中,我们经常会对数据库进行必要的操作,下来我们就了解一下如何用java连接mysql数据库 以及java连接sql server数据库 一、mysql 二、sql server 以上就

  • 问题内容: 我正在使用SQL Server 2008 R2和Microsoft Excel。 我已将服务器设置为通过Windows用户 或 数据库用户登录 我 可以 用数据库用户正常登录数据库 我 可以 使用Silverlight应用程序连接到数据库 我 无法 弄清楚如何从Excel中的远程PC连接 我去了Excel->数据->从其他来源->从SQL Server 我的服务器名称是,因此在Exce

  • 我想通过camunda连接sql server数据库(更明确地说,我想将脚本处理器解析的数据写入spl server数据库),我已经在conf/server.xml中添加了这些配置 我想知道我应该在我的camunda项目或camunda Modeler中配置或添加什么,以使我的项目在databse Tabeles中写入这些数据? 你能给我链接任何示例或教程吗?whiach能帮助我实现这个逻辑吗?我

  • 我正在尝试使用jdbc连接到我的MS SQL2008数据库,如下所示,但它的给出错误 我的数据库名为,实例名为。请建议我如何提供数据库实例名称和数据库名称在URL。 上面写着 但是当我尝试用相同的用户名和密码从DB GUI登录时,它被登录了。想知道在jdbc设置中在哪里提供数据库实例的详细信息 我也试过用下面的dut不管用

  • ConnectionURL=“jdbc:jtds:sqlserver://havvasemserv3.database.windows.net:1433;DatbaseName=Newfin;用户=;密码=;加密=真;trustServerCertificate=false;hostNameInCertificate=*。数据库窗户。网loginTimeout=30”; } 我正在尝试将azure

  • 主要内容:1.引入jar包,2.配置文件编写,3.编写数据库,4.编写实体类,5.编写Mapper接口,6.在业务层中引入用户的用户名和密码,7.测试1.引入jar包 2.配置文件编写 appilication.properties 需要注意后面需要加上时区,因为当前引入的是SpringBoot2以上的版本 3.编写数据库 4.编写实体类 5.编写Mapper接口 这里是继承了BaseMapper接口 6.在业务层中引入用户的用户名和密码 第一个是导入UserMapper接口 第二个是根据接口去