reasno / gotask
Go语言中Swoole TaskWorker的替代品
v3.0.1
2023-12-20 03:21 UTC
Requires
- php: >=8.1
- ext-swoole: >=5.0
- hyperf/pool: ^3.0
- hyperf/process: ^3.0
- spiral/goridge: ^2.4
- symfony/event-dispatcher: ^6.3
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.21
- hyperf/command: ^3.0
- hyperf/config: ^3.0
- hyperf/di: ^3.0
- hyperf/framework: ^3.0
- hyperf/testing: ^3.0
- mockery/mockery: ^1.6
- phpstan/phpstan: ^1.10
- swoole/ide-helper: ^5.0
- dev-master / 3.0.x-dev
- v3.0.1
- v3.0.0
- v3.0.0-alpha
- v2.2.10
- v2.2.9
- v2.2.8
- v2.2.7
- v2.2.6
- v2.2.5
- v2.2.4
- v2.2.3
- v2.2.2
- v2.2.1
- v2.2.0
- v2.1.x-dev
- v2.1.1
- v2.1.0
- v2.0.3
- v2.0.2
- v2.0.1
- v2.0.0
- v1.0.2
- v1.0.1
- v1.0.0
- v0.3.0
- 0.2.0
- v0.1.3
- v0.1.2
- 0.1.1
- 0.1.0
- 0.0.3
- dev-dependabot/composer/spiral/goridge-tw-2.4or-tw-4.0
- dev-dependabot/composer/symfony/event-dispatcher-tw-6.3or-tw-7.0
- dev-dependabot/composer/friendsofphp/php-cs-fixer-tw-2.14or-tw-3.0
- dev-perm
This package is auto-updated.
Last update: 2024-09-10 13:30:31 UTC
README
英文 | 中文
GoTask在Swoole旁边启动一个Go进程,并建立双向IPC以将重任务卸载到Go。可以将其视为Go中的Swoole Taskworker。
composer require hyperf/gotask
特性
- 高性能,占用小。
- 基于Swoole 4协程socket API。
- 支持Unix Socket、TCP和stdin/stdout管道。
- 支持PHP到Go和Go到PHP的调用。
- 自动管理边车生命周期。
- 正确处理远程错误。
- 支持结构化有效载荷和二进制有效载荷。
- 边车API与net/rpc兼容。
- 内置连接池。
- 可选集成Hyperf框架。
适用于
- Swoole中的阻塞操作,如MongoDB查询。
- CPU密集型操作,如编码和解码。
- 利用Go生态系统,如Kubernetes客户端。
要求
- PHP 7.2+
- Go 1.13+
- Swoole 4.4LTS+
- Hyperf 1.1+ (可选)
任务交付演示
package main import ( "github.com/hyperf/gotask/v2/pkg/gotask" ) type App struct{} func (a *App) Hi(name string, r *interface{}) error { *r = map[string]string{ "hello": name, } return nil } func main() { gotask.SetAddress("127.0.0.1:6001") gotask.Register(new(App)) gotask.Run() }
<?php use Hyperf\GoTask\IPC\SocketIPCSender; use function Swoole\Coroutine\run; require_once "../vendor/autoload.php"; run(function(){ $task = new SocketIPCSender('127.0.0.1:6001'); var_dump($task->call("App.Hi", "Hyperf")); // [ "hello" => "Hyperf" ] });
资源
英文文档尚未完成!请先查看示例。
基准测试
https://github.com/reasno/gotask-benchmark
致谢
- https://github.com/spiral/goridge 提供了IPC协议。
- https://github.com/twose 帮助创建了此项目。