JDBC 连接池设置不适用于 Glassfish5
JDBC Connection Pool setup not working on Glassfish5
我目前是 Glassfish 应用程序服务器的新手,我一直在按照各种在线教程使用管理界面在服务器上设置 JDBC 连接池。
我可以看到创建的连接池与服务器上默认创建的两个连接池一起列出,如下面的屏幕截图所示
我对这个设置执行了 ping 操作以确保一切正常,但是当我尝试从下面的代码列表中获取与数据库的连接时
public static Connection getDatabaseConnection()
{
Connection con = null;
try {
Context initialContext = new InitialContext();
if ( initialContext == null){
System.out.println("JNDI problem. Cannot get InitialContext.");
}
DataSource datasource = (DataSource)initialContext.lookup("AppDb");
if (datasource != null) {
con = datasource.getConnection();
}
else {
System.out.println("Failed to lookup datasource.");
}
}
catch(Exception ex)
{
System.out.println("error looking up connection");
ex.printStackTrace();
}
return con;
}
但我收到以下错误,指出未找到连接
javax.naming.NamingException: Lookup failed for 'AppDb' in SerialContext[myEnv={java.naming.factory.initial=com.sun.enterprise.naming.impl.SerialInitContextFactory, java.naming.factory.state=com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl, java.naming.factory.url.pkgs=com.sun.enterprise.naming} [Root exception is javax.naming.NameNotFoundException: AppDb not found]
at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:491)
at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:438)
at javax.naming.InitialContext.lookup(InitialContext.java:417)
at javax.naming.InitialContext.lookup(InitialContext.java:417)
at com.keystone.test.User.getDatabaseConnection(User.java:156)
创建一个 JDBC 连接池是不够的,你应该:
1) 在 "JDBC Resources" 部分,创建一个使用您的资源池的资源
2) 为该资源指定一个 JNDI 名称
3) 在您的代码中查找该名称
(比照Payara/GlassFish DataSource JNDI Lookup Reference and JDBC Connection Pool for GlassFish and Payara Java Application Servers)
我目前是 Glassfish 应用程序服务器的新手,我一直在按照各种在线教程使用管理界面在服务器上设置 JDBC 连接池。
我可以看到创建的连接池与服务器上默认创建的两个连接池一起列出,如下面的屏幕截图所示
我对这个设置执行了 ping 操作以确保一切正常,但是当我尝试从下面的代码列表中获取与数据库的连接时
public static Connection getDatabaseConnection()
{
Connection con = null;
try {
Context initialContext = new InitialContext();
if ( initialContext == null){
System.out.println("JNDI problem. Cannot get InitialContext.");
}
DataSource datasource = (DataSource)initialContext.lookup("AppDb");
if (datasource != null) {
con = datasource.getConnection();
}
else {
System.out.println("Failed to lookup datasource.");
}
}
catch(Exception ex)
{
System.out.println("error looking up connection");
ex.printStackTrace();
}
return con;
}
但我收到以下错误,指出未找到连接
javax.naming.NamingException: Lookup failed for 'AppDb' in SerialContext[myEnv={java.naming.factory.initial=com.sun.enterprise.naming.impl.SerialInitContextFactory, java.naming.factory.state=com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl, java.naming.factory.url.pkgs=com.sun.enterprise.naming} [Root exception is javax.naming.NameNotFoundException: AppDb not found]
at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:491)
at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:438)
at javax.naming.InitialContext.lookup(InitialContext.java:417)
at javax.naming.InitialContext.lookup(InitialContext.java:417)
at com.keystone.test.User.getDatabaseConnection(User.java:156)
创建一个 JDBC 连接池是不够的,你应该:
1) 在 "JDBC Resources" 部分,创建一个使用您的资源池的资源
2) 为该资源指定一个 JNDI 名称
3) 在您的代码中查找该名称
(比照Payara/GlassFish DataSource JNDI Lookup Reference and JDBC Connection Pool for GlassFish and Payara Java Application Servers)