ホームページ > Java > &#&チュートリアル > JNDI (Java Naming and Directory Interface) の概要

JNDI (Java Naming and Directory Interface) の概要

Patricia Arquette
リリース: 2024-10-22 06:12:02
オリジナル
855 人が閲覧しました

Quick look of JNDI (Java Naming and Directory Interface)

簡単に言うと、プログラマは同じ JNDI インターフェイスを使用して次のクエリを実行できます

  • データ ソースなど、アプリケーション サーバーによって提供されるリソースを検索します
  • LDAP エントリを検索
  • DNS レコードを検索

簡単な紹介はこちらです。

コード

アプリケーションサーバーのリソースは、"java:comp/env" プレフィックスの下に配置されます。データソースがオンであると仮定します

java:/comp/env/jdbc/db1
ログイン後にコピー

そのデータ ソースを取得するには

javax.naming.Context initialContext = new javax.naming.InitialContext();
javax.naming.Context subContext = (javax.naming.Context) initialContext.lookup("java:comp/env");
DataSource dataSource = (DataSource) subContext.lookup("jdbc/db1");
ログイン後にコピー

または、フルパスを指定してインスタンスを直接取得することもできます

javax.naming.Context initialContext = new javax.naming.InitialContext();
DataSource dataSource = (DataSource) initialContext.lookup("java:comp/env/jdbc/db1");
ログイン後にコピー

Spring Bootの統合

application.properties
に行を追加するだけです

spring.datasource.jndi-name=java:/comp/env/jdbc/db1
ログイン後にコピー

関連 Bean は org.springframework.boot.autoconfigure.jdbc.JndiDataSourceAutoConfiguration
によって作成されます。

@Configuration(proxyBeanMethods = false)
@AutoConfigureBefore({ XADataSourceAutoConfiguration.class, DataSourceAutoConfiguration.class })
@ConditionalOnClass({ DataSource.class, EmbeddedDatabaseType.class })
@ConditionalOnProperty(prefix = "spring.datasource", name = "jndi-name")
@EnableConfigurationProperties(DataSourceProperties.class)
public class JndiDataSourceAutoConfiguration {

    @Bean(destroyMethod = "")
    @ConditionalOnMissingBean
    public DataSource dataSource(DataSourceProperties properties, ApplicationContext context) {
        JndiDataSourceLookup dataSourceLookup = new JndiDataSourceLookup();
        DataSource dataSource = dataSourceLookup.getDataSource(properties.getJndiName());
        excludeMBeanIfNecessary(dataSource, "dataSource", context);
        return dataSource;
    }

    private void excludeMBeanIfNecessary(Object candidate, String beanName, ApplicationContext context) {
        for (MBeanExporter mbeanExporter : context.getBeansOfType(MBeanExporter.class).values()) {
            if (JmxUtils.isMBean(candidate.getClass())) {
                mbeanExporter.addExcludedBean(beanName);
            }
        }
    }

}
ログイン後にコピー

以上がJNDI (Java Naming and Directory Interface) の概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート