eos/elasticsearch-5-connector

适用于 elasticsearch 5 的抽象 PHP 连接器

1.0.0 2019-10-15 14:08 UTC

This package is auto-updated.

Last update: 2024-09-16 02:13:11 UTC


README

适用于 elasticsearch 5 的抽象 PHP 连接器。

composer require eos/elasticsearch-7-connector

如何使用?

此库提供了具有基本功能的抽象类。您的域类(例如,仓库、事件处理器或命令处理器)应扩展 AbstractConnector 或,如果您想使用并行索引,则扩展 AbstractParallelIndexConnector

抽象类提供的方法

所有方法都定义为受保护的,并设计用于在您的扩展类中内部使用。

AbstractConnector:

AbstractParallelIndexConnector:

依赖项

AbstractConnector 需要一个 ConnectionFactoryInterface 的实例和一个 IndexDefinerInterface 的实例(AbstractParallelIndexConnector 则需要 ParellelIndexDefinerInterface)。

您可以选择提供 bulkSize。如果 bulkSize(默认为 0)大于 1,则将执行具有给定批量大小的批量请求,而不是为每个存储操作执行单个请求。

ConnectionFactoryInterface

连接工厂负责创建 Elasticsearch\Client 的实例。

ConnectionFactoryInterface 的提供的实现是 SimpleConnectionFactory,它将单个 (!) dsnscheme://host:port)作为构造函数参数。

IndexDefinerInterface

索引定义器提供包含/创建特定索引的 elasticsearch 定义的方法。

索引定义器可以提供多个索引定义,但每个类型只能有一个。

每种类型都将存储在自己的索引中。

如果您想为每种类型使用一个索引定义器,则您的索引定义器可以扩展 AbstractIndexDefiner 并添加到 IndexDefinerRegistry 的实例中。

如果您想将所有索引名称前缀为相同的基名称,则可以将 IndexDefinerRegistry 包装在 PrefixedIndexDefiner 的实例中(也可以将每个单个索引定义器包装在其自己的 PrefixedIndexDefiner 中或直接在索引定义器中定义完整的索引名称)。

Docker / Docker Compose

对于本地开发,可以创建并使用包含所有必需组件(php、composer)的 docker 容器

构建并启动容器

docker-compose up --build -d

在容器中执行命令(此处为 "composer install")

docker-compose exec app sh -c "composer install"