Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI 사용
Java 개발에서 JNDI(Java Naming and Directory Interface)는 이름 지정 및 디렉터리 서비스를 관리하기 위한 표준 API입니다. 이름 지정 서비스에 액세스하는 것뿐만 아니라 데이터베이스에 연결하고 리소스를 관리하는 데에도 사용할 수 있습니다. 이 기사에서는 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법을 소개하고 자세한 코드 예제를 제공합니다.
<resource-ref> <description>Database Connection</description> <res-ref-name>jdbc/myDB</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref>
여기에서는 jdbc/myDB
라는 JNDI 데이터 소스를 정의하고 해당 유형을 javax.sql.DataSource
로 지정합니다. jdbc/myDB
的JNDI数据源,并指定了其类型为javax.sql.DataSource
。
context.xml
文件中):<Resource name="jdbc/myDB" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/myDB" username="root" password="password" maxTotal="100" maxIdle="30" maxWaitMillis="10000" />
这里,我们配置了一个名为jdbc/myDB
的数据源,指定了连接的URL、用户名、密码等信息,以及连接池的一些配置。
// 创建JNDI上下文 Context initCtx = new InitialContext(); Context envCtx = (Context) initCtx.lookup("java:comp/env"); // 获取数据源 DataSource ds = (DataSource) envCtx.lookup("jdbc/myDB"); // 获取数据库连接 Connection conn = ds.getConnection();
这里,我们首先创建了JNDI的初始上下文initCtx
,然后通过该上下文获取了环境上下文envCtx
。接着,我们从环境上下文中获取了之前配置好的数据源jdbc/myDB
context.xml
파일). try { Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM users"); while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); System.out.println("User: " + id + ", " + name); } rs.close(); stmt.close(); } catch (SQLException e) { e.printStackTrace(); }
jdbc/myDB
라는 데이터 소스를 구성합니다. 사용자 이름, 비밀번호 및 기타 정보는 물론 연결 풀의 일부 구성도 포함됩니다. try { if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); }
initCtx
의 초기 컨텍스트를 생성한 후 이 컨텍스트를 통해 환경 컨텍스트 envCtx
를 얻습니다. 다음으로 환경 컨텍스트에서 이전에 구성된 데이터 소스 jdbc/myDB
를 얻습니다. 마지막으로 데이터 소스를 통해 데이터베이스 연결을 얻습니다.
데이터베이스 연결 사용
데이터베이스 연결을 얻은 후 이를 사용하여 쿼리, 삽입, 업데이트 등과 같은 다양한 데이터베이스 작업을 수행할 수 있습니다. 다음은 간단한 예입니다.
위 내용은 Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!