Infinispanクライアントエクステンションリファレンスガイド
Infinispanは、分散型のインメモリキー/バリューストアで、Quarkusアプリケーションに高度に設定可能で独立して拡張可能なデータレイヤーを提供します。このエクステンションでは、Quarkus上で動作するアプリケーションとリモートのInfinispanクラスターを接続するクライアント機能が提供されます。Infinispanを使い始めるには、以下をお勧めします:
-
入門チュートリアル に沿う(5分)。
-
リモートキャッシュ シンプルコードチュートリアル を実行する。
詳しくは、Infinispanのドキュメント をご覧ください。
インストール
Quarkusプロジェクトのベースディレクトリで以下のコマンドを実行し、 infinispan-client
エクステンションを追加します:
quarkus extension add infinispan-client
./mvnw quarkus:add-extension -Dextensions='infinispan-client'
./gradlew addExtension --extensions='infinispan-client'
このコマンドは、ビルドファイルに以下の依存関係を追加します:
<dependency>
<groupId>io.quarkus</groupId>
<artifactId>quarkus-infinispan-client</artifactId>
</dependency>
implementation 'io.quarkus:quarkus-infinispan-client'
annotationProcessor 'org.infinispan.protostream:protostream-processor:{infinispan-protostream-version}' (1)
1 | アノテーションベースのシリアライゼーションでファイル生成を有効にするため、Gradleビルドで必須 |
Infinispanへの接続
サーバーの実行
実行中のInfinispan Serverのインスタンスが少なくとも1つ必要です。
If you are running a Docker instance, you can use Infinispan Dev Services and connect without configuration.
Dockerを使用して自分でサーバーを実行したい場合は、Infinispan Serverを実行するための5分間の Infinispan入門 チュートリアルをチェックしてください。
また、${infinispan.version} Server ベアメタルディストリビューションを ダウンロード することが出来、ディストリビューションフォルダで以下のコマンドを実行します。
$ ./bin/server.sh
Infinispan Serverは デフォルトで認証とセキュリティ 認可を有効にしている ので、権限を持つユーザーを作成する必要があります。
-
Infinispan Server イメージ を実行する場合は、
USER="admin"
とPASS="password"
パラメータを渡します。 -
ベアメタルディストリビューション を実行する場合は、次のようにコマンドラインインターフェイス(CLI)を使用します:
$ ./bin/cli.sh user create admin -p password
Kubernetesでは、 Infinispan Operator をお勧めします。さらに、 Cross Site Replication のチュートリアルをご覧ください。ここでは、docker compose(ローカル開発用)とOperatorを使用して、2つの別々のInfinispanクラスターを実行する方法を学びます。
接続の設定
Infinispan Serverを実行している場合、 src/main/resources
ディレクトリの application.properties
ファイルに接続するための以下のプロパティを追加します。
quarkus.infinispan-client.hosts=localhost:11222 (1)
quarkus.infinispan-client.username=admin (2)
quarkus.infinispan-client.password=password (3)
1 | Infinispanサーバーのアドレスリストをカンマ区切りで設定します。 |
2 | 認証ユーザー名を設定 |
3 | 認証パスワードを設定 |
または、単一の接続プロパティを指定することで、uri接続を使用することもできます。
quarkus.infinispan-client.uri=hotrod://admin:password@localhost:11222 (1)
1 | InfinispanのURI接続を設定します。以下のプロパティは無視されます: hosts、username、password。 |
Infinispan Dev Services を使用してサーバーを実行し、設定なしで接続します。 |
Client intelligence
Infinispan client uses intelligence mechanisms to efficiently send requests to Infinispan Server clusters. By default, the HASH_DISTRIBUTION_AWARE intelligence mechanism is enabled. However, locally with Docker for Mac, you might experience connectivity issues. In this case, configure the client intelligence to BASIC.
Learn more in the Infinispan documentation.
quarkus.infinispan-client.client-intelligence=BASIC (1)
1 | Docker for Mac workaround. |
Don’t use BASIC in production environments by default, performance might be impacted. |
Configuring backup clusters in Cross-Site Replication
In High Availability production deployments, it is common to have multiple Infinispan Clusters that are distributed across various Data Centers worldwide. Infinispan offers the capability to connect these clusters and configure backups between them. This enables seamless switching between clusters through both automated and manual methods using a single connection. To achieve this, it is necessary to configure the client to direct to the backup clusters.
quarkus.infinispan-client.hosts=host1:11222,host2:3122 (1)
quarkus.infinispan-client.username=admin
quarkus.infinispan-client.password=password
quarkus.infinispan-client.backup-cluster.nyc-site.hosts=nyc1:11222,nyc2:21222,nyc3:31222 (2)
quarkus.infinispan-client.backup-cluster.nyc-site.client-intelligence=BASIC (3)
quarkus.infinispan-client.backup-cluster.lon-site.hosts=lon1:11222,lon2:21222,lon3:31222 (4)
1 | Sets Infinispan Server address list, separated with commas. This is the default cluster. |
2 | Configures a backup site 'nyc-site' with the provided address list |
3 | Configures a backup site 'nyc-site' with the provided client intelligence |
4 | Configures an additional backup site 'lon-site' with the provided address list |
Based on the provided configuration, in the event of the default cluster becoming unavailable, the client will seamlessly transition to one of the accessible backup clusters. Additionally, there is also the option to manually switch the client to an alternate cluster:
@ApplicationScoped
public class InfinispanExample {
@Inject
RemoteCacheManager cacheManager;
public void doSomething() {
cacheManager.switchToCluster("nyc-site"); (1)
cacheManager.switchToCluster("lon-site"); (2)
cacheManager.switchToDefaultCluster(); (3)
}
}
1 | The client connects to the 'nyc-site'. |
2 | The client connects to the 'lon-site'. |
3 | The client connects to the default site. |
By default, Protobuf Schemas will also be uploaded to the backup clusters. However, it might be required to handle
the registration manually as a schema may evolve over time when used in production, so you can
disable this from occurring in each backup site by configuring the
quarkus.infinispan-client.backup-cluster.YOUR_SITE_NAME.use-schema-registration
to false
.
The value of this property will be ignored if the use-schema-registration
global property is false
.
Cross-site replication is a powerful feature offered by Infinispan that facilitates data backup between clusters situated in geographically diverse data centers, even spanning across various cloud providers. Learn more in the Infinispan documentation. |
デフォルト接続と名前付き接続
This extension lets you configure a default Infinispan client connections and named ones. Named connections are essential to connect to multiple Infinispan clusters.
The default connection is configured using the quarkus.infinispan-client.*
properties as seen above.
When using the default connection, you can inject using a plain @Inject
:
Named clients are configured using the quarkus.infinispan-client.<name>.*
properties:
quarkus.infinispan-client.site-lon.hosts=localhost:11222
quarkus.infinispan-client.site-lon.username=admin
quarkus.infinispan-client.site-lon.password=password
quarkus.infinispan-client.site-nyc.hosts=localhost:31222
quarkus.infinispan-client.site-nyc.username=admin
quarkus.infinispan-client.site-nyc.password=password
Use the @InfinispanClientName
qualifier with dependency injection:
@ApplicationScoped
public class InfinispanExample {
@Inject
@InfinispanClientName("site-lon")
RemoteCacheManager rcmLon;
@Inject
@InfinispanClientName("site-nyc")
RemoteCacheManager rmcNyc;
}
Infinispan ヘルス・チェック
quarkus-smallrye-health エクステンションを使用している場合、Infinispan クライアントエクステンションは、接続を検証するためのReadinessヘルスチェックを自動的に追加します。
アプリケーションの /q/health/ready
エンドポイントにアクセスすると、サーバー接続と利用可能なキャッシュの情報が表示されます。
この動作は、プロパティ quarkus.infinispan-client.health.enabled
で無効にすることができます。
OpenTelemetryでトレース
InfinispanはOpenTelemetryによるサーバーのインスツルメンテーションをサポートしています。 quarkus-opentelemetry
エクステンションを追加することで、Infinispan クライアントからサーバーにトレースが伝搬されます。この動作は、プロパティ quarkus.infinispan-client.tracing.propagation.enabled
で無効にすることが出来ます。
クライアントからキャッシュを作成
クライアントからキャッシュにアクセスする際、Infinispan Server内にキャッシュが存在せず、初回アクセス時にキャッシュを作成したい場合は、以下のいずれかのプロパティを使用します。
quarkus.infinispan-client.cache.magazine.configuration=<distributed-cache><encoding media-type="application/x-protostream"/></distributed-cache> (1)
quarkus.infinispan-client.cache.books.configuration-resource=booksDistributedCache.json (2)
quarkus.infinispan-client.cache.authors.configuration-uri=/file/authorsIndexedCache.yaml (3)
1 | 'magazine' のxmlでの設定(yaml、jsonもサポートされています) |
2 | 'books' キャッシュの設定を含む resources フォルダー下のファイル名 |
3 | A provided file URI. The file URI can also be a file under resources |
If configuration-resource
, configuration
and configuration-uri
are configured for the same cache with
the same Quarkus profile, configuration-uri
gets the highest preference, over configuration-resource
and configuration
.
configuration-resource
gets preference over configuration
.
The |
キャッシュ設定は、XML、JSON、または YAML で提供することができます。Infinispan コンソールおよびキャッシュ設定ウィザードを使用して、Infinispan キャッシュの詳細について学び、ガイド付きの設定を作成してください。 |
特定のキャッシュについて何も設定されていない場合、以下の基本設定で作成されます。
<distributed-cache>
<encoding media-type="application/x-protostream"/>
</distributed-cache>
{
"distributed-cache": {
"encoding": {
"media-type": "application/x-protostream"
}
}
}
distributedCache:
encoding:
mediaType: "application/x-protostream"
認証メカニズム
Infinispanクライアントでは、以下の認証メカニズムを使用することができます:
-
DIGEST-MD5
-
PLAIN(TLS暗号化との併用のみ推奨)
-
EXTERNAL
SCRAMやGSSAPIなどの他の認証メカニズムは、Infinispanクライアントではまだ検証されていません。
認証の設定についての詳しい情報は Hot Rod Endpoint Authentication Mechanisms に存在します。
Dependency Injectionを使用する場合は、 hotrod-client.properties ファイルで認証の設定を行う必要があります。
|
シリアライゼーション(Key Value型のサポート)
デフォルトでは、クライアントは以下の型のキーとバリューをサポートします: byte[]、プリミティブラッパー(例: Integer、Long、Doubleなど)、String、Date、Instant。ユーザ型については、ここで詳しく説明される追加のステップが必要です。以下のようなユーザクラスがあるとします:
public record Author(String name, String surname) {
}
public record Book(String title,
String description,
int publicationYear,
Set<Author> authors,
Type bookType,
BigDecimal price) {
}
ユーザ型のシリアライズは、https://github.com/infinispan/protostream[Protostream]と呼ばれるprotobufをベースにしたライブラリを使用します。
Infinispanのキャッシュは、さまざまなエンコーディングでキーと値を保存できますが、 プロトコル・バッファ(Protobuf) の使用を推奨します。 詳しくは、 Cache Encoding and Marshalling ガイドをご覧ください。 |
アノテーションに基づくシリアライゼーション
これは、ユーザクラスに protostream アノテーションを追加することで自動的に行えます。加えて、初期化子がアノテーションされたインターフェースが1つ必要です。これは、サポートするクラスの生成方法を制御します。
ここでは、先述のクラスをどのように変更するかの例を示します:
@Proto (1)
public record Author(String name, String surname) { (2)
}
1 | Since Protostream 5.0, a single annotation is needed to generate a default mapping |
2 | Since Protostream 5.0, records are supported |
@Proto
public enum Type { (1)
FANTASY,
PROGRAMMING
}
1 | Enums are supported |
@Proto
@Indexed (1)
public record Book(@Text String title, (2)
@Keyword(projectable = true, sortable = true, normalizer = "lowercase", indexNullAs = "unnamed", norms = false) (3)
String description,
int publicationYear,
Set<Author> authors, (4)
Type bookType,
BigDecimal price) { (5)
}
1 | Indicates that the entity will be indexed. Necessary to perform distributed full-text query operations. |
2 | Indicates the title should be indexed as text |
3 | Indicates the description field field should be indexed as a Keyword. |
4 | Collections are supported |
5 | Protostreamは、BigDecimal のように、一般的に使用される型に対するデフォルトの Protobuf マッパーを提供します。これらは org.infinispan.protostream.types パッケージに含まれます。 |
必要なのは、設定を指定する為のアノテーションを付与した非常にシンプルな GeneratedSchema
インターフェイスだけです。
import org.infinispan.protostream.GeneratedSchema;
import org.infinispan.protostream.annotations.ProtoSchema;
import org.infinispan.protostream.types.java.math.BigDecimalAdapter;
@ProtoSchema(includeClasses = { Book.class, Author.class, BigDecimalAdapter.class }, schemaPackageName = "book_sample")
interface BookStoreSchema extends GeneratedSchema {
}
You can use the |
そこで今回は、含まれるクラスのマーシャラーとスキーマを自動生成して、スキーマパッケージに自動で配置します。パッケージは用意する必要はありませんが、Infinispan検索機能を利用する場合は生成されたパッケージを知っておく必要があります。
In Quarkus the schemaFileName and schemaFilePath attributes should NOT be set on the ProtoSchema annotation. Setting either attributes causes native runtime errors.
|
カスタムシリアライゼーション
前の方法は、ユーザが自分のクラスにアノテーションを付けられる場合のために提案されています。残念ながら、ユーザはキャッシュに入れるすべてのクラスにアノテーションを付けることができないかもしれません。このような場合はスキーマを定義し、自分で独自のマーシャラを作成しなければなりません。
- Protobuf スキーマ
-
2つの方法のいずれかでprotobufスキーマを提供できます。
-
Proto ファイル
プロジェクトのMETA-INF
ディレクトリに.proto
ファイルを置くことができます。これらのファイルは初期化時に自動的にピックアップされます。library.protopackage book_sample; message Book { required string title = 1; required string description = 2; required int32 publicationYear = 3; // no native Date type available in Protobuf repeated Author authors = 4; requited double price = 5; // no native BigDecimal type available in Protobuf but you can use the adapter } message Author { required string name = 1; required string surname = 2; }
-
In Code
Or you can define the proto schema directly in user code by defining a produced bean of typeorg.infinispan.protostream.schema.Schema
.@Produces Schema bookSchema() { return new Schema.Builder("book.proto") .packageName("book_sample") .addMessage("Author") .addField(Type.Scalar.STRING, "name", 1) .addField(Type.Scalar.STRING, "surname", 2) .addMessage("Book") .addField(Type.Scalar.STRING, "title", 1) .addField(Type.Scalar.STRING, "description", 2) .addField(Type.Scalar.INT32, "publicationYear", 3) .addRepeatedField(Type.create("Author"), "author", 4) .addField(Type.Scalar.DOUBLE, "price", 5) .build(); }
-
- ユーザマーシャラ
-
最後にすべきことは、proto スキーマで定義された各ユーザクラスの
org.infinispan.protostream.MessageMarshaller
実装を提供することです。このクラスは、上記のコードベースの proto スキーマの定義と同様の方法で@Produces
を介して提供されます。こちらは、Author と Book クラスのマーシャラクラスです。
型名は <protobuf package>.<protobuf message>
と正確に一致している必要があります!AuthorMarshaller.javapublic class AuthorMarshaller implements MessageMarshaller<Author> { @Override public String getTypeName() { return "book_sample.Author"; } @Override public Class<? extends Author> getJavaClass() { return Author.class; } @Override public void writeTo(ProtoStreamWriter writer, Author author) throws IOException { writer.writeString("name", author.getName()); writer.writeString("surname", author.getSurname()); } @Override public Author readFrom(ProtoStreamReader reader) throws IOException { String name = reader.readString("name"); String surname = reader.readString("surname"); return new Author(name, surname); } }
BookMarshaller.javapublic class BookMarshaller implements MessageMarshaller<Book> { @Override public String getTypeName() { return "book_sample.Book"; } @Override public Class<? extends Book> getJavaClass() { return Book.class; } @Override public void writeTo(ProtoStreamWriter writer, Book book) throws IOException { writer.writeString("title", book.getTitle()); writer.writeString("description", book.getDescription()); writer.writeInt("publicationYear", book.getPublicationYear()); writer.writeCollection("authors", book.getAuthors(), Author.class); writer.writeDouble("price", book.getPrice().doubleValue()); } @Override public Book readFrom(ProtoStreamReader reader) throws IOException { String title = reader.readString("title"); String description = reader.readString("description"); int publicationYear = reader.readInt("publicationYear"); Set<Author> authors = reader.readCollection("authors", new HashSet<>(), Author.class); BigDecimal price = BigDecimal.valueOf(reader.readDouble("price")); return new Book(title, description, publicationYear, authors, price); } }
そして、以下のように定義してマーシャラを渡します:
@Produces MessageMarshaller authorMarshaller() { return new AuthorMarshaller(); } @Produces MessageMarshaller bookMarshaller() { return new BookMarshaller(); }
上記のように生成されたMarshallerメソッドは、型なしで MessageMarshaller
を返さなければなりません。さもないと、それが見つかりません。
依存性注入
上で見たように、私たちはユーザーが Marshaller のコンフィギュレーションをインジェクションすることをサポートしています。Infinispan クライアントエクステンションでは、 RemoteCacheManager
と RemoteCache
オブジェクトへのインジェクションを提供し、その逆を行うことができます。 グローバルな RemoteCacheManager
が一つあり、上記のセクションで設定したすべてのコンフィギュレーションパラメータを受け取ります。
これらのコンポーネントをインジェクトするのは非常に簡単です。必要なのは、フィールド、コンストラクタ、またはメソッドに @Inject
アノテーションを追加することだけです。以下のコードでは、フィールドとコンストラクタのインジェクションを利用しています。
@Inject
SomeClass(RemoteCacheManager remoteCacheManager) {
this.remoteCacheManager = remoteCacheManager;
}
@Inject
@Remote("myCache")
RemoteCache<String, Book> cache;
RemoteCacheManager remoteCacheManager;
If you notice the RemoteCache
declaration has an additional annotation named Remote
.
This is a qualifier annotation allowing you to specify which named cache that will be injected. This
annotation is not required and if it is not supplied, the default cache will be injected.
The RemoteCacheManager and RemoteCache bean scope is @ApplicationScoped
.
デフォルト以外の接続の場合は、@InfinispanClientName
修飾子と @Remote
修飾子を組み合わせてください。
@Inject
@InfinispanClientName("lon-site")
@Remote("books")
RemoteCache<String, Book> lonBooks;
@Inject
@InfinispanClientName("nyc-site")
@Remote("books")
RemoteCache<String, Book> nycBooks;
その他の型は注入のためにサポートされている場合がありますが、詳細については他のセクションを参照してください |
モックサポート
Quarkus supports the use of mock objects using two different approaches. You can either use CDI alternatives to
mock out a bean for all test classes, or use QuarkusMock
to mock out beans on a per test basis.
Check the Getting started with testing guide for more information.
RemoteCacheManager and RemoteCache can be mocked.
@ApplicationScoped
public class BookService {
@Inject
@Remote("books")
RemoteCache<String, Book> books; (1)
public String getBookDescriptionById(String id) {
Book book = books.get(id);
if (book == null) {
return "default";
}
return book.getDescription();
}
}
1 | Use dependency injection to connect to the books cache |
In the test class, the RemoteCache can be mocked.
@QuarkusTest
public class BookServiceTest {
@Inject
BookService bookService;
@InjectMock (1)
@Remote("books")
RemoteCache<String, Book> bookRemoteCache;
@Test
public void mockRemoteCache() {
Mockito.when(bookRemoteCache.get("harry_potter")).thenReturn(new Book(... "Best saga ever");(2)
Assertions.assertThat(bookService.getBookDescriptionById("harry_potter")).isEqualTo("Best saga ever");(3)
}
}
1 | Inject a mock instead of the RemoteCache bean |
2 | Use Mockito to mock the call of the RemoteCache |
3 | Assert the service call |
InfinispanサーバへのProtobufスキーマの登録
クエリを実行したり、 Protobuf
から JSON
のような他のメディアタイプに変換するには、生成された Protobuf スキーマを Infinispan Server に登録する必要があります。
Infinispan Consoleにログインし、 Infinispan Dev Servicesガイド を確認し、Infinispan Dev Servicesサーバーに接続して下さい。 |
デフォルトでは、この方法で生成されたProtobufスキーマは、クライアントが最初に接続したときに、このエクステンションによって登録されます。 しかし、実運用で使用しているとスキーマが時間の経過とともに進化する可能性があるため、手動で登録を処理する必要があるかもしれません。そのため、`quarkus.infinispan-client.use-schema-registration`を`false`に設定して、この現象を無効にすることができます。
スキーマを手動で設定するには、Kubernetes デプロイメント用の Infinispan Operator 、Infinispan Console、 REST API または Hot Rod Java Client を使用してください。
アノテーションを利用したキャッシング
Infinispan Caching annotations are deprecated in this extension and will be removed.
Use or replace your annotations by using the Infinispan Cache extension.
Update your import statements to use the annotations from |
Infinispan Client エクステンションは、Infinispan でのキャッシュ能力を有効にするために CDI 管理 Bean で使用できるアノテーションのセットを提供します。
プライベートメソッドではアノテーションのキャッシュは許可されていません。package-private (明示的な修飾子を持たない) を含む他のアクセス修飾子では問題なく動作します。 |
@CacheResult
可能な限り、メソッドボディを実行せずにキャッシュからメソッドの結果を読み込みます。
@CacheResult
でアノテーションされたメソッドが呼び出されると、Quarkus はメソッドの引数をキャッシュキーとして使用し、そのメソッドがすでに呼び出されているかどうかをキャッシュでチェックします。複数のパラメータを持つメソッドは許可されません。複合キーの場合は、複数の値を保持するProtobufスキーマを定義します。キャッシュ内に値が見つかった場合、その値を返し、アノテーションされたメソッドは実際に実行されることはありません。値が見つからない場合、アノテーションされたメソッドが呼び出され、返された値は計算されたキーを使用してキャッシュに格納されます。このアノテーションは、 void
を返すメソッドには使用できません。
Infinispan Client エクステンションは、Quarkus-Cache エクステンションとは異なり、まだ null 値をキャッシュすることができません。
|
クエリ
The Infinispan client supports both indexed and non-indexed search as long as the
ProtoStreamMarshaller
is configured above. This allows the user to query on keys or
values based on the properties of the proto schema. Indexed queries are preferred for performance reasons.
<distributed-cache name="books" statistics="true">
<!-- other configuration -->
<indexing enabled="true" storage="filesystem" startup-mode="PURGE">
<indexed-entities>
<indexed-entity>book_sample.Book</indexed-entity>
</indexed-entities>
</indexing>
</distributed-cache>
{
"books": {
"distributed-cache": {
...
"indexing": {
"enabled": true,
"storage": "filesystem",
"startupMode": "PURGE",
"indexed-entities": [
"book_sample.Book"
]
}
}
}
}
distributedCache:
# other configuration
indexing:
enabled: "true"
storage: "filesystem"
startupMode: "PURGE"
indexedEntities:
- "book_sample.Book"
Query は、 ProtoStreamMarshaller
の設定時に設定できるproto定義に基づいて構築されます。上記のいずれのシリアライズ方法でも、起動時に自動的にスキーマをサーバに登録し、リモートの Infinispan サーバーに保存されているオブジェクトを問い合せる機能を自動的に得られます。
@Indexed (1)
public class Book {
@ProtoFactory
public Book(String title, String description, int publicationYear, Set<Author> authors) {
...
}
@ProtoField(number = 1)
@Text (2)
public String getTitle() {
return title;
}
@ProtoField(number = 2)
@Keyword(projectable = true, sortable = true, normalizer = "lowercase", indexNullAs = "unnamed", norms = false) (3)
public String getDescription() {
return description;
}
...
1 | @Indexed アノテーションは、POJOをインデックス可能にします |
2 | @Basic アノテーションは、インデックス付きフィールドに対して特別な変換を行わずに使用されます。 |
3 | @Keyword アノテーションは、テキストフィールドにnormalizer を適用するために使用します。 |
Quarkus Infinispanクライアントエクステンションでは、Query DSLまたはIckle Query 言語のいずれかを使用できます。
@Inject
@Remote("books")
RemoteCache<String, Book> booksCache; (1)
Query<Book> query = booksCache.query("from book_sample.Book b where b.authors.name like '%" + name + "%'"); (2)
List<Book> list = query.execute().list();
1 | Inject the books cache |
2 | Perform a full text query on books author name |
詳細は Infinispan のドキュメントの クエリ を参照してください。 |
Prior to Quarkus 3.9 and the Infinispan 15 integration, queries were executed by calling the following code: .Query.java
This code won’t work anymore since
|
カウンター
Infinispanにはカウンターという概念もあり、Quarkus Infinispanのクライアントはそれらもサポートしています。
Quarkus Infinispan クライアントエクステンションでは、 CounterManager
を直接依存性注入することができます。フィールド、コンストラクタ、メソッドにアノテーションを付けるだけで、簡単に取得できます。そして、通常と同じようにカウンタを使用することができます。
@Inject
CounterManager counterManager;
詳細は Infinispan のドキュメント クラスタカウンター を参照してください。
ニアキャッシング
ニアキャッシングはデフォルトでは無効ですが、次のプロパティを設定することで、キャッシュ単位で有効にすることができます:
quarkus.infinispan-client.cache.books.near-cache-mode=INVALIDATED (1)
quarkus.infinispan-client.cache.books.near-cache-max-entries=200 (2)
quarkus.infinispan-client.cache.books.near-cache-use-bloom-filter=true (3)
1 | モードを INVALIDATED に設定して 'books' キャッシュのニアキャッシュを有効にします |
2 | 'books' キャッシュのエビクションが発生するまでにニアキャッシュが保持できる最大エントリ数を設定します |
3 | 'books' キャッシュのブルームフィルタを有効にします |
暗号化
この時点での暗号化には、作業を開始するための追加のステップが必要です。
The first step is to configure the application.properties
file to point to your truststore
and/or keystore. This is further detailed here.
Infinispanクライアント拡張は、デフォルトでSSL/TLSを有効にします。これについては Using SSL With Native Executables に詳しく書かれています。
SSL Host Name Validation
To prevent MITM attacks, when SSL is enabled, SSL host name validation is enabled by default in Infinispan. In this case, configuring the SNI host name is mandatory to start the client.
quarkus.infinispan-client.sni-host-name=localhost (1)
1 | Sets the SNI host name |
This behaviour can be changed by disabling the validation.
quarkus.infinispan-client.ssl-host-name-validation=false (1)
1 | Disables ssl host name validation |
追加機能
Infinispanクライアントには、ここに記載されていない追加機能があります。これは、この機能がQuarkus環境でテストされていないことを意味し、それらは動作するかもしれませんし、動作しないかもしれません。これらの追加機能が必要な場合は、ぜひお知らせください。
Infinispanの開発サービス
開発モードまたはテストでinfinispan-clientエクステンションを使用すると、Quarkusは自動的にInfinispanサーバーを起動し、アプリケーションを設定します。
Infinispanの開発サービスの有効化/無効化
詳しくは、 Infinispan Dev Servicesのガイド をご覧ください。 |
共有サーバー
開発モードで複数のアプリケーションを実行している場合、QuarkusはInfinispanブローカーを共有します。 Infinispanの開発サービスは、 dev モードで実行されている複数のQuarkusアプリケーションが1つのブローカーを共有するための service discovery メカニズムを実装しています。
Infinispanの開発サービス は、コンテナを識別するために使用される quarkus-dev-service-infinispan ラベルでコンテナを起動します。
|
複数の(共有)Infinispanサーバーが必要な場合は、 quarkus.infinispan-client.devservices.service-name
属性を設定して、サーバー名を指定することが可能です。 同じ値を持つコンテナを探すか、見つからない場合は新しいコンテナを起動します。 デフォルトのサービス名は infinispan
です。
共有は、開発モードではデフォルトで有効ですが、テストモードでは無効になります。 共有は quarkus.infinispan-client.devservices.shared=false
で無効にすることができます。
ポートの設定
デフォルトでは、Infinispanの開発サービスはランダムなポートを選択し、アプリケーションを設定します。 ポートは quarkus.infinispan-client.devservices.port
プロパティを設定することによって定義することができます。
設定リファレンス
ビルド時に固定される構成プロパティ - 他のすべての構成プロパティは実行時にオーバーライド可能
Configuration property |
型 |
デフォルト |
---|---|---|
string |
||
boolean |
|
|
string |
||
string |
||
Sets client intelligence used by authentication Available values: * Environment variable: Show more |
string |
|
boolean |
|
|
string |
||
string |
||
string |
|
|
string |
|
|
Sets SASL mechanism used by authentication. Available values: * Environment variable: Show more |
string |
|
string |
||
string |
||
string |
||
string |
||
string |
||
string |
||
string |
||
string |
||
string |
||
list of string |
||
boolean |
||
string |
||
int |
||
Whether a tracing propagation is enabled in case the Opentelemetry extension is present. By default the propagation of the context is propagated from the client to the Infinispan Server. Environment variable: Show more |
boolean |
|
Enables or disables Protobuf generated schemas upload to the server. Set it to 'false' when you need to handle the lifecycle of the Protobuf Schemas on Server side yourself. Default is 'true'. This is a global setting and is not specific to a Infinispan Client. Environment variable: Show more |
boolean |
|
boolean |
|
|
Cache configuration file in XML, JSON or YAML is defined in build time to create the cache on first access. An example of the user defined property. cacheConfig.xml file is located in the 'resources' folder: quarkus.infinispan-client.cache.bookscache.configuration-resource=cacheConfig.xml Environment variable: Show more |
string |
|
Cache configuration in inlined XML to create the cache on first access. Will be ignored if the configuration-uri is provided for the same cache name. An example of the user defined property: quarkus.infinispan-client.cache.bookscache.configuration= Environment variable: Show more |
string |
|
Cache configuration file in XML, Json or YAML whose path will be converted to URI to create the cache on first access. An example of the user defined property. cacheConfig.xml file is located in the 'resources' folder: quarkus.infinispan-client.cache.bookscache.configuration-uri=cacheConfig.xml Environment variable: Show more |
string |
|
int |
||
Sets near cache mode used by the Infinispan Client Available values: * Environment variable: Show more |
|
|
Enables bloom filter for near caching. Bloom filters optimize performance for write operations by reducing the total number of invalidation messages. Environment variable: Show more |
boolean |
|
string |
required |
|
Sets client intelligence used by authentication Available values: * Environment variable: Show more |
string |
|
Enables or disables Protobuf generated schemas upload to the backup. Set it to 'false' when you need to handle the lifecycle of the Protobuf Schemas on Server side yourself. Default is 'true'. This setting will be ignored if the Global Setting is set up to false. Environment variable: Show more |
boolean |
|
型 |
デフォルト |
|
string |
||
Cache configuration file in XML, JSON or YAML is defined in build time to create the cache on first access. An example of the user defined property. cacheConfig.xml file is located in the 'resources' folder: quarkus.infinispan-client.cache.bookscache.configuration-resource=cacheConfig.xml Environment variable: Show more |
string |
|
string |
||
string |
||
Sets client intelligence used by authentication Available values: * Environment variable: Show more |
string |
|
boolean |
|
|
string |
||
string |
||
string |
|
|
string |
|
|
Sets SASL mechanism used by authentication. Available values: * Environment variable: Show more |
string |
|
string |
||
string |
||
string |
||
string |
||
Specifies the filename of a truststore to use to create the Environment variable: Show more |
string |
|
string |
||
string |
||
string |
||
string |
||
list of string |
||
boolean |
||
string |
||
int |
||
Whether a tracing propagation is enabled in case the Opentelemetry extension is present. By default the propagation of the context is propagated from the client to the Infinispan Server. Environment variable: Show more |
boolean |
|
Cache configuration in inlined XML to create the cache on first access. Will be ignored if the configuration-uri is provided for the same cache name. An example of the user defined property: quarkus.infinispan-client.cache.bookscache.configuration= Environment variable: Show more |
string |
|
Cache configuration file in XML, Json or YAML whose path will be converted to URI to create the cache on first access. An example of the user defined property. cacheConfig.xml file is located in the 'resources' folder: quarkus.infinispan-client.cache.bookscache.configuration-uri=cacheConfig.xml Environment variable: Show more |
string |
|
int |
||
Sets near cache mode used by the Infinispan Client Available values: * Environment variable: Show more |
|
|
Enables bloom filter for near caching. Bloom filters optimize performance for write operations by reducing the total number of invalidation messages. Environment variable: Show more |
boolean |
|
string |
required |
|
Sets client intelligence used by authentication Available values: * Environment variable: Show more |
string |
|
Enables or disables Protobuf generated schemas upload to the backup. Set it to 'false' when you need to handle the lifecycle of the Protobuf Schemas on Server side yourself. Default is 'true'. This setting will be ignored if the Global Setting is set up to false. Environment variable: Show more |
boolean |
|
型 |
デフォルト |
|
If DevServices has been explicitly enabled or disabled. DevServices is generally enabled by default, unless there is an existing configuration present. When DevServices is enabled Quarkus will attempt to automatically configure and start a database when running in Dev or Test mode and when Docker is running. Environment variable: Show more |
boolean |
|
When the configuration is empty, an Infinispan default client is automatically created to connect to the running dev service. However, there are scenarios where creating this client is unnecessary, yet we still need to spin up an Infinispan Server. In such cases, this property serves to determine whether the client should be created by default or not by the extension. Environment variable: Show more |
boolean |
|
int |
||
Indicates if the Infinispan server managed by Quarkus Dev Services is shared. When shared, Quarkus looks for running containers using label-based service discovery. If a matching container is found, it is used, and so a second one is not started. Otherwise, Dev Services for Infinispan starts a new container. The discovery uses the Container sharing is only used in dev mode. Environment variable: Show more |
boolean |
|
The value of the This property is used when you need multiple shared Infinispan servers. Environment variable: Show more |
string |
|
string |
||
List of the artifacts to automatically download and add to the Infinispan server libraries. For example a Maven coordinate (org.postgresql:postgresql:42.3.1) or a dependency location url. If an invalid value is passed, the Infinispan server will throw an error when trying to start. Environment variable: Show more |
list of string |
|
Add a site name to start the Infinispan Server Container with Cross Site Replication enabled (ex. lon). Cross Site Replication is the capability to connect two separate Infinispan Server Clusters that might run in different Data Centers, and configure backup caches to copy the data across the clusters with active-active or active-passive replication. See more about Cross Site Replication in the Infinispan Documentation https://infinispan.org/docs/stable/titles/xsite/xsite.html Configure Environment variable: Show more |
string |
|
If you are running an Infinispan Server already in docker, if the containers use the same mcastPort they will form a cluster. Set a different mcastPort to create a separate cluster in Docker (e. 46656). A common use case in a local Docker development mode, is the need of having two different Infinispan Clusters with Cross Site Replication enabled. see https://github.com/infinispan/infinispan-simple-tutorials/blob/main/infinispan-remote/cross-site-replication/docker-compose/ Environment variable: Show more |
int |
|
Map<String,String> |
||
list of string |
||
型 |
デフォルト |
|
If DevServices has been explicitly enabled or disabled. DevServices is generally enabled by default, unless there is an existing configuration present. When DevServices is enabled Quarkus will attempt to automatically configure and start a database when running in Dev or Test mode and when Docker is running. Environment variable: Show more |
boolean |
|
When the configuration is empty, an Infinispan default client is automatically created to connect to the running dev service. However, there are scenarios where creating this client is unnecessary, yet we still need to spin up an Infinispan Server. In such cases, this property serves to determine whether the client should be created by default or not by the extension. Environment variable: Show more |
boolean |
|
int |
||
Indicates if the Infinispan server managed by Quarkus Dev Services is shared. When shared, Quarkus looks for running containers using label-based service discovery. If a matching container is found, it is used, and so a second one is not started. Otherwise, Dev Services for Infinispan starts a new container. The discovery uses the Container sharing is only used in dev mode. Environment variable: Show more |
boolean |
|
The value of the This property is used when you need multiple shared Infinispan servers. Environment variable: Show more |
string |
|
string |
||
List of the artifacts to automatically download and add to the Infinispan server libraries. For example a Maven coordinate (org.postgresql:postgresql:42.3.1) or a dependency location url. If an invalid value is passed, the Infinispan server will throw an error when trying to start. Environment variable: Show more |
list of string |
|
Add a site name to start the Infinispan Server Container with Cross Site Replication enabled (ex. lon). Cross Site Replication is the capability to connect two separate Infinispan Server Clusters that might run in different Data Centers, and configure backup caches to copy the data across the clusters with active-active or active-passive replication. See more about Cross Site Replication in the Infinispan Documentation https://infinispan.org/docs/stable/titles/xsite/xsite.html Configure Environment variable: Show more |
string |
|
If you are running an Infinispan Server already in docker, if the containers use the same mcastPort they will form a cluster. Set a different mcastPort to create a separate cluster in Docker (e. 46656). A common use case in a local Docker development mode, is the need of having two different Infinispan Clusters with Cross Site Replication enabled. see https://github.com/infinispan/infinispan-simple-tutorials/blob/main/infinispan-remote/cross-site-replication/docker-compose/ Environment variable: Show more |
int |
|
Map<String,String> |
||
list of string |