池化 LDAP 连接有助于减少为每个 LDAP 交互创建新的 LDAP 连接的开销。虽然存在 Java LDAP 池支持,但它的配置选项和功能(如连接验证和池维护)受到限制。Spring LDAP 提供了对每个 - 基础上的详细池配置的支持。ContextSourcespring-doc.cn

通过在应用程序上下文配置中为元素提供 child 元素来提供池化支持。只读和读写对象分别共用(如果指定)。Jakarta Commons-Pool 用于提供底层的矿池实现。<ldap:pooling /><ldap:context-source />DirContextanonymous-read-onlyspring-doc.cn

DirContext验证

验证池连接是使用自定义池库而不是 JDK 提供的 LDAP 池功能的主要动机。验证允许检查池连接,以确保在将池连接签出池、将其签入池中或当它们在池中处于空闲状态时,这些连接仍正确连接和配置。DirContextspring-doc.cn

如果配置了连接验证,则使用 验证池连接。 执行 , 如果名称为空,过滤器为 ,并设置为限制具有唯一 the 属性和 500ms 超时的单个结果。如果返回的 s 有结果,则 通过验证。如果未返回任何结果或引发异常,则验证失败。 在大多数 LDAP 服务器上,默认设置应该无需更改配置即可使用,并且提供了验证 . 如果需要自定义,可以使用池配置中描述的验证配置属性来实现自定义。DefaultDirContextValidatorDefaultDirContextValidatorDirContext.search(String, String, SearchControls)"objectclass=*"SearchControlsobjectclassNamingEnumerationDirContextDirContextDirContextspring-doc.cn

如果连接引发被视为非暂时性的异常,则连接将自动失效。例如,如果实例引发 ,则会将其解释为非暂时性错误,并且该实例会自动失效,而不会产生其他操作的开销。解释为非瞬态的异常是使用 .DirContextjavax.naming.CommunicationExceptiontestOnReturnnonTransientExceptionsPoolingContextSource
如果连接引发被视为非暂时性的异常,则连接将自动失效。例如,如果实例引发 ,则会将其解释为非暂时性错误,并且该实例会自动失效,而不会产生其他操作的开销。解释为非瞬态的异常是使用 .DirContextjavax.naming.CommunicationExceptiontestOnReturnnonTransientExceptionsPoolingContextSource

池配置

元素上提供了以下属性,用于配置 DirContext 池:<ldap:pooling />spring-doc.cn

表 1.池化配置属性
属性 违约 描述

max-activespring-doc.cn

8spring-doc.cn

可以同时从此池分配的每种类型(只读或读写)的活动连接的最大数量。您可以无限制地使用非正数。spring-doc.cn

max-totalspring-doc.cn

-1spring-doc.cn

可以同时从此池中分配的活动连接总数(适用于所有类型)。您可以无限制地使用非正数。spring-doc.cn

max-idlespring-doc.cn

8spring-doc.cn

每种类型(只读或读写)在池中保持空闲状态而不释放额外连接的最大活动连接数。您可以无限制地使用非正数。spring-doc.cn

min-idlespring-doc.cn

0spring-doc.cn

可以在池中保持空闲状态的每种类型(只读或读写)的活动连接的最小数量,而无需创建额外的连接。您可以使用 0(默认值)来不创建 none。spring-doc.cn

max-waitspring-doc.cn

-1spring-doc.cn

池在引发异常之前等待 (没有可用连接时) 返回连接的最大毫秒数。您可以使用非正数无限期等待。spring-doc.cn

when-exhaustedspring-doc.cn

BLOCKspring-doc.cn

指定池耗尽时的行为。spring-doc.cn

  • 当池耗尽时,将引发该选项。FAILNoSuchElementExceptionspring-doc.cn

  • 该选项将等待,直到有新对象可用。如果为正数,并且在时间到期后没有新对象可用,则引发。BLOCKmax-waitmax-waitNoSuchElementExceptionspring-doc.cn

  • 该选项创建并返回一个新对象(本质上使 THE MEANING 无意义)。GROWmax-activespring-doc.cn

test-on-borrowspring-doc.cn

falsespring-doc.cn

在从池中借用对象之前是否对其进行验证。如果对象验证失败,则会将其从池中删除,并尝试借用另一个对象。spring-doc.cn

test-on-returnspring-doc.cn

falsespring-doc.cn

在将对象返回到池之前是否对其进行验证。spring-doc.cn

test-while-idlespring-doc.cn

falsespring-doc.cn

