spiral / roadrunner-bridge
RoadRunner integration package
Fund package maintenance!
spiral
Installs: 158 644
Dependents: 10
Suggesters: 0
Security: 0
Stars: 14
Watchers: 4
Forks: 7
Open Issues: 11
Requires
- php: >=8.1
- grpc/grpc: ^1.57
- psr/http-factory: ^1.1
- psr/simple-cache: ^3.0
- roadrunner-php/app-logger: ^1.0
- roadrunner-php/centrifugo: ^2.0
- roadrunner-php/lock: ^1.0
- spiral/grpc-client: ^1.0
- spiral/hmvc: ^3.14
- spiral/roadrunner-grpc: ^3.3
- spiral/roadrunner-http: ^3.5
- spiral/roadrunner-jobs: ^4.4
- spiral/roadrunner-kv: ^4.0
- spiral/roadrunner-metrics: ^3.0
- spiral/roadrunner-tcp: ^3.1 || ^4.0
- spiral/scaffolder: ^3.13
- spiral/serializer: ^3.13
Requires (Dev)
- buggregator/trap: ^1.10
- internal/dload: ^1.0.0
- phpunit/phpunit: ^10.5
- spiral/framework: ^3.14
- spiral/nyholm-bridge: ^1.3
- spiral/roadrunner-cli: ^2.6
- spiral/testing: ^2.8
- vimeo/psalm: ^5.25
Suggests
- ext-protobuf: For better performance, install the protobuf C extension.
- 4.x-dev
- v4.0.0-RC1
- v4.0.0-alpha2
- v4.0.0-alpha
- 3.x-dev
- v3.7.0
- v3.6.2
- v3.6.1
- v3.6.0
- v3.5.0
- 3.4.0
- 3.3.1
- 3.3.0
- 3.2.0
- 3.1.0
- 3.0.2
- 3.0.1
- 3.0.0
- 2.x-dev
- 2.6.0
- 2.5.1
- 2.5.0
- 2.4.0
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.0
- 2.1.0
- 2.0.1
- 2.0.0
- 2.0-beta2
- 2.0-beta1
- 2.0-beta
- 1.x-dev
- 1.3.0
- 1.2.0
- 1.1.0
- 1.0.0
- dev-feature/grpc-tokenizer
- dev-feature/rr-services
This package is auto-updated.
Last update: 2024-11-04 22:01:16 UTC
README
Requirements
Make sure that your server is configured with following PHP version and extensions:
- PHP 8.1+
- Spiral Framework 3.7+
Installation
To install the package:
composer require spiral/roadrunner-bridge
After package install you need to add bootloaders from the package in your application on the top of the list.
use Spiral\RoadRunnerBridge\Bootloader as RoadRunnerBridge; protected const LOAD = [ RoadRunnerBridge\HttpBootloader::class, // Optional, if it needs to work with http plugin RoadRunnerBridge\QueueBootloader::class, // Optional, if it needs to work with jobs plugin RoadRunnerBridge\CacheBootloader::class, // Optional, if it needs to work with KV plugin RoadRunnerBridge\GRPCBootloader::class, // Optional, if it needs to work with GRPC plugin RoadRunnerBridge\CentrifugoBootloader::class, // Optional, if it needs to work with centrifugo server RoadRunnerBridge\TcpBootloader::class, // Optional, if it needs to work with TCP plugin RoadRunnerBridge\MetricsBootloader::class, // Optional, if it needs to work with metrics plugin RoadRunnerBridge\LoggerBootloader::class, // Optional, if it needs to work with app-logger plugin RoadRunnerBridge\LockBootloader::class, // Optional, if it needs to work with lock plugin RoadRunnerBridge\ScaffolderBootloader::class, // Optional, to generate Centrifugo handlers and TCP services via Scaffolder RoadRunnerBridge\CommandBootloader::class, // ... ];
Usage
TCP
RoadRunner includes TCP server and can be used to replace classic TCP setup with much greater performance and flexibility.
Bootloader
Add Spiral\RoadRunnerBridge\Bootloader\TcpBootloader
to application bootloaders list:
use Spiral\RoadRunnerBridge\Bootloader as RoadRunnerBridge; protected const LOAD = [ // ... RoadRunnerBridge\TcpBootloader::class, // ... ];
This bootloader adds a dispatcher and necessary services for TCP to work.
Also, using the addService
and addInterceptors
methods can dynamically add services to TCP servers and configure
interceptors.
Configuration
Configure tcp
section in the RoadRunner .rr.yaml
configuration file with needed TCP servers. Example:
tcp: servers: smtp: addr: tcp://127.0.0.1:22 delimiter: "\r\n" # by default monolog: addr: tcp://127.0.0.1:9913 pool: num_workers: 2 max_jobs: 0 allocate_timeout: 60s destroy_timeout: 60s
Create configuration file app/config/tcp.php
. In the configuration, it's required to specify the services that
will handle requests from a specific TCP server. Optionally, interceptors can be added for each specific server.
With the help there, can add some logic before handling the request in service. Configuration example:
<?php declare(strict_types=1); return [ /** * Services for each server. */ 'services' => [ 'smtp' => SomeService::class, 'monolog' => OtherService::class ], /** * Interceptors, this section is optional. * @see https://spiral.dev/docs/cookbook-domain-core/2.8/en#core-interceptors */ 'interceptors' => [ // several interceptors 'smtp' => [ SomeInterceptor::class, OtherInterceptor::class ], 'monolog' => SomeInterceptor::class // one interceptor ], 'debug' => env('TCP_DEBUG', false) ];
Services
A service must implement the interface Spiral\RoadRunnerBridge\Tcp\Service\ServiceInterface
with one required
method handle
.
After processing a request, the handle
method must return the Spiral\RoadRunnerBridge\Tcp\Response\ResponseInterface
object
with result (RespondMessage
, CloseConnection
, ContinueRead
).
Example:
<?php declare(strict_types=1); namespace App\Tcp\Service; use Spiral\RoadRunner\Tcp\Request; use Spiral\RoadRunnerBridge\Tcp\Response\RespondMessage; use Spiral\RoadRunnerBridge\Tcp\Response\ResponseInterface; use Spiral\RoadRunnerBridge\Tcp\Service\ServiceInterface; class TestService implements ServiceInterface { public function handle(Request $request): ResponseInterface { // some logic return new RespondMessage('some message', true); } }
The service can be generated using the Scaffolder component. Make sure that bootloader
Spiral\RoadRunnerBridge\Bootloader\ScaffolderBootloader
is added in your application and run:
php app.php create:tcp-service Test
This will generate service TestService in the folder Endpoint/Tcp/Service/TestService.php.
Note Namespace (and generation path) can be configured. Read more about Scaffolder component.
Note Read more about RoadRunner configuration on official site https://roadrunner.dev.
License:
MIT License (MIT). Please see LICENSE
for more information. Maintained by Spiral Scout.