- PHP Client: other versions:
- Overview
- Quickstart
- Installation
- Configuration
- Inline Host Configuration
- Extended Host Configuration
- Authorization and Encryption
- Set retries
- Enabling the Logger
- Configure the HTTP Handler
- Setting the Connection Pool
- Setting the Connection Selector
- Setting the Serializer
- Setting a custom ConnectionFactory
- Set the Endpoint closure
- Building the client from a configuration hash
- Per-request configuration
- Future Mode
- Dealing with JSON Arrays and Objects in PHP
- Index Management Operations
- Indexing Documents
- Getting Documents
- Updating Documents
- Deleting documents
- Search Operations
- Namespaces
- Security
- Connection Pool
- Selectors
- Serializers
- PHP Version Requirement
- Breaking changes from 5.x
- Community DSLs
- Community Integrations
- Reference - Endpoints
- Elasticsearch\Client
- Elasticsearch\ClientBuilder
- Elasticsearch\Namespaces\CatNamespace
- Elasticsearch\Namespaces\ClusterNamespace
- Elasticsearch\Namespaces\IndicesNamespace
- Elasticsearch\Namespaces\IngestNamespace
- Elasticsearch\Namespaces\NodesNamespace
- Elasticsearch\Namespaces\RemoteNamespace
- Elasticsearch\Namespaces\SnapshotNamespace
- Elasticsearch\Namespaces\TasksNamespace
IMPORTANT: No additional bug fixes or documentation updates
will be released for this version. For the latest information, see the
current release documentation.
Heterogeneous batches are OK
editHeterogeneous batches are OK
editIt is possible to queue up heterogeneous batches of requests. For example, you can queue up several GETs, indexing requests and a search:
$client = ClientBuilder::create()->build(); $futures = []; $params = [ 'index' => 'test', 'type' => 'test', 'id' => 1, 'client' => [ 'future' => 'lazy' ] ]; $futures['getRequest'] = $client->get($params); // First request $params = [ 'index' => 'test', 'type' => 'test', 'id' => 2, 'body' => [ 'field' => 'value' ], 'client' => [ 'future' => 'lazy' ] ]; $futures['indexRequest'] = $client->index($params); // Second request $params = [ 'index' => 'test', 'type' => 'test', 'body' => [ 'query' => [ 'match' => [ 'field' => 'value' ] ] ], 'client' => [ 'future' => 'lazy' ] ]; $futures['searchRequest'] = $client->search($params); // Third request // Resolve futures...blocks until network call completes $searchResults = $futures['searchRequest']['hits']; // Should return immediately, since the previous future resolved the entire batch $doc = $futures['getRequest']['_source'];
ElasticON events are back!
Learn about the Elastic Search AI Platform from the experts at our live events.
Register nowWas this helpful?
Thank you for your feedback.