对象是否由空闲对象 evictor ((如果有) )验证。如果对象验证失败,则会将其从池中删除。spring-doc.cn

eviction-run-interval-millisspring-doc.cn

-1spring-doc.cn

空闲对象 evictor 线程运行之间休眠的毫秒数。当为非正数时,不运行空闲对象 evictor 线程。spring-doc.cn

tests-per-eviction-runspring-doc.cn

3spring-doc.cn

在每次运行空闲对象 evictor 线程期间要检查的对象数(如果有)。spring-doc.cn

min-evictable-time-millisspring-doc.cn

1000 * 60 * 30(30 分钟)spring-doc.cn

对象在有资格被空闲对象 evictor (如果有) 逐出之前,可以在池中处于空闲状态的最短时间。spring-doc.cn

validation-query-basespring-doc.cn

LdapUtils.emptyName()spring-doc.cn

验证连接时使用的搜索库。仅在指定 、 或 时使用。test-on-borrowtest-on-returntest-while-idlespring-doc.cn

validation-query-filterspring-doc.cn

objectclass=*spring-doc.cn

验证连接时使用的搜索筛选条件。仅在指定 、 或 时使用。test-on-borrowtest-on-returntest-while-idlespring-doc.cn

validation-query-search-controls-refspring-doc.cn

null;默认搜索控制设置如上所述。spring-doc.cn

验证连接时要使用的实例的 ID。仅在指定 、 、 或 时使用。SearchControlstest-on-borrowtest-on-returntest-while-idlespring-doc.cn

non-transient-exceptionsspring-doc.cn

javax.naming.CommunicationExceptionspring-doc.cn

以逗号分隔的类列表。列出的异常被视为非暂时性 Age Invalidation 。如果对池化实例的调用引发了列出的任何异常(或其子类),则该对象将自动失效,而无需任何其他 testOnReturn 操作。ExceptionDirContextspring-doc.cn

表 1.池化配置属性
属性 违约 描述

max-activespring-doc.cn

8spring-doc.cn

可以同时从此池分配的每种类型(只读或读写)的活动连接的最大数量。您可以无限制地使用非正数。spring-doc.cn

max-totalspring-doc.cn

-1spring-doc.cn

可以同时从此池中分配的活动连接总数(适用于所有类型)。您可以无限制地使用非正数。spring-doc.cn

max-idlespring-doc.cn

8spring-doc.cn

每种类型(只读或读写)在池中保持空闲状态而不释放额外连接的最大活动连接数。您可以无限制地使用非正数。spring-doc.cn

min-idlespring-doc.cn

0spring-doc.cn

可以在池中保持空闲状态的每种类型(只读或读写)的活动连接的最小数量,而无需创建额外的连接。您可以使用 0(默认值)来不创建 none。spring-doc.cn

max-waitspring-doc.cn

-1spring-doc.cn

池在引发异常之前等待 (没有可用连接时) 返回连接的最大毫秒数。您可以使用非正数无限期等待。spring-doc.cn

when-exhaustedspring-doc.cn

BLOCKspring-doc.cn

指定池耗尽时的行为。spring-doc.cn

  • 当池耗尽时,将引发该选项。FAILNoSuchElementExceptionspring-doc.cn

  • 该选项将等待,直到有新对象可用。如果为正数,并且在时间到期后没有新对象可用,则引发。BLOCKmax-waitmax-waitNoSuchElementExceptionspring-doc.cn

  • 该选项创建并返回一个新对象(本质上使 THE MEANING 无意义)。GROWmax-activespring-doc.cn

test-on-borrowspring-doc.cn

falsespring-doc.cn

在从池中借用对象之前是否对其进行验证。如果对象验证失败,则会将其从池中删除,并尝试借用另一个对象。spring-doc.cn

test-on-returnspring-doc.cn

falsespring-doc.cn

在将对象返回到池之前是否对其进行验证。spring-doc.cn

test-while-idlespring-doc.cn

falsespring-doc.cn

对象是否由空闲对象 evictor ((如果有) )验证。如果对象验证失败,则会将其从池中删除。spring-doc.cn

eviction-run-interval-millisspring-doc.cn

-1spring-doc.cn

空闲对象 evictor 线程运行之间休眠的毫秒数。当为非正数时,不运行空闲对象 evictor 线程。spring-doc.cn

tests-per-eviction-runspring-doc.cn

3spring-doc.cn

在每次运行空闲对象 evictor 线程期间要检查的对象数(如果有)。spring-doc.cn

min-evictable-time-millisspring-doc.cn

1000 * 60 * 30(30 分钟)spring-doc.cn

