Movatterモバイル変換


[0]ホーム

URL:


Event-driven, non-blocking I/O with PHP

ReactPHP is a low-level library for event-driven programming in PHP. At its core is an event loop, on top of which it provides low-level utilities, such as: Streams abstraction, async DNS resolver, network client/server, HTTP client/server and interaction with processes. Third-party libraries can use these components to create async network clients/servers and more.

<?php// $ composer require react/http react/socket # install example using Composer// $ php example.php # run example on command line, requires no additional web serverrequire__DIR__ .'/vendor/autoload.php';$http =newReact\Http\HttpServer(function (Psr\Http\Message\ServerRequestInterface$request) {returnReact\Http\Message\Response::plaintext("Hello World!\n"    );});$socket =newReact\Socket\SocketServer('127.0.0.1:8080');$http->listen($socket);echo"Server running at http://127.0.0.1:8080" .PHP_EOL;

This simple web server written in ReactPHP responds with "Hello World!" for every request.


ReactPHP is production ready and battle-tested with millions of installations from all kinds of projects around the world.

Its event-driven architecture makes it a perfect fit for efficient network servers and clients handling hundreds or thousands of concurrent connections, long-running applications and many other forms of cooperative multitasking with non-blocking I/O operations.

What makes ReactPHP special is its vivid ecosystem with hundreds of third-party libraries allowing you to integrate with many existing systems, such as common network services, database systems and other third-party APIs.

ReactPHP is non-blocking by default. Use workers for blocking I/O.

The event loop is based on the reactor pattern (hence the name) and strongly inspired by libraries such as EventMachine (Ruby), Twisted (Python) and Node.js (V8).

  • Production ready and battle-tested.
  • Rock-solid with stable long-term support (LTS) releases.
  • Requires no extensions and runs on any platform - no excuses!
  • Takes advantage ofoptional extensions to get better performance when available.
  • Supports latest version of PHP 8+ and PHP 7+ for best performance and support.
  • Stillsupports legacy PHP 5.3+ and HHVM for maximum compatibility.
  • Well designed andreusable components.
  • Decoupled parts so they can be replaced by alternate implementations.
  • Carefullytested (unit & functional).
  • Promotesstandard PSRs where possible for maximum interoperability.
  • Aims to betechnology neutral, so you can use your preferred application stack.
  • Smallcore team of professionals supported bylarge network of outside contributors.


Core Components

EventLoop

ReactPHP's core reactor event loop that libraries can use for evented I/O.

Read the documentation

Stream

Event-driven readable and writable streams for non-blocking I/O in ReactPHP.

Read the documentation

Promise

Promises/A implementation for PHP.

Read the documentation

Async

Async utilities and fibers for ReactPHP.

Read the documentation

Network Components

Socket

Async, streaming plaintext TCP/IP and secure TLS socket server and client connections for ReactPHP.

Read the documentation

Datagram

Event-driven UDP client and server sockets for ReactPHP.

Read the documentation

HTTP

Event-driven, streaming HTTP client and server implementation for ReactPHP.

Read the documentation

DNS

Async DNS resolver for ReactPHP.

Read the documentation

Utility Components

Cache

Async, Promise-based cache interface for ReactPHP.

Read the documentation

ChildProcess

Event-driven library for executing child processes with ReactPHP.

Read the documentation

PromiseTimer

A trivial implementation of timeouts for Promises, built on top of ReactPHP.

Read the documentation

PromiseStream

The missing link between Promise-land and Stream-land for ReactPHP.

Read the documentation

Legacy Components

HttpClient

[Deprecated] Event-driven, streaming HTTP client for ReactPHP.

Read the documentation

SocketClient

[Legacy] Async, streaming plaintext TCP/IP and secure TLS based connections for ReactPHP.

Read the documentation


Built with ReactPHP

Thruway

PHP Client and Router Library for Autobahn and WAMP (Web Application Messaging Protocol) for Real-Time Application Messaging

voryx/Thruway

PPM - PHP Process Manager

PPM is a process manager, supercharger and load balancer for modern PHP applications.

php-pm/php-pm

php-ar-drone

🚁 Port of node-ar-drone which allows user to control a Parrot AR Drone over PHP

jolicode/php-ar-drone

Ratchet

Asynchronous WebSocket server

ratchetphp/Ratchet

Predis\Async

Asynchronous PHP client library for Redis built on top of ReactPHP

nrk/predis-async

clue/redis-server

A Redis server implementation in pure PHP

clue/redis-server

And many more on our wiki page »


Articles

Sergey Zhuk

A series of articles covering ReactPHP: from the basics to the real application examples.

sergeyzhuk.me

Cees-Jan Kiewiet

Blog series about several ReactPHP components and how they work.

blog.wyrihaximus.net

Loïc Faugeron

Super Speed Symfony - ReactPHP.

gnugat.github.io

Marc J. Schmidt

Bring High Performance Into Your PHP App (with ReactPHP).

marcjschmidt.de


Talks

youtube.com
youtube.com
youtube.com

Get to know the people behind ReactPHP

We're a small core team of professionals. We help manage, maintain and steer the project.
But ReactPHP isn'tjust us. We're proudly supported by a large network of outside contributors from all over the world.

Christian Lück

Christian Lück

Cees-Jan Kiewiet

Cees-Jan Kiewiet

Jan Sorgalla

Jan Sorgalla

Chris Boden

Chris Boden


Support

Do you have a question and need help with ReactPHP?
Don't worry, we're here to help!

As a first step, check the elaborate documentation that comes with each component (see links to individual documentation for each component above). If you find your question is not answered within the documentation, there's a fair chance that it may be relevant to more people. Please do not hesitate to file your question as an issue in the relevant component so others can also participate.

You can find our official channel atreactphp/reactphp onGitter.im. Many of us are available in this channel, so many questions get answered in a few minutes to some hours. We also use this channel to announce all new releases and ongoing development efforts.

Also follow@reactphp on Twitter for updates. We use this mostly for noteworthy, bigger updates and to keep the community updated about ongoing development efforts. You can always use the#reactphp hashtag if you have anything to share!

We're a very open project and we prefer public communication whenever possible, so that more people can participate and help getting the best solutions available. At the same time, we realize that some things are better addressed in private.

Whether you just want to saythank you, want to report a security issue or want to help sponsor a certain feature development, you can reach out to the core team in private by sending an email to[email protected]. Please keep in mind that we're a small team of volunteers and do our best to support anybody reaching out.

Do you want to support ReactPHP? Awesome! Let's start with letting the the world know why you think ReactPHP is awesome and try to help others getting on board! Send a tweet, write a blog post, give a talk at your local user group or conference or even write a book. There are many ways you can help. You can always reach out to us in private and help others in our support channels. Thank you!


[8]ページ先頭

©2009-2025 Movatter.jp