2017-06-19 69 views
1

我使用這個屬性的Informix版本4.10.6.20151104光速連接池給IFXHOST不會對目標類com.informix.jdbcx.IfxDataSource存在的Informix

spring.informix.datasource.type=com.zaxxer.hikari.HikariDataSource 
spring.informix.datasource.dataSourceClassName=com.informix.jdbcx.IfxDataSource 
     spring.informix.datasource.dataSourceProperties.serverName=CISCO-UCCE-EXP 
     spring.informix.datasource.dataSourceProperties.portNumber=1504 
    spring.informix.datasource.dbcp2.pool-prepared-statements=true 
    spring.informix.datasource.dataSourceProperties.IFXHOST = cisco_ucce_exp_uccx 

得到錯誤此

java.lang.RuntimeException: Property IFXHOST does not exist on target class com.informix.jdbcx.IfxDataSource 
    at com.zaxxer.hikari.util.PropertyElf.setProperty(PropertyElf.java:155) ~[HikariCP-2.4.7.jar:na] 
    at com.zaxxer.hikari.util.PropertyElf.setTargetFromProperties(PropertyElf.java:67) ~[HikariCP-2.4.7.jar:na] 
    at com.zaxxer.hikari.pool.PoolBase.initializeDataSource(PoolBase.java:295) ~[HikariCP-2.4.7.jar:na] 
    at com.zaxxer.hikari.pool.PoolBase.<init>(PoolBase.java:91) ~[HikariCP-2.4.7.jar:na] 
    at com.zaxxer.hikari.pool.HikariPool.<init>(HikariPool.java:101) ~[HikariCP-2.4.7.jar:na] 
    at com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:94) ~[HikariCP-2.4.7.jar:na] 
    at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:111) ~[spring-jdbc-4.3.3.RELEASE.jar:4.3.3.RELEASE] 
    at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:77) ~[spring-jdbc-4.3.3.RELEASE.jar:4.3.3.RELEASE] 

我也試過同樣的配置與參照的 https://docs.oracle.com/cd/E19575-01/821-0185/beanj/index.html 爲IfxIFXHost也是我得到了同樣的問題 好心幫。 PS我是新來阿光

+0

有圍繞'='的行不工作的空間有什麼意義?有沒有上的配置不均壓痕任何意義所示(屬性列表)?與性能檢查後 –

回答

3

之前從未使用過光速,但快速測試顯示你應該添加到數據源來獲取連接屬性:

隨着「IFXHOST」我得到異常:

D:\JJTMP>grep IFXHOST p.java 
               config.addDataSourceProperty("IFXHOST", "420ito"); 
               config.addDataSourceProperty("IfxIFXHOST", "420ito"); 

D:\JJTMP>java p 
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Starting... 
[main] ERROR com.zaxxer.hikari.util.PropertyElf - Property IFXHOST does not exist on target class com.informix.jdbcx.IfxDataSource 
Exception in thread "main" java.lang.NullPointerException 
     at p.main(p.java:64) 

使用 「IfxIFXHOST」 作品:

D:\JJTMP>grep IFXHOST p.java 
               //config.addDataSourceProperty("IFXHOST", "420ito"); 
               config.addDataSourceProperty("IfxIFXHOST", "420ito"); 

D:\JJTMP>javac p.java 

D:\JJTMP>java p 
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Starting... 
[main] INFO com.zaxxer.hikari.pool.PoolBase - HikariPool-1 - Driver does not support get/set network timeout for connections. (M 
ethod not supported : IfxSqliConnect.getNetworkTimeout()) 
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Start completed. 
The Connection Object is of Class: class com.zaxxer.hikari.pool.HikariProxyConnection 
systables,informix      ,1048580 
syscolumns,informix      ,1048581 
sysindices,informix      ,1048582 
systabauth,informix      ,1048583 
syscolauth,informix      ,1048584 

D:\JJTMP> 

和公正的情況下,代碼我使用:

// ----- p.java ----- 
import java.sql.Connection; 
import java.sql.PreparedStatement; 
import java.sql.ResultSet; 
import java.sql.SQLException; 

import javax.sql.DataSource; 

import com.zaxxer.hikari.HikariConfig; 
import com.zaxxer.hikari.HikariDataSource; 

public class p 
{ 

     private static DataSource datasource; 

     public static DataSource getDataSource() 
     { 
       if(datasource == null) 
       { 
         HikariConfig config = new HikariConfig(); 

         config.setDataSourceClassName("com.informix.jdbcx.IfxDataSource"); 
         config.addDataSourceProperty("serverName", "ids1210"); 
         //config.addDataSourceProperty("IFXHOST", "420ito"); 
         config.addDataSourceProperty("IfxIFXHOST", "420ito"); 
         config.addDataSourceProperty("PortNumber", "9088"); 
         config.addDataSourceProperty("databaseName", "sysmaster"); 
         config.addDataSourceProperty("user", "informix"); 
         config.addDataSourceProperty("password", "ximrofni"); 
         config.setMaximumPoolSize(10); 
         config.setAutoCommit(false); 

         datasource = new HikariDataSource(config); 
       } 
       return datasource; 
     } 

     public static void main(String[] args) 
     { 

       Connection connection = null; 
       PreparedStatement pstmt = null; 
       ResultSet resultSet = null; 
       try 
       { 
         DataSource dataSource = p.getDataSource(); 
         connection = dataSource.getConnection(); 
         pstmt = connection.prepareStatement("SELECT FIRST 5 * FROM systables"); 

         System.out.println("The Connection Object is of Class: " + connection.getClass()); 

         resultSet = pstmt.executeQuery(); 
         while (resultSet.next()) 
         { 
           System.out.println(resultSet.getString(1) + "," + resultSet.getString(2) + "," + resultSet.getString(3)); 
         } 

       } 
       catch (Exception e) 
       { 
         try 
         { 
           connection.rollback(); 
         } 
         catch (SQLException e1) 
         { 
           e1.printStackTrace(); 
         } 
         e.printStackTrace(); 
       } 

     } 

} 

// ----- p.java ----- 
+0

感謝,我發現是越來越增值空間 – UchihaObito

0

所以這個工作對我來說

spring.informix.datasource.type=com.zaxxer.hikari.HikariDataSource 
spring.informix.datasource.minimumIdle=10 
spring.informix.datasource.maximumPoolSize=30 
spring.informix.datasource.idleTimeout=500 
spring.informix.datasource.dataSourceClassName=com.informix.jdbcx.IfxDataSource 
spring.informix.datasource.dataSourceProperties.databaseName=db_ 
spring.informix.datasource.dataSourceProperties.serverName=CISCO-UCCE-EXP 
#spring.informix.datasource.dataSourceProperties.url = jdbc:informix-sqli://CISCO-UCCE-EXP:1504/db_cra:INFORMIXSERVER=cisco_ucce_exp_uccx; Protocol=onsoctcp; client_locale=en_US.57372; db_locale=en_US.57372 
spring.informix.datasource.dataSourceProperties.portNumber=1504 
spring.informix.datasource.dbcp2.pool-prepared-statements=true 
spring.informix.datasource.dataSourceProperties.LoginTimeout=0 
spring.informix.datasource.connectionTimeout=0 
spring.informix.datasource.dataSourceProperties.IfxIFXHOST=cisco_ucce_exp_uccx