对象在有资格被空闲对象 evictor (如果有) 逐出之前,可以在池中处于空闲状态的最短时间。spring-doc.cn

validation-query-basespring-doc.cn

LdapUtils.emptyName()spring-doc.cn

验证连接时使用的搜索库。仅在指定 、 或 时使用。test-on-borrowtest-on-returntest-while-idlespring-doc.cn

validation-query-filterspring-doc.cn

objectclass=*spring-doc.cn

验证连接时使用的搜索筛选条件。仅在指定 、 或 时使用。test-on-borrowtest-on-returntest-while-idlespring-doc.cn

validation-query-search-controls-refspring-doc.cn

null;默认搜索控制设置如上所述。spring-doc.cn

验证连接时要使用的实例的 ID。仅在指定 、 、 或 时使用。SearchControlstest-on-borrowtest-on-returntest-while-idlespring-doc.cn

non-transient-exceptionsspring-doc.cn

javax.naming.CommunicationExceptionspring-doc.cn

以逗号分隔的类列表。列出的异常被视为非暂时性 Age Invalidation 。如果对池化实例的调用引发了列出的任何异常(或其子类),则该对象将自动失效,而无需任何其他 testOnReturn 操作。ExceptionDirContextspring-doc.cn

Pool2 配置

用于配置池的元素上提供了以下属性:<ldap:pooling2 />DirContextspring-doc.cn

表 2.池化配置属性
属性 违约 描述

max-totalspring-doc.cn

-1spring-doc.cn

可以同时从此池中分配的活动连接总数(适用于所有类型)。您可以无限制地使用非正数。spring-doc.cn

max-total-per-keyspring-doc.cn

8spring-doc.cn

每个键的池分配的对象实例数 (签出或空闲) 的限制。达到限制时,子池将耗尽。负值表示没有限制。spring-doc.cn

max-idle-per-keyspring-doc.cn

8spring-doc.cn

可以在池中保持空闲状态的每种类型(只读或读写)的最大活动连接数,而不会释放额外的连接。负值表示没有限制。spring-doc.cn

min-idle-per-keyspring-doc.cn

0spring-doc.cn

可以在池中保持空闲状态的每种类型(只读或读写)的最小活动连接数,而无需创建额外的连接。您可以使用 0(默认值)来不创建 none。spring-doc.cn

max-waitspring-doc.cn

-1spring-doc.cn

池在引发异常之前等待 (没有可用连接时) 返回连接的最大毫秒数。您可以使用非正数无限期等待。spring-doc.cn

block-when-exhaustedspring-doc.cn

truespring-doc.cn

是否等待新对象可用。如果 max-wait 为正数,则如果时间到期后没有新对象可用,则抛出 a。NoSuchElementExceptionmaxWaitspring-doc.cn

test-on-createspring-doc.cn

falsespring-doc.cn

借用前是否验证对象。如果对象验证失败,则借用失败。spring-doc.cn

test-on-borrowspring-doc.cn

falsespring-doc.cn

指示对象在从池中借用之前是否经过验证的指示器。如果对象验证失败,则会将其从池中删除,并尝试借用另一个对象。spring-doc.cn

test-on-returnspring-doc.cn

falsespring-doc.cn

指示对象在返回到池之前是否经过验证的指示器。spring-doc.cn

test-while-idlespring-doc.cn

falsespring-doc.cn

指示对象是否由空闲对象 evictor ((如果有))验证的指示器。如果对象验证失败,则会将其从池中删除。spring-doc.cn

eviction-run-interval-millisspring-doc.cn

-1spring-doc.cn

空闲对象 evictor 线程运行之间休眠的毫秒数。当为非正数时,不运行空闲对象 evictor 线程。spring-doc.cn

tests-per-eviction-runspring-doc.cn

3spring-doc.cn

在每次运行空闲对象 evictor 线程期间要检查的对象数(如果有)。spring-doc.cn

min-evictable-time-millisspring-doc.cn

1000 * 60 * 30(30 分钟)spring-doc.cn

对象在有资格被空闲对象 evictor (如果有) 逐出之前,可以在池中处于空闲状态的最短时间。spring-doc.cn

soft-min-evictable-time-millisspring-doc.cn

-1spring-doc.cn

对象在有资格被空闲对象 evictor 驱逐之前可以在池中闲置的最短时间,额外的条件是每个键至少保留池中的最小对象实例数。如果将此设置设置为正值,则会覆盖此设置。min-evictable-time-millisspring-doc.cn

eviction-policy-classspring-doc.cn

