Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법
Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI 사용
Java 개발에서 JNDI(Java Naming and Directory Interface)는 이름 지정 및 디렉터리 서비스를 관리하기 위한 표준 API입니다. 이름 지정 서비스에 액세스하는 것뿐만 아니라 데이터베이스에 연결하고 리소스를 관리하는 데에도 사용할 수 있습니다. 이 기사에서는 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법을 소개하고 자세한 코드 예제를 제공합니다.
- JNDI 데이터 소스 구성
먼저 Java 웹 애플리케이션(예: web.xml)의 구성 파일에 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
。
- 在服务器中配置数据源
接下来,需要在服务器(如Tomcat)的配置文件中,配置实际的数据库连接信息。以下是一个示例配置(在Tomcat的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、用户名、密码等信息,以及连接池的一些配置。
- 获取数据库连接
在Java代码中,通过JNDI来获取数据库连接。以下是一个示例:
// 创建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
- 서버에서 데이터 소스를 설정하세요
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(); }
로그인 후 복사여기서 연결 URL을 지정하여 - Java 코드에서 JNDI를 통해 데이터베이스 연결을 가져옵니다. 다음은 예시입니다.
- 다음으로, 서버(예: Tomcat)의 설정 파일에서 실제 데이터베이스 연결 정보를 설정해야 합니다. 다음은 구성 예입니다(Tomcat의
context.xml
파일). jdbc/myDB
라는 데이터 소스를 구성합니다. 사용자 이름, 비밀번호 및 기타 정보는 물론 연결 풀의 일부 구성도 포함됩니다. - 데이터베이스 연결 가져오기
try { if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); }
initCtx
의 초기 컨텍스트를 생성한 후 이 컨텍스트를 통해 환경 컨텍스트 envCtx
를 얻습니다. 다음으로 환경 컨텍스트에서 이전에 구성된 데이터 소스 jdbc/myDB
를 얻습니다. 마지막으로 데이터 소스를 통해 데이터베이스 연결을 얻습니다.
데이터베이스 연결 사용
데이터베이스 연결을 얻은 후 이를 사용하여 쿼리, 삽입, 업데이트 등과 같은 다양한 데이터베이스 작업을 수행할 수 있습니다. 다음은 간단한 예입니다.
위 내용은 Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











데이터베이스 작업에 MyBatis-Plus 또는 기타 ORM 프레임 워크를 사용하는 경우 엔티티 클래스의 속성 이름을 기반으로 쿼리 조건을 구성해야합니다. 매번 수동으로 ...

일부 애플리케이션이 제대로 작동하지 않는 회사의 보안 소프트웨어에 대한 문제 해결 및 솔루션. 많은 회사들이 내부 네트워크 보안을 보장하기 위해 보안 소프트웨어를 배포 할 것입니다. ...

시스템 도킹의 필드 매핑 처리 시스템 도킹을 수행 할 때 어려운 문제가 발생합니다. 시스템의 인터페이스 필드를 효과적으로 매핑하는 방법 ...

IntellijideAultimate 버전을 사용하여 봄을 시작하십시오 ...

Java 객체 및 배열의 변환 : 캐스트 유형 변환의 위험과 올바른 방법에 대한 심층적 인 논의 많은 Java 초보자가 객체를 배열로 변환 할 것입니다 ...

다른 아키텍처 CPU에 대한 Java 프로그램의 메모리 누출 현상 분석. 이 기사는 Java 프로그램이 ARM과 X86 Architecture CPU에 다른 메모리 동작을 보여주는 사례에 대해 논의합니다.

그룹 내에서 정렬을 구현하기 위해 이름을 숫자로 변환하는 방법은 무엇입니까? 그룹으로 사용자를 정렬 할 때는 종종 사용자 이름을 숫자로 변환하여 다르게 만들 수 있습니다 ...

Redis 캐싱 솔루션은 제품 순위 목록의 요구 사항을 어떻게 인식합니까? 개발 과정에서 우리는 종종 a ... 표시와 같은 순위의 요구 사항을 처리해야합니다.
