> Java > java지도 시간 > 본문

Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법

PHPz
풀어 주다: 2023-09-20 10:10:58
원래의
913명이 탐색했습니다.

Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법

Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI 사용

Java 개발에서 JNDI(Java Naming and Directory Interface)는 이름 지정 및 디렉터리 서비스를 관리하기 위한 표준 API입니다. 이름 지정 서비스에 액세스하는 것뿐만 아니라 데이터베이스에 연결하고 리소스를 관리하는 데에도 사용할 수 있습니다. 이 기사에서는 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법을 소개하고 자세한 코드 예제를 제공합니다.

  1. 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

  1. 在服务器中配置数据源
    接下来,需要在服务器(如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、用户名、密码等信息,以及连接池的一些配置。

  1. 获取数据库连接
    在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

    서버에서 데이터 소스를 설정하세요
      다음으로, 서버(예: Tomcat)의 설정 파일에서 실제 데이터베이스 연결 정보를 설정해야 합니다. 다음은 구성 예입니다(Tomcat의 context.xml 파일).

    1. 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();
      }
      로그인 후 복사
    2. 여기서 연결 URL을 지정하여 jdbc/myDB라는 데이터 소스를 구성합니다. 사용자 이름, 비밀번호 및 기타 정보는 물론 연결 풀의 일부 구성도 포함됩니다.
        데이터베이스 연결 가져오기
      1. Java 코드에서 JNDI를 통해 데이터베이스 연결을 가져옵니다. 다음은 예시입니다.
      2. try {
            if (conn != null) {
                conn.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        로그인 후 복사
        여기서 먼저 JNDI initCtx의 초기 컨텍스트를 생성한 후 이 컨텍스트를 통해 환경 컨텍스트 envCtx를 얻습니다. 다음으로 환경 컨텍스트에서 이전에 구성된 데이터 소스 jdbc/myDB를 얻습니다. 마지막으로 데이터 소스를 통해 데이터베이스 연결을 얻습니다.

        데이터베이스 연결 사용
        데이터베이스 연결을 얻은 후 이를 사용하여 쿼리, 삽입, 업데이트 등과 같은 다양한 데이터베이스 작업을 수행할 수 있습니다. 다음은 간단한 예입니다.

        🎜rrreee🎜🎜데이터베이스 연결 닫기🎜 데이터베이스 연결 사용을 마친 후 리소스를 해제하려면 수동으로 닫아야 합니다. 다음은 데이터베이스 연결을 종료하는 코드 예제입니다. 🎜🎜rrreee🎜위 단계를 통해 JNDI를 사용하여 데이터베이스 연결 및 리소스 관리를 수행할 수 있습니다. JNDI를 사용하면 코드에 연결 매개변수를 하드 코딩하지 않고도 데이터베이스 연결 정보를 구성 파일에서 중앙 집중식으로 관리할 수 있어 코드가 더욱 간결해지고 유지 관리가 용이해진다는 장점이 있습니다. 🎜🎜요약: 🎜이 글에서는 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법을 소개합니다. JNDI 데이터 소스, 서버 구성 데이터 소스 구성, 데이터베이스 연결 확보, 연결 샘플 코드 사용 및 종료를 통해 JNDI를 사용하여 Java 개발 시 데이터베이스 연결 및 리소스를 쉽게 관리할 수 있습니다. 이 글이 JNDI를 배우고 사용하는 개발자들에게 도움이 되기를 바랍니다. 🎜

        위 내용은 Java 개발: 데이터베이스 연결 및 리소스 관리를 위해 JNDI를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