org.apache.commons.pool2.impl.DefaultEvictionPolicyspring-doc.cn

此池使用的逐出策略实现。池尝试使用线程上下文类加载器加载类。如果失败,则池将尝试使用加载此类的类加载器来加载该类。spring-doc.cn

fairnessspring-doc.cn

falsespring-doc.cn

该池为等待公平借用连接的线程提供服务。 表示等待线程就像在 FIFO 队列中等待一样提供。truespring-doc.cn

jmx-enablespring-doc.cn

truespring-doc.cn

JMX 使用池的平台 MBean 服务器启用。spring-doc.cn

jmx-name-basespring-doc.cn

nullspring-doc.cn

JMX 名称库,用作分配给启用 JMX 的池的名称的一部分。spring-doc.cn

jmx-name-prefixspring-doc.cn

poolspring-doc.cn

JMX 名称前缀,用作分配给已启用 JMX 的池的名称的一部分。spring-doc.cn

lifospring-doc.cn

truespring-doc.cn

指示池是否具有相对于空闲对象或 FIFO(先进先出)队列的 LIFO (后进先出) 行为的指示器。LIFO 始终返回池中最近使用的对象,而 FIFO 始终返回空闲对象池中最早的对象spring-doc.cn

validation-query-basespring-doc.cn

LdapUtils.emptyPath()spring-doc.cn

用于验证搜索的基本 DN。spring-doc.cn

validation-query-filterspring-doc.cn

objectclass=*spring-doc.cn

用于验证查询的筛选条件。spring-doc.cn

validation-query-search-controls-refspring-doc.cn

null;默认搜索控制设置如上所述。spring-doc.cn

验证连接时要使用的实例的 ID。仅在指定 、 或 时使用SearchControlstest-on-borrowtest-on-returntest-while-idlespring-doc.cn

non-transient-exceptionsspring-doc.cn

javax.naming.CommunicationExceptionspring-doc.cn

以逗号分隔的类列表。列出的异常被视为非暂时性 Age Invalidation 。如果对池化实例的调用引发了列出的任何异常(或其子类),则该对象将自动失效,而无需任何其他 testOnReturn 操作。ExceptionDirContextspring-doc.cn

表 2.池化配置属性
属性 违约 描述

max-totalspring-doc.cn

-1spring-doc.cn

可以同时从此池中分配的活动连接总数(适用于所有类型)。您可以无限制地使用非正数。spring-doc.cn

max-total-per-keyspring-doc.cn

8spring-doc.cn

每个键的池分配的对象实例数 (签出或空闲) 的限制。达到限制时,子池将耗尽。负值表示没有限制。spring-doc.cn

max-idle-per-keyspring-doc.cn

8spring-doc.cn

可以在池中保持空闲状态的每种类型(只读或读写)的最大活动连接数,而不会释放额外的连接。负值表示没有限制。spring-doc.cn

min-idle-per-keyspring-doc.cn

0spring-doc.cn

可以在池中保持空闲状态的每种类型(只读或读写)的最小活动连接数,而无需创建额外的连接。您可以使用 0(默认值)来不创建 none。spring-doc.cn

max-waitspring-doc.cn

-1spring-doc.cn

池在引发异常之前等待 (没有可用连接时) 返回连接的最大毫秒数。您可以使用非正数无限期等待。spring-doc.cn

block-when-exhaustedspring-doc.cn

truespring-doc.cn

是否等待新对象可用。如果 max-wait 为正数,则如果时间到期后没有新对象可用,则抛出 a。NoSuchElementExceptionmaxWaitspring-doc.cn

test-on-createspring-doc.cn

falsespring-doc.cn

借用前是否验证对象。如果对象验证失败,则借用失败。spring-doc.cn

test-on-borrowspring-doc.cn

falsespring-doc.cn

指示对象在从池中借用之前是否经过验证的指示器。如果对象验证失败,则会将其从池中删除,并尝试借用另一个对象。spring-doc.cn

test-on-returnspring-doc.cn

falsespring-doc.cn

指示对象在返回到池之前是否经过验证的指示器。spring-doc.cn

test-while-idlespring-doc.cn

falsespring-doc.cn

指示对象是否由空闲对象 evictor ((如果有))验证的指示器。如果对象验证失败,则会将其从池中删除。spring-doc.cn

eviction-run-interval-millisspring-doc.cn

-1spring-doc.cn

空闲对象 evictor 线程运行之间休眠的毫秒数。当为非正数时,不运行空闲对象 evictor 线程。spring-doc.cn

