schranz-search/seal-read-write-adapter

An adapter to support to split read and write operations for the schranz-search/seal package.

0.4.0 2024-03-18 21:03 UTC

This package is auto-updated.

Last update: 2024-03-29 09:11:30 UTC


README

Schranz Search Logo with a Seal on it with a magnifying glass

Schranz Search SEAL
Read Write Adapter



The ReadWriteAdapter allows to use one adapter instance for reading and one for writing. This is useful if you want to reindex something without a downtime.

Note: This is part of the schranz-search/schranz-search project create issues in the main repository.

Note: This project is heavily under development and any feedback is greatly appreciated.

Installation

Use composer for install the package:

composer require schranz-search/seal schranz-search/seal-read-write-adapter

Usage

To use the adapter an instance of ReadWriteAdapter need to be created which get a $readAdapter and $writeAdapter which are instances of the AdapterInterface.

The following code shows how to create an Engine using this Adapter:

<?php

use Schranz\Search\SEAL\Adapter\Elasticsearch\ElasticsearchAdapter;
use Schranz\Search\SEAL\Adapter\ReadWrite\ReadWriteAdapter;
use Schranz\Search\SEAL\Engine;

$readAdapter = new ElasticsearchAdapter(/* .. */); // can be any adapter
$writeAdapter = new ElasticsearchAdapter(/* .. */); // can be any adapter

$engine = new Engine(
    new ReadWriteAdapter(
        $readAdapter,
        $writeAdapter
    ),
    $schema,
);

Via DSN for your favorite framework:

multi://readAdapter?adapters[]=writeAdapter
read-write://readAdapter?write=multiAdapter

Note Read a document and partial update it based on the read document should be avoided when using this adapter, as the read document could already be outdated. So always fully update the document and never do based on read documents. Have a look at the MultiAdapter to write into read and write adapter.

Authors