Concurrency & Pools
Saloon supports request concurrency and requests pools out of the box. This allows you to make multiple API calls to the same service while keeping the CURL connection open. Under the hood, it uses PHP's cURL multi-handler to keep the connection open, this results in huge speed benefits when making lots of API calls. Saloon's concurrency is powered by Guzzle's implementation behind the scenes.
One of Laravel's core members, Nuno Maduro wrote a great blog post about request concurrency and its performance with Guzzle directly. The same performance can be shared with Saloon's implementation as Saloon uses Guzzle behind the scenes.
Concurrency is only supported with the GuzzleSender
and HttpSender
senders for Saloon. The default sender out of the box with Saloon is the GuzzleSender.
We conducted our own benchmark by making 1,000 API calls to our internal testing API, running on a virtual server with 2 vCPUs and 2GB of RAM. The results were impressive, as all 1,000 API calls were completed in just 2.5 seconds, a significant improvement compared to 60 seconds when using synchronous requests.
Getting Started
Saloon's pooling has been designed specifically to be easy to use. Simply instantiate your connector class and use the pool
method to create a pool. This method doesn't require any arguments, but you may provide requests, concurrency and handlers right from this method.
Available Methods
setRequests(callable|iterable $requests)
getRequests()
withResponseHandler(callable $callable)
withExceptionHandler(callable $callable)
send()
Providing Requests
The pool class accepts many types of requests:
Array of requests
PHP generator providing requests
Closure or Invokable class returning an array of requests
Closure or Invokable class returning a generator
You may provide these requests into the pool either as the first argument of the pool
method or using the setRequests
method. The requests can be instances of Saloon\Http\Request
or Saloon\Http\PendingRequest
.
Array of requests
The simplest way to provide requests to the pool is an array.
Using a PHP generator
If you are going to send lots of requests you may wish to provide a generator into the pool. This allows you to keep memory consumption low and potentially send hundreds of requests.
Using a callable or invokable class
You may wish to use a callable method to return an array of requests or a generator, this is useful if you have any additional logic that needs to execute just before the request pool begins.
Concurrency
By default, Saloon will send up to 5 requests concurrently. You can customise the concurrency that is used by pools with the setConcurrency
method. It accepts an integer or a callable like a method or an invokable class in case you want to write advanced logic to determine the concurrency.
Response Handlers
When you send requests with pooling, each request is asynchronous, so you cannot guarantee when they are returned. In order to handle the response, Saloon has provided you with two handlers to handle successful requests and failed requests.
Handling Successful Requests
Any responses that are successful will be handled by the response handler. You may add this with the constructor of your pool or add it once it is created. You can only have one handler. You will get a response instance.
Handling Failed Requests
When requests fail, they will always be caught with the error handler, even if you don't throw on requests. When a failed request happens you can handle the exception with the withExceptionHandler
method.
Named/Keyed Requests
Saloon also supports keyed responses to help you easily track exact requests that have been sent. This is especially useful if you are sending requests to different endpoints. You may use keying with arrays or even with a generator.
Sending
Once you have provided the pool with requests, you are ready to send them. Just use the send
method on the pool. This will return an instance of PromiseInterface
. Requests will be handled asynchronously but you can force them to complete with the wait
method.
Last updated