tests-per-eviction-runspring-doc.cn

3spring-doc.cn

在每次运行空闲对象 evictor 线程期间要检查的对象数(如果有)。spring-doc.cn

min-evictable-time-millisspring-doc.cn

1000 * 60 * 30(30 分钟)spring-doc.cn

对象在有资格被空闲对象 evictor (如果有) 逐出之前,可以在池中处于空闲状态的最短时间。spring-doc.cn

soft-min-evictable-time-millisspring-doc.cn

-1spring-doc.cn

对象在有资格被空闲对象 evictor 驱逐之前可以在池中闲置的最短时间,额外的条件是每个键至少保留池中的最小对象实例数。如果将此设置设置为正值,则会覆盖此设置。min-evictable-time-millisspring-doc.cn

eviction-policy-classspring-doc.cn

org.apache.commons.pool2.impl.DefaultEvictionPolicyspring-doc.cn

此池使用的逐出策略实现。池尝试使用线程上下文类加载器加载类。如果失败,则池将尝试使用加载此类的类加载器来加载该类。spring-doc.cn

fairnessspring-doc.cn

falsespring-doc.cn

该池为等待公平借用连接的线程提供服务。 表示等待线程就像在 FIFO 队列中等待一样提供。truespring-doc.cn

jmx-enablespring-doc.cn

truespring-doc.cn

JMX 使用池的平台 MBean 服务器启用。spring-doc.cn

jmx-name-basespring-doc.cn

nullspring-doc.cn

JMX 名称库,用作分配给启用 JMX 的池的名称的一部分。spring-doc.cn

jmx-name-prefixspring-doc.cn

poolspring-doc.cn

JMX 名称前缀,用作分配给已启用 JMX 的池的名称的一部分。spring-doc.cn

lifospring-doc.cn

truespring-doc.cn

指示池是否具有相对于空闲对象或 FIFO(先进先出)队列的 LIFO (后进先出) 行为的指示器。LIFO 始终返回池中最近使用的对象,而 FIFO 始终返回空闲对象池中最早的对象spring-doc.cn

validation-query-basespring-doc.cn

LdapUtils.emptyPath()spring-doc.cn

用于验证搜索的基本 DN。spring-doc.cn

validation-query-filterspring-doc.cn

objectclass=*spring-doc.cn

用于验证查询的筛选条件。spring-doc.cn

validation-query-search-controls-refspring-doc.cn

null;默认搜索控制设置如上所述。spring-doc.cn

验证连接时要使用的实例的 ID。仅在指定 、 或 时使用SearchControlstest-on-borrowtest-on-returntest-while-idlespring-doc.cn

non-transient-exceptionsspring-doc.cn

javax.naming.CommunicationExceptionspring-doc.cn

以逗号分隔的类列表。列出的异常被视为非暂时性 Age Invalidation 。如果对池化实例的调用引发了列出的任何异常(或其子类),则该对象将自动失效,而无需任何其他 testOnReturn 操作。ExceptionDirContextspring-doc.cn

配置

配置池化需要添加嵌套在元素中的元素,如下所示:<ldap:pooling><ldap:context-source>spring-doc.cn

<beans>
   ...
    <ldap:context-source
        password="secret" url="ldap://localhost:389" username="cn=Manager">
        <ldap:pooling />
    </ldap:context-source>
   ...
</beans>

在实际情况下,您可能会配置池选项并启用连接验证。前面的示例演示了一般思路。spring-doc.cn

验证配置

以下示例在将每个对象传递到客户端应用程序之前对其进行测试,并测试池中一直处于空闲状态的对象:DirContextDirContextspring-doc.cn

<beans>
   ...
    <ldap:context-source
        username="cn=Manager" password="secret" url="ldap://localhost:389" >
        <ldap:pooling
            test-on-borrow="true"
            test-while-idle="true" />
    </ldap:context-source>
   ...
</beans>

已知问题

本节描述了人们在使用 Spring LDAP 时有时会出现的问题。目前,它涵盖了以下问题:spring-doc.cn

自定义身份验证

假定从中检索到的所有对象都具有相同的环境,同样,从中检索到的所有对象也具有相同的环境。这意味着用 an 包装 configure 并不能按预期工作。池将使用第一个用户的凭证填充,并且,除非需要新连接,否则不会为请求线程指定的用户填充后续上下文请求。PoolingContextSourceDirContextContextSource.getReadOnlyContext()DirContextContextSource.getReadWriteContext()LdapContextSourceAuthenticationSourcePoolingContextSourceAuthenticationSourcespring-doc.cn