Apache Pulsar サポート
Apache Pulsar (英語) は、Spring for Apache Pulsar プロジェクトの自動構成を提供することによってサポートされます。
org.springframework.pulsar:spring-pulsar がクラスパス上にある場合、Spring Boot は Spring for Apache Pulsar コンポーネントを自動的に構成して登録します。
使用にあたって依存関係を便利に収集するための spring-boot-starter-pulsar スターターがあります。
Pulsar への接続
Pulsar スターターを使用すると、Spring Boot は PulsarClient (英語) Bean を自動的に構成して登録します。
デフォルトでは、アプリケーションは pulsar://localhost:6650 にあるローカル Pulsar インスタンスへの接続を試行します。これは、spring.pulsar.client.service-url プロパティを別の値に設定することで調整できます。
| 値は有効な Pulsar プロトコル [Apache] (英語) URL である必要があります |
spring.pulsar.client.* というプレフィックスが付いたアプリケーションプロパティのいずれかを指定して、クライアントを構成できます。
構成をさらに細かく制御する必要がある場合は、1 つ以上の PulsarClientBuilderCustomizer (Javadoc) Bean を登録することを検討してください。
認証
認証が必要な Pulsar クラスターに接続するには、pluginClassName とプラグインに必要なパラメーターを設定して、使用する認証プラグインを指定する必要があります。パラメーターをパラメーター名とパラメーター値のマップとして設定できます。次の例は、AuthenticationOAuth2 プラグインを構成する方法を示しています。
プロパティ
YAML
spring.pulsar.client.authentication.plugin-class-name=org.apache.pulsar.client.impl.auth.oauth2.AuthenticationOAuth2
spring.pulsar.client.authentication.param.issuerUrl=https://auth.server.cloud/
spring.pulsar.client.authentication.param.privateKey=file:///Users/some-key.json
spring.pulsar.client.authentication.param.audience=urn:sn:acme:dev:my-instancespring:
pulsar:
client:
authentication:
plugin-class-name: org.apache.pulsar.client.impl.auth.oauth2.AuthenticationOAuth2
param:
issuerUrl: https://auth.server.cloud/
privateKey: file:///Users/some-key.json
audience: urn:sn:acme:dev:my-instance
例: また、バインディングが緩和されていないため、変換中に大文字と小文字の区別が失われるため、認証パラメーターに環境変数を使用することが問題になります。パラメーターに環境変数を使用する場合、正しく動作させるには、Spring for Apache Pulsar リファレンスドキュメントの次の手順に従う必要があります。 |
SSL
デフォルトでは、Pulsar クライアントは Pulsar サービスとプレーンテキストで通信します。Spring for Apache Pulsar リファレンスドキュメントの次の手順に従って、TLS 暗号化を有効にできます。
クライアントと認証の詳細については、Spring for Apache Pulsar リファレンスドキュメントを参照してください。
Pulsar 管理への接続
Spring for Apache Pulsar の PulsarAdministration (Javadoc) クライアントも自動構成されます。
デフォルトでは、アプリケーションは http://localhost:8080 にあるローカル Pulsar インスタンスへの接続を試行します。これは、spring.pulsar.admin.service-url プロパティを (http|https)://<host>:<port> の形式で別の値に設定することで調整できます。
構成をさらに細かく制御する必要がある場合は、1 つ以上の PulsarAdminBuilderCustomizer (Javadoc) Bean を登録することを検討してください。
認証
認証が必要な Pulsar クラスターにアクセスする場合、管理クライアントには通常の Pulsar クライアントと同じセキュリティ構成が必要です。spring.pulsar.client.authentication を spring.pulsar.admin.authentication に置き換えることで、前述の認証構成を使用できます。
起動時にトピックを作成するには、型 PulsarTopic (Javadoc) の Bean を追加します。トピックがすでに存在する場合、Bean は無視されます。 |
メッセージの送信
Spring の PulsarTemplate (Javadoc) は自動構成されており、次の例に示すように、これを使用してメッセージを送信できます。
Java
Kotlin
import org.springframework.pulsar.core.PulsarTemplate;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
private final PulsarTemplate<String> pulsarTemplate;
public MyBean(PulsarTemplate<String> pulsarTemplate) {
this.pulsarTemplate = pulsarTemplate;
}
public void someMethod() {
this.pulsarTemplate.send("someTopic", "Hello");
}
}import org.apache.pulsar.client.api.PulsarClientException
import org.springframework.pulsar.core.PulsarTemplate
import org.springframework.stereotype.Component
@Component
class MyBean(private val pulsarTemplate: PulsarTemplate<String>) {
@Throws(PulsarClientException::class)
fun someMethod() {
pulsarTemplate.send("someTopic", "Hello")
}
}PulsarTemplate (Javadoc) は、基盤となる Pulsar プロデューサーを作成するために PulsarProducerFactory (Javadoc) に依存します。Spring Boot 自動構成では、このプロデューサーファクトリも提供され、デフォルトでは、作成したプロデューサーがキャッシュされます。spring.pulsar.producer.* および spring.pulsar.producer.cache.* プレフィックス付きアプリケーションプロパティのいずれかを指定して、プロデューサーファクトリとキャッシュ設定を構成できます。
プロデューサーファクトリ構成をさらに制御する必要がある場合は、1 つ以上の ProducerBuilderCustomizer (Javadoc) Bean を登録することを検討してください。これらのカスタマイザーは、作成されたすべてのプロデューサーに適用されます。メッセージを送信するときに、現在のプロデューサーにのみ影響を与える ProducerBuilderCustomizer (Javadoc) を渡すこともできます。
送信されるメッセージをさらに制御する必要がある場合は、メッセージを送信するときに TypedMessageBuilderCustomizer (Javadoc) を渡すことができます。
メッセージの受信
Apache Pulsar インフラストラクチャが存在する場合、任意の Bean に @PulsarListener (Javadoc) のアノテーションを付けてリスナーエンドポイントを作成できます。次のコンポーネントは、someTopic トピックにリスナーエンドポイントを作成します。
Java
Kotlin
import org.springframework.pulsar.annotation.PulsarListener;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
@PulsarListener(topics = "someTopic")
public void processMessage(String content) {
// ...
}
}import org.springframework.pulsar.annotation.PulsarListener
import org.springframework.stereotype.Component
@Component
class MyBean {
@PulsarListener(topics = ["someTopic"])
fun processMessage(content: String?) {
// ...
}
}Spring Boot 自動構成は、PulsarListenerContainerFactory (Javadoc) や、基礎となる Pulsar コンシューマーの構築に使用するコンシューマーファクトリなど、PulsarListener (Javadoc) に必要なすべてのコンポーネントを提供します。これらのコンポーネントは、spring.pulsar.listener.* および spring.pulsar.consumer.* プレフィックス付きアプリケーションプロパティのいずれかを指定して構成できます。
コンシューマーファクトリの構成をさらに細かく制御する必要がある場合は、1 つ以上の ConsumerBuilderCustomizer (Javadoc) Bean を登録することを検討してください。これらのカスタマイザーは、ファクトリによって作成されたすべてのコンシューマーに適用され、すべての @PulsarListener (Javadoc) インスタンスに適用されます。@PulsarListener (Javadoc) アノテーションの consumerCustomizer 属性を設定することで、単一のリスナーをカスタマイズすることもできます。
実際のコンテナーファクトリ構成をさらに制御する必要がある場合は、1 つ以上の PulsarContainerFactoryCustomizer<ConcurrentPulsarListenerContainerFactory<?>> Bean を登録することを検討してください。
メッセージを読む
Pulsar リーダーインターフェースを使用すると、アプリケーションでカーソルを手動で管理できます。リーダーを使用してトピックに接続する場合、リーダーがトピックに接続するときにどのメッセージから読み始めるかを指定する必要があります。
Apache Pulsar インフラストラクチャが存在する場合、任意の Bean に @PulsarReader (Javadoc) のアノテーションを付けて、リーダーを使用してメッセージを消費できます。次のコンポーネントは、someTopic トピックの先頭からメッセージの読み取りを開始するリーダーエンドポイントを作成します。
Java
Kotlin
import org.springframework.pulsar.annotation.PulsarReader;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
@PulsarReader(topics = "someTopic", startMessageId = "earliest")
public void processMessage(String content) {
// ...
}
}import org.springframework.pulsar.annotation.PulsarReader
import org.springframework.stereotype.Component
@Component
class MyBean {
@PulsarReader(topics = ["someTopic"], startMessageId = "earliest")
fun processMessage(content: String?) {
// ...
}
}@PulsarReader (Javadoc) は、基盤となる Pulsar リーダーを作成するために PulsarReaderFactory (Javadoc) に依存しています。Spring Boot 自動構成では、このリーダーファクトリが提供されており、spring.pulsar.reader.* プレフィックスの付いたアプリケーションプロパティのいずれかを設定することでカスタマイズできます。
リーダーファクトリの構成をさらに細かく制御する必要がある場合は、1 つ以上の ReaderBuilderCustomizer (Javadoc) Bean を登録することを検討してください。これらのカスタマイザは、ファクトリによって作成されたすべてのリーダーに適用され、すべての @PulsarReader (Javadoc) インスタンスに適用されます。@PulsarReader (Javadoc) アノテーションの readerCustomizer 属性を設定することで、単一のリスナーをカスタマイズすることもできます。
実際のコンテナーファクトリ構成をさらに制御する必要がある場合は、1 つ以上の PulsarContainerFactoryCustomizer<DefaultPulsarReaderContainerFactory<?>> Bean を登録することを検討してください。
| 上記のコンポーネントの詳細と、その他の利用可能な機能については、Spring for Apache Pulsar リファレンスドキュメントを参照してください。 |
トランザクションサポート
Spring for Apache Pulsar は、PulsarTemplate (Javadoc) および @PulsarListener (Javadoc) を使用するときにトランザクションをサポートします。
spring.pulsar.transaction.enabled プロパティを true に設定すると、次のようになります。
PulsarTransactionManager(Javadoc) Bean を構成するPulsarTemplate(Javadoc) のトランザクションサポートを有効にする@PulsarListener(Javadoc) メソッドのトランザクションサポートを有効にする
@PulsarListener (Javadoc) の transactional 属性を使用すると、リスナーでトランザクションを使用するタイミングを微調整できます。
Spring for Apache Pulsar トランザクション機能をさらに制御するには、独自の PulsarTemplate (Javadoc) および / または ConcurrentPulsarListenerContainerFactory (Javadoc) Bean を定義する必要があります。また、デフォルトで自動構成された PulsarTransactionManager (Javadoc) が適していない場合は、PulsarAwareTransactionManager (Javadoc) Bean を定義することもできます。
Pulsar の追加プロパティ
自動構成でサポートされるプロパティは、付録の統合プロパティセクションに示されています。ほとんどの場合、これらのプロパティ (ハイフン付きまたは camelCase) は、Apache Pulsar 構成プロパティに直接マップされることに注意してください。詳細については、Apache Pulsar のドキュメントを参照してください。
Pulsar でサポートされているプロパティのサブセットのみが、PulsarProperties (Javadoc) クラスを通じて直接使用できます。直接サポートされていない追加のプロパティを使用して自動構成されたコンポーネントを調整する場合は、前述の各コンポーネントでサポートされているカスタマイザーを使用できます。