Amp alternatives and similar libraries
Based on the "Event" category.
Alternatively, view Amp alternatives based on common mentions on social networks and blogs.
7.0 0.0 L5 Amp VS BroadwayInfrastructure and testing helpers for creating CQRS and event sourced applications.
6.3 0.0 L4 Amp VS IcicleIcicle is a PHP library for writing asynchronous code using synchronous coding techniques
5.7 0.0 Amp VS EventSaucePHPA pragmatic event sourcing library for PHP with a focus on developer experience.
2.1 0.0 L5 Amp VS Cake Event[READ-ONLY] The event dispatcher library for CakePHP. This repo is a split of the main code that can be found in https://github.com/cakephp/cakephp
0.6 10.0 Amp VS Novalize for LaravelGenerate Laravel Nova admin panels at light speed with GPT-4.
0.5 10.0 Amp VS Ardillo Event LoopReactPHP Event Loop implementation for Ardillo
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of Amp or a related project?
Amp is a non-blocking concurrency framework for PHP. It provides an event loop, promises and streams as a base for asynchronous programming.
Promises in combination with generators are used to build coroutines, which allow writing asynchronous code just like synchronous code, without any callbacks.
Traditionally, PHP has a synchronous execution flow, doing one thing at a time. If you query a database, you send the query and wait for the response from the database server in a blocking manner. Once you have the response, you can start doing the next thing.
Instead of sitting there and doing nothing while waiting, we could already send the next database query, or do an HTTP call to an API.
Making use of the time we usually spend on waiting for I/O can speed up the total execution time. The following diagram shows the execution flow with dependencies between the different tasks, once executed sequentially and once concurrently.
Amp allows such concurrent I/O operations while keeping the cognitive load low by avoiding callbacks.
Instead, the results of asynchronous operations can be awaited using
yield resulting in code which is structured like traditional blocking I/O code while the actual execution flow is handled by Amp.
This package can be installed as a Composer dependency.
composer require amphp/amp
This installs the basic building blocks for asynchronous applications in PHP. We offer a lot of repositories building on top of this repository, e.g.
amphp/byte-streamproviding a stream abstraction
amphp/socketproviding a socket layer for UDP and TCP including TLS
amphp/parallelproviding parallel processing to utilize multiple CPU cores and offload blocking operations
amphp/http-clientproviding an HTTP/1.1 and HTTP/2 client
amphp/http-serverproviding an HTTP/1.1 and HTTP/2 application server
amphp/postgresfor non-blocking database access
- and many more packages
Documentation can be found on amphp.org as well as in the [
Each package has its own
This package requires PHP 7.0 or later. Many of the other packages raised their requirement to PHP 7.1. No extensions required!
Extensions are only needed if your app necessitates a high number of concurrent socket connections, usually this limit is configured up to 1024 file descriptors.
Examples can be found in the [
./examples](./examples) directory of this repository as well as in the
./examples directory of our other libraries.
amphp/amp follows the semver semantic versioning specification like all other
Supported. We don't have plans to release v3, yet.
No longer supported. We stopped providing bug fixes 2017-12-31 and stopped providing security fixes 2018-12-31.
Compatible packages should use the
amphp topic on GitHub.
If you discover any security related issues, please email
[email protected] instead of using the issue tracker.
The MIT License (MIT). Please see [
LICENSE](./LICENSE) for more information.
*Note that all licence references and agreements mentioned in the Amp README section above are relevant to that project's source